Índice
Objetivo
Este guia é destinado aos desenvolvedores internos e externos da plataforma que desejam utilizar o componente de recorte de imagem. O objetivo é apresentar o seu funcionamento e o detalhamento de todos os parâmetros de configuração.
Pré-requisitos
- Conhecer os conceitos dos componentes de negócio do TOTVS Fluig Plataforma, disponíveis na página Componentes de Negócio.
Recorte de imagem
O componente de recorte de imagem tem como objetivo facilitar o processo de atualização de imagens encapsulando todas as configurações básicas necessárias para essa atualização, restando para o desenvolvedor somente configurar o plugin e utilizar o callback para montar sua lógica de negócio.
Estrutura Básica
WCMBC.cropImage(config, callback);
Como pode-se notar na estrutura básica, o componente recebe basicamente dois parâmetros:
- o primeiro, um objeto config com as configurações do componente;
- e o segundo uma função callback contendo o erro e/ou o sucesso da atualização.
O primeiro parâmetro espera um objeto contendo sete atributos: alias, title, types, imageShape, imageSrc, saveCallback e cancelCallback, onde os parâmetros são opcionais.
var config = { alias: 'bruno.quadrotti', //alias do usuário/comunidade que será atualizada - Valor default: alias do usuário logado. title: 'Atualização de imagem de comunidade', //título do modal de troca de imagem. - Valor default: Editar foto types: 'gif|jpg|jpeg|tiff|png', //string contendo as extensões permitidas para atualização separado por pipeline "|". - Valor default: jpg|jpeg|png imageShape: 'rounded', //string com o formato de imagem a ser apresentado, conforme os formatos do guia de estilos('rounded', 'circle' ou '') imageSrc: 'http://www.fluig.com/assets/images/logo_fluig.png', //url da imagem saveCallback: function(data){}, //função callback para a ação de salvar imagem, onde "data" são as coordenadas definidas para o recorte da imagem cancelCallback: function(){} //função callback callback para cancelar a função de crop };
O segundo parâmetro espera uma função que recebe dois valores: error e data.
function(error, data) { if(error) { //tratamento de erro... } //lógica do sucesso... }
Utilização Básica
var UserPreferences = SuperWidget.extend({ alias: null, type: null, bindings: { local: { 'update-image': ['click_updateImage'] } }, init: function() { this.type = 'gif|jpg|jpeg|png'; }, updateImage: function(el, ev) { var that = this; WCMBC.cropImage({ alias: this.alias, types: this.type }, function(err, data) { if(err) { return alert(err.responseText); } that.someFunc(data); }); }, someFunc: function(data) { //Qualquer coisa com o retorno de sucesso... } });
No application.info de seu widget, adicione o componente como dependência:
application.resource.component.1=wcm/cropimage