<?xml version="1.0" encoding="UTF-8"?>
|
|
<panel-form xmlns="http://www.davinti.com.br/vitruvio/form/panel" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
xsi:schemaLocation="http://www.davinti.com.br/vitruvio/form/panel https://bitbucket.org/davinTI/vitruvio-xds/raw/master/vitruvio-panel-form.xsd">
|
|
<form formKey="formCadastroPadrao" height="100%" width="100%">
|
|
<name>Operações</name>
|
|
<description>Cadastro de Operações</description>
|
|
<afterFormRenderScript language="JavaScript">
|
|
<![CDATA[
|
|
/*, */
|
|
var config = { "tabela" :
|
|
{
|
|
"conexao" : "vitruvio",
|
|
"nome" : "OPERACAO" ,
|
|
"sequence" : "OPERACAO_SEQ" ,
|
|
"idTabela" : "CODIGO",
|
|
"campos" : ["CODIGO", "NOME" ],
|
|
"camposTable" : ["CODIGO", "DESCRICAO"]
|
|
},
|
|
"relaciona" : [ ["CODIGO","idChave","Number"] ,
|
|
["NOME","idDescricao","String"]
|
|
] ,
|
|
"validacaoExclusao" : [ ["SELECT 0 AS CONTAR FROM OPERACAO WHERE CODIGO = ", "Existem registros ligados a esta tabela."],
|
|
["SELECT COUNT(CHAVE_OPERACAO) AS CONTAR FROM CONTROLE_DESPESAS_OPERACIONAIS WHERE CHAVE_OPERACAO = ", "Existem registros ligados a esta tabela."],
|
|
["SELECT COUNT(CHAVE_OPERACAO) AS CONTAR FROM CONTROLE_DESPESAS_COMBUSTIVEIS WHERE CHAVE_OPERACAO = ", "Existem registros ligados a esta tabela."],
|
|
["SELECT COUNT(CHAVE_OPERACAO) AS CONTAR FROM CONTROLE_RECEITAS_FRETES WHERE CHAVE_OPERACAO = ", "Existem registros ligados a esta tabela."]
|
|
],
|
|
'painel' :
|
|
{
|
|
'titulo' : 'Cadastro de Operações',
|
|
'icone' : ''
|
|
}
|
|
};
|
|
function run()
|
|
{
|
|
engine.setGlobalVariable('config', config);
|
|
}
|
|
]]>
|
|
|
|
</afterFormRenderScript>
|
|
<initScript language="JavaScript">
|
|
<;
|
|
engine.getField('socios')['setValue(java.lang.Object)'](null);
|
|
engine.getField('socioLista').getContainerDataSource().removeAllItems();
|
|
engine.getField('socioPercentual').getContainerDataSource().removeAllItems();
|
|
engine.getField('twinUsuario')["setValue(java.lang.Object)"](null);
|
|
engine.getField('idPesquisaLista')['setValue(java.lang.String)'](null);
|
|
};
|
|
|
|
var habilitaCampos = function(lHabilita){
|
|
|
|
var botaoNovo = engine.getWidgetController('btnNovo').getButton();
|
|
var botaoSalvar = engine.getWidgetController('btnSalvar').getButton();
|
|
var botaoExcluir = engine.getWidgetController('btnExcluir').getButton();
|
|
var botaoVoltar = engine.getWidgetController('btnVoltar').getButton();
|
|
|
|
botaoNovo.setEnabled(true);
|
|
botaoSalvar.setEnabled(lHabilita);
|
|
botaoExcluir.setEnabled(lHabilita);
|
|
|
|
if(engine.getGlobalVariable('painelLista') == 1) {
|
|
botaoVoltar.setVisible(false);
|
|
botaoSalvar.setVisible(false);
|
|
botaoExcluir.setVisible(false);
|
|
} else {
|
|
botaoVoltar.setVisible(true);
|
|
botaoSalvar.setVisible(true);
|
|
botaoExcluir.setVisible(true);
|
|
}
|
|
|
|
var config = engine.getGlobalVariable('config');
|
|
var lib = libService.loadScript('lib_cadastro_padrao');
|
|
var retorno = lib.fncHabilitaCampos(config, lHabilita);
|
|
|
|
engine.getField('idChave').setEnabled(false);
|
|
|
|
engine.getField('listaPrincipal').refresh();
|
|
};
|
|
|
|
var novoRegistro = function() {
|
|
fncLimpaCampos();
|
|
|
|
habilitaCampos(true);
|
|
engine.getLayout('pnlTitulo').getRootComposition().setVisible(false);
|
|
engine.getLayout('pnlInclusao').getRootComposition().setVisible(true);
|
|
//engine.getWidgetController('btnVoltar').getButton().setVisible(true);
|
|
engine.getField('idPesquisaLista')['setValue(java.lang.String)'](null);
|
|
engine.getField('listaPrincipal').refresh();
|
|
|
|
engine.getField('idChave').focus();
|
|
|
|
};
|
|
|
|
var carregarCampos = function(id) {
|
|
|
|
var config = engine.getGlobalVariable('config');
|
|
var lib = libService.loadScript('lib_cadastro_padrao');
|
|
var sql = lib.fncCarregarCampos(config, id);
|
|
var sql = "Select s.nome, os.participacao from operacao_socio os inner join operacao o on o.codigo = os.codigo_operacao inner join socios s on s.codigo = os.codigo_socio where os.codigo_operacao = " + id;
|
|
var db = libService.loadScript('db');
|
|
var dbVitruvio = new db('vitruvio');
|
|
var containerPercentual = engine.getField("socioPercentual").getContainerDataSource();
|
|
var containerSocio = engine.getField("socioLista").getContainerDataSource();
|
|
dbVitruvio.query(sql).each(function (r) {
|
|
if (r.nome) {
|
|
containerSocio.addItem(r.nome).getItemProperty("caption").setValue(r.nome);
|
|
containerPercentual.addItem(r.nome).getItemProperty("caption").setValue(String(r.participacao));
|
|
}
|
|
});
|
|
sql = "Select codigo_usuario from operacao_usuario where codigo_operacao = " + id;
|
|
var ids = new java.util.ArrayList();
|
|
dbVitruvio.query(sql).each(function (r) {
|
|
if (r.codigo_usuario) {
|
|
ids.add(r.codigo_usuario);
|
|
}
|
|
});
|
|
engine.getField('twinUsuario').setValue(ids);
|
|
|
|
};
|
|
|
|
var telaInicial = function() {
|
|
engine.getLayout('pnlTitulo').getRootComposition().setVisible(true);
|
|
engine.getLayout('pnlInclusao').getRootComposition().setVisible(false);
|
|
var botaoNovo = engine.getWidgetController('btnNovo').getButton();
|
|
var botaoSalvar = engine.getWidgetController('btnSalvar').getButton();
|
|
var botaoExcluir = engine.getWidgetController('btnExcluir').getButton();
|
|
var botaoVoltar = engine.getWidgetController('btnVoltar').getButton();
|
|
|
|
botaoNovo.setVisible(true);
|
|
botaoNovo.setEnabled(true);
|
|
botaoSalvar.setVisible(false);
|
|
botaoExcluir.setVisible(false);
|
|
botaoVoltar.setVisible(false);
|
|
|
|
}
|
|
|
|
var deletarRegistro = function(id) {
|
|
var config = engine.getGlobalVariable('config');
|
|
var lib = libService.loadScript('lib_cadastro_padrao');
|
|
var retorno = lib.fncDeletarRegistro(config, id);
|
|
if (retorno) {
|
|
//engine.getField('idChave').setValue(params.get('id'));
|
|
engine.getGlobalVariable('fncLimpaCampos')();
|
|
engine.getGlobalVariable('habilitaCampos')(true);
|
|
}
|
|
}
|
|
|
|
var validarDuplicidade = function(valor) {
|
|
var sql = "Select count(nome) ct from OPERACAO where NOME = '" + valor + "'";
|
|
var db = libService.loadScript('db');
|
|
var dbVitruvio = new db('vitruvio');
|
|
var row = dbVitruvio.queryRow(sql);
|
|
if (row.ct == 0 ) {
|
|
return false;
|
|
} else {
|
|
if (engine.getField('idChave').getValue()) {
|
|
//engine.getField('idPesquisa')['setValue(java.lang.Object)'](null);
|
|
return false;
|
|
} else {
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
function run() {
|
|
var config = engine.getGlobalVariable('config');
|
|
var titulo = config['painel'].titulo;
|
|
var icone = config['painel'].icone;
|
|
engine.getLabel('Descricaocadastro').setValue('<p align="center"><img align="left" alt="" src="'+ icone + '" width="56" /><p align="center"><font color="Gray" face="Calibri" size="6" > ' + titulo + '</font></p></p>');
|
|
engine.getLabel('DescricaocadastroDentro').setValue('<p align="center"><img align="left" alt="" src="'+ icone + '" width="56" /><p align="center"><font color="Gray" face="Calibri" size="6" > ' + titulo + '</font></p></p>');
|
|
engine.setGlobalVariable('novoRegistro', novoRegistro);
|
|
engine.setGlobalVariable('carregarCampos', carregarCampos);
|
|
engine.setGlobalVariable('habilitaCampos', habilitaCampos);
|
|
engine.setGlobalVariable('fncLimpaCampos', fncLimpaCampos);
|
|
engine.setGlobalVariable('telaInicial', telaInicial);
|
|
engine.setGlobalVariable('deletarRegistro', deletarRegistro);
|
|
engine.setGlobalVariable('validarDuplicidade', validarDuplicidade);
|
|
engine.setGlobalVariable('painelLista',1);
|
|
engine.getField('socioPercentual').setEnabled(false);
|
|
|
|
//fncLimpaCampos();
|
|
habilitaCampos(false);
|
|
|
|
engine.getWidgetController('btnSalvar').getButton().setIcon(IconFactory.instance().getIconAsResource(IconLibraryAPISmall.APLICAR));
|
|
engine.getWidgetController('btnNovo').getButton().setIcon(IconFactory.instance().getIconAsResource(IconLibraryAPISmall.CRIAR));
|
|
engine.getWidgetController('btnExcluir').getButton().setIcon(IconFactory.instance().getIconAsResource(IconLibraryAPISmall.REMOVER));
|
|
engine.getWidgetController('btnVoltar').getButton().setIcon(IconFactory.instance().getIconAsResource(IconLibraryAPISmall.VOLTAR));
|
|
engine.getWidgetController('btnPercentual').getButton().setIcon(FontAwesome.PLUS);
|
|
engine.getWidgetController('btnRemoverPercentual').getButton().setIcon(FontAwesome.MINUS);
|
|
//engine.getFieldLocked('idAjuda', false); // pode ser erro no componente, aberto caso Eduardo = 20108
|
|
telaInicial();
|
|
|
|
}
|
|
]]>
|
|
</initScript>
|
|
<components>
|
|
<VerticalLayout spacing="false" margin="false" height="100%" width="100%" align="TOP_LEFT" >
|
|
<Panel width="100%" caption="" height="100%" expandRatio="1" margin="false" id="pnlTitulo" align="TOP_LEFT" >
|
|
<VerticalLayout width="100%" expandRatio="1" margin="true">
|
|
<Label id="Descricaocadastro" contentMode="HTML" align="MIDDLE_CENTER" width="100%" > </Label>
|
|
<TextField id="idPesquisaLista" caption="Digite aqui para pesquisar:" type="string" width="100%" visible="true" immediate="true">
|
|
<events>
|
|
<valueChange>
|
|
<script language="JavaScript">
|
|
<![CDATA[
|
|
function run(){
|
|
engine.getField('listaPrincipal').refresh();
|
|
}
|
|
]]>
|
|
</script>
|
|
</valueChange>
|
|
</events>
|
|
</TextField>
|
|
<DBTable id="listaPrincipal" type="number" visible="true" width="100%" immediate="true" rows="5" selectable="false" multivalue="false" showRowCount="true">
|
|
<datasource>
|
|
<sqlBuilderDataSource connection-key="vitruvio" language="JavaScript">
|
|
<![CDATA[
|
|
|
|
var getSql = function() {
|
|
|
|
var config = { "tabela" :
|
|
{
|
|
"conexao" : "vitruvio",
|
|
"nome" : "operacao" ,
|
|
"sequence" : "operacao_seq" ,
|
|
"idTabela" : "CODIGO",
|
|
"campos" : ["CODIGO", "NOME"],
|
|
"camposTable" : ["CODIGO", "NOME"]
|
|
},
|
|
"relaciona" :
|
|
[ ["CODIGO","idChave","Number"]
|
|
, ["NOME","idDescricao","String"]
|
|
] ,
|
|
"validacaoExclusao" :
|
|
[ ["SELECT 0 AS CONTAR FROM OPERACAO WHERE CODIGO = ", "Existem registros ligados a esta tabela."],
|
|
["SELECT COUNT(CHAVE_OPERACAO) AS CONTAR FROM CONTROLE_DESPESAS_OPERACIONAIS WHERE CHAVE_OPERACAO = ", "Existem registros ligados a esta tabela."],
|
|
["SELECT COUNT(CHAVE_OPERACAO) AS CONTAR FROM CONTROLE_DESPESAS_COMBUSTIVEIS WHERE CHAVE_OPERACAO = ", "Existem registros ligados a esta tabela."],
|
|
["SELECT COUNT(CHAVE_OPERACAO) AS CONTAR FROM CONTROLE_RECEITAS_FRETES WHERE CHAVE_OPERACAO = ", "Existem registros ligados a esta tabela."]
|
|
],
|
|
'painel' :
|
|
{
|
|
'titulo' : 'Cadastro de Operações',
|
|
'icone' : ''
|
|
}
|
|
|
|
|
|
};
|
|
var lib = libService.loadScript('lib_cadastro_padrao');
|
|
return lib.table(config, 'camposTable');
|
|
}
|
|
|
|
function buildSQL(params) {
|
|
var sql = getSql();
|
|
if(engine) {
|
|
var idPesquisaLista = engine.getField('idPesquisaLista').getValue();
|
|
if (idPesquisaLista != null) {
|
|
sql = "SELECT * FROM ( " + sql + " ) T WHERE T.NOME LIKE UPPER('%" + idPesquisaLista + "%')";
|
|
}
|
|
}
|
|
return sql;
|
|
}
|
|
]]>
|
|
</sqlBuilderDataSource>
|
|
|
|
</datasource>
|
|
<key-field>CODIGO</key-field>
|
|
<columns>
|
|
<!-- icone de edição -->
|
|
<generated name="Editar" align="CENTER" expand-ratio="0.2">
|
|
<scriptColumnGenerator language="JavaScript">
|
|
<![CDATA[
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.resources.icons16x16.IconLibraryAPISmall);
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.icons.IconFactory);
|
|
|
|
function Generator() {
|
|
var comp = libService.loadScript('vaadinComponents');
|
|
this.generate = function (itemId, columnId, item, container) {
|
|
var btn = comp.buttonIcon('editar', function () {
|
|
|
|
var id = itemId;
|
|
engine.getField('idChave').setValue(id);
|
|
|
|
if (id != null) {
|
|
engine.setGlobalVariable('painelLista',0);
|
|
engine.getGlobalVariable('carregarCampos')(id);
|
|
engine.getGlobalVariable('habilitaCampos')(true);
|
|
engine.getLayout('pnlInclusao').getRootComposition().setVisible(true);
|
|
engine.getLayout('pnlTitulo').getRootComposition().setVisible(false);
|
|
}
|
|
|
|
}, 'pencil');
|
|
|
|
return btn;
|
|
}
|
|
}
|
|
var script = new Generator();
|
|
]]>
|
|
</scriptColumnGenerator>
|
|
</generated>
|
|
|
|
<!-- icone de exclusão -->
|
|
<generated name="Excluir" align="CENTER" expand-ratio="0.2">
|
|
<scriptColumnGenerator language="JavaScript">
|
|
<![CDATA[
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.layout.ConfirmationBox);
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.resources.icons16x16.IconLibraryAPISmall);
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.icons.IconFactory);
|
|
|
|
function Generator() {
|
|
var comp = libService.loadScript('vaadinComponents');
|
|
this.generate = function (itemId, columnId, item, container) {
|
|
var btn = comp.buttonIcon('excluir', function () {
|
|
|
|
var deletar = engine.getGlobalVariable('deletarRegistro');
|
|
var registro = item.getItemProperty('CODIGO') + " - " + item.getItemProperty('NOME');
|
|
var msg = 'Confirma a exclusão das informações para \n';
|
|
msg = msg.concat(registro, "?");
|
|
|
|
ConfirmationBox.show( 'Confirmar operação'
|
|
, msg
|
|
, new ConfirmationBox.ConfirmationBoxListener() {
|
|
dialogEnd: function(context, action) {
|
|
if(action == ConfirmationBox.Action.YES) {
|
|
if(deletar){
|
|
engine.setGlobalVariable('painelLista',1);
|
|
deletar(itemId);
|
|
engine.getField('listaPrincipal').refresh();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
);
|
|
}, 'trash');
|
|
|
|
return btn;
|
|
}
|
|
}
|
|
var script = new Generator();
|
|
]]>
|
|
</scriptColumnGenerator>
|
|
</generated>
|
|
|
|
<column name="CODIGO" caption="Código"/>
|
|
<column name="NOME" caption="Nome"/>
|
|
</columns>
|
|
</DBTable>
|
|
</VerticalLayout>
|
|
</Panel>
|
|
|
|
<Panel width="100%" height="100%" expandRatio="1" caption="" margin="false" id="pnlInclusao">
|
|
<VerticalLayout width="100%" margin="true">
|
|
<Label id="DescricaocadastroDentro" contentMode="HTML" align="MIDDLE_CENTER" width="100%" > </Label>
|
|
<TabLayout height="100%" width="100%">
|
|
<Tab caption="Dados" >
|
|
<VerticalLayout width="70%" margin="true" spacing="true">
|
|
<DBSearchField type="number" id="idPesquisa" expandRatio="1" caption="Pesquisar operação" width="100%" searchCaption="Nome do operação" searchViewWidth="85%" description="Selecione um fornecedor" >
|
|
<datasource>
|
|
<freeQuery connection-key="vitruvio">
|
|
<![CDATA[
|
|
SELECT * FROM operacao
|
|
]]>
|
|
</freeQuery>
|
|
</datasource>
|
|
<loadItemQuery>
|
|
<![CDATA[
|
|
SELECT *
|
|
FROM operacao
|
|
nome = ? ORDER BY codigo
|
|
]]>
|
|
</loadItemQuery>
|
|
<key-field>CODIGO</key-field>
|
|
<caption-field>NOME</caption-field>
|
|
<columns>
|
|
<column name="CODIGO" caption="Código" />
|
|
<column name="NOME" caption="Descrição" />
|
|
</columns>
|
|
<filterProperties filterRequired="false">
|
|
<value>CODIGO</value>
|
|
<value>NOME</value>
|
|
</filterProperties>
|
|
<events>
|
|
<valueChange>
|
|
<script language="JavaScript">
|
|
<![CDATA[
|
|
function run() {
|
|
//engine.getGlobalVariable('fncLimpaCampos')();
|
|
engine.getGlobalVariable('carregarCampos')(engine.getField('idPesquisa').getValue());
|
|
}
|
|
]]>
|
|
</script>
|
|
</valueChange>
|
|
</events>
|
|
</DBSearchField>
|
|
<HorizontalLayout spacing="true" width="100%" >
|
|
<TextField type="number" id="idChave" width="100%" caption="Código" expandRatio="0.08" />
|
|
<TextField type="string" id="idDescricao" text-transform="uppercase" caption="Descrição" required="true" width="100%" expandRatio="1" />
|
|
</HorizontalLayout>
|
|
<TabLayout compact="true" width="100%">
|
|
<Tab caption="Sócios">
|
|
<VerticalLayout spacing="true" width="100%">
|
|
<Label id="lb1" >
|
|
<value>
|
|
|
|
</value>
|
|
</Label>
|
|
<HorizontalLayout spacing="true" width="420">
|
|
<DBComboBox type="string" id="socios" caption="Sócio" width="100%" expandRatio="0.8" description="Selecione um sócio" allowNullSelection="true" searchCaption="Digite para localizar...">
|
|
<datasource>
|
|
<freeQuery connection-key="vitruvio">
|
|
<![CDATA[
|
|
Select nome from socios where codigo > 0
|
|
]]>
|
|
</freeQuery>
|
|
</datasource>
|
|
<key-field>NOME</key-field>
|
|
<caption-field>NOME</caption-field>
|
|
</DBComboBox>
|
|
<DecimalField caption="% Participação" expandRatio="0.2" maximumValue="100" maxLength="6" type="decimal" id="percentualSocio" width="100%" align="TOP_LEFT" description="Percentual de participação do sócio" />
|
|
<ButtonWidget id="btnPercentual" description="Adicionar percentual" height="25" align="BOTTOM_LEFT" >
|
|
<onClickScript language="JavaScript">
|
|
<;
|
|
engine.getField('socios')['setValue(java.lang.Object)'](null);
|
|
} else {
|
|
MessageBox.show(MessageBox.BoxType.INFO, 'Atenção', 'Percentual não pode ultrapassar 100%.');
|
|
}
|
|
}
|
|
}
|
|
]]>
|
|
</onClickScript>
|
|
</ButtonWidget>
|
|
<ButtonWidget id="btnRemoverPercentual" description="Remover percentual" height="25" align="BOTTOM_LEFT" >
|
|
<onClickScript language="JavaScript">
|
|
<![CDATA[
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.layout.MessageBox);
|
|
function run() {
|
|
var texto = engine.getField('socioLista').getValue();
|
|
if (texto != '') {
|
|
try {
|
|
var container = engine.getField("socioLista").getContainerDataSource();
|
|
container.removeItem(texto);
|
|
var container2 = engine.getField("socioPercentual").getContainerDataSource();
|
|
container2.removeItem(texto);
|
|
} catch(e) {
|
|
MessageBox.show('Alerta', 'Dados inválidos!');
|
|
}
|
|
}
|
|
};
|
|
]]>
|
|
</onClickScript>
|
|
</ButtonWidget>
|
|
</HorizontalLayout>
|
|
<HorizontalLayout width="420" >
|
|
<ListSelect type="string" id="socioLista" readOnly="true" width="100%" expandRatio="0.8" allowNullSelection="true" rows="5">
|
|
<events>
|
|
<valueChange>
|
|
<script language="JavaScript">
|
|
<![CDATA[
|
|
function run() {
|
|
engine.getField('socioPercentual').setValue(engine.getField('socioLista').getValue());
|
|
}
|
|
]]>
|
|
</script>
|
|
</valueChange>
|
|
</events>
|
|
</ListSelect>
|
|
<ListSelect type="string" id="socioPercentual" readOnly="true" width="100%" expandRatio="0.2" allowNullSelection="true" rows="5">
|
|
|
|
</ListSelect>
|
|
</HorizontalLayout>
|
|
</VerticalLayout>
|
|
</Tab>
|
|
<Tab caption="Usuários" visible="false">
|
|
<VerticalLayout margin="false" width="100%" >
|
|
<Label id="lb2">
|
|
<value>
|
|
|
|
</value>
|
|
</Label>
|
|
<DBTwinColSelect type="number" id="twinUsuario" allowNullSelection="true" multivalue="true" width="70%" align="TOP_LEFT" >
|
|
<datasource>
|
|
<freeQuery connection-key="vitruvio">
|
|
<![CDATA[
|
|
Select usuario_id, nome from nauth.usuario where ativo = true
|
|
]]>
|
|
</freeQuery>
|
|
</datasource>
|
|
<key-field>USUARIO_ID</key-field>
|
|
<caption-field>NOME</caption-field>
|
|
</DBTwinColSelect>
|
|
</VerticalLayout>
|
|
</Tab>
|
|
</TabLayout>
|
|
</VerticalLayout>
|
|
</Tab>
|
|
</TabLayout>
|
|
</VerticalLayout>
|
|
</Panel>
|
|
<Panel width="100%" margin="false" id="pnlBotoes" >
|
|
<VerticalLayout width="100%" >
|
|
<HorizontalLayout margin="true" spacing="true" align="MIDDLE_CENTER" >
|
|
<ButtonWidget id="btnSalvar" caption="Salvar" expandRatio="0.2" description="Salva os dados das Informações Adicionais do Cargo " align="MIDDLE_CENTER">
|
|
<onClickScript language="JavaScript">
|
|
<![CDATA[
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.layout.MessageBox);
|
|
function run() {
|
|
if (engine.isValid()) {
|
|
if (engine.getGlobalVariable('validarDuplicidade')(engine.getField('idDescricao').getValue())) {
|
|
MessageBox.show(MessageBox.BoxType.INFO, 'Atenção', 'Já existe uma operação cadastrada com este nome.');
|
|
} else {
|
|
var containerSocio = engine.getField("socioLista").getContainerDataSource();
|
|
var containerPercentual = engine.getField("socioPercentual").getContainerDataSource();
|
|
var ids = engine.getField('socioLista').getContainerDataSource().getItemIds();
|
|
var iter = ids.iterator();
|
|
var total = 0.00;
|
|
while (iter.hasNext()) {
|
|
var value = iter.next();
|
|
total = parseFloat(total) + parseFloat(String(engine.getField('socioPercentual').getContainerDataSource().getItem(value)).replace(',','.'));
|
|
}
|
|
|
|
if (total != 100.00) {
|
|
MessageBox.show(MessageBox.BoxType.INFO, 'Atenção', 'Percentual deve ser igual a 100%.');
|
|
} else {
|
|
|
|
var config = engine.getGlobalVariable('config');
|
|
var id = engine.getField('idChave').getConvertedValue();
|
|
var lib = libService.loadScript('lib_cadastro_padrao');
|
|
var retorno = lib.fncGravarRegistro(config, id);
|
|
|
|
var db = libService.loadScript('db');
|
|
var dbVitruvio = new db('vitruvio');
|
|
var sql;
|
|
var socio;
|
|
var percentual;
|
|
var iter2 = ids.iterator();
|
|
|
|
dbVitruvio.transaction(function() {
|
|
sql = "delete from operacao_socio where codigo_operacao = :operacao";
|
|
this.update(sql, {
|
|
operacao: Number(retorno)
|
|
});
|
|
});
|
|
|
|
while (iter2.hasNext()) {
|
|
var value = iter2.next();
|
|
var row = dbVitruvio.queryRow("Select codigo from socios where nome = '" + String(engine.getField('socioLista').getContainerDataSource().getItem(value)) + "'");
|
|
if (row.codigo) {
|
|
socio = row.codigo
|
|
}
|
|
percentual = parseFloat(String(engine.getField('socioPercentual').getContainerDataSource().getItem(value)).replace(',','.'));
|
|
dbVitruvio.transaction(function() {
|
|
sql = "insert into operacao_socio (codigo,codigo_operacao,codigo_socio,participacao) values (" + dbVitruvio.getSequenceNextValSql('operacao_socios_seq') + ",:operacao,:socio,:participacao)";
|
|
this.update(sql, {
|
|
operacao: Number(retorno),
|
|
socio: Number(socio),
|
|
participacao: percentual
|
|
});
|
|
});
|
|
}
|
|
|
|
dbVitruvio.transaction(function() {
|
|
sql = "delete from operacao_usuario where codigo_operacao = :operacao";
|
|
this.update(sql, {
|
|
operacao: Number(retorno)
|
|
});
|
|
});
|
|
|
|
var u = engine.getField('twinUsuario').getValue();
|
|
if (u) {
|
|
var i = u.iterator();
|
|
while (i.hasNext()) {
|
|
dbVitruvio.transaction(function() {
|
|
sql = "insert into operacao_usuario (codigo,codigo_operacao,codigo_usuario) values (" + dbVitruvio.getSequenceNextValSql('operacao_usuario_seq') + ",:operacao,:usuario)";
|
|
this.update(sql, {
|
|
operacao: Number(retorno),
|
|
usuario: Number(i.next())
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
if (retorno) {
|
|
engine.getGlobalVariable('fncLimpaCampos')();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
]]>
|
|
</onClickScript>
|
|
</ButtonWidget>
|
|
<ButtonWidget caption="Novo" id="btnNovo" expandRatio="0.2" description="Novo cadastro" align="MIDDLE_CENTER">
|
|
<onClickScript language="JavaScript">
|
|
<![CDATA[
|
|
function run() {
|
|
engine.setGlobalVariable('painelLista',0);
|
|
engine.getGlobalVariable('novoRegistro')();
|
|
}
|
|
]]>
|
|
</onClickScript>
|
|
</ButtonWidget>
|
|
<ButtonWidget caption="Excluir" id="btnExcluir" expandRatio="0.2" description="Excluir os dados atuais" align="MIDDLE_CENTER">
|
|
<onClickScript language="JavaScript">
|
|
<![CDATA[
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.layout.MessageBox);
|
|
importClass(Packages.br.com.davinti.base.vaadin.components.layout.ConfirmationBox);
|
|
importClass(Packages.com.vaadin.ui.Notification);
|
|
|
|
function run() {
|
|
if(engine.isValid()) {
|
|
var deletar = engine.getGlobalVariable('deletarRegistro');
|
|
var listener = new ConfirmationBox.ConfirmationBoxListener() {
|
|
dialogEnd: function(context, action) {
|
|
if(action == ConfirmationBox.Action.YES) {
|
|
var id = engine.getField('idChave').getConvertedValue();
|
|
if(deletar){
|
|
engine.setGlobalVariable('painelLista',0);
|
|
deletar(id);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
ConfirmationBox.show(ConfirmationBox.DialogIcon.WARNING, 'Confirmar exclusão do registro?', 'Tem certeza de que deseja excluir o tipo de ocorrência selecionado?', listener, ConfirmationBox.ACTION_YES_CANCEL);
|
|
}
|
|
}
|
|
]]>
|
|
</onClickScript>
|
|
</ButtonWidget>
|
|
<ButtonWidget caption="Voltar" id="btnVoltar" expandRatio="0.2" description="Voltar a tela inicial" align="MIDDLE_CENTER">
|
|
<onClickScript language="JavaScript">
|
|
<![CDATA[
|
|
function run() {
|
|
engine.setGlobalVariable('painelLista',1);
|
|
engine.getGlobalVariable('fncLimpaCampos')();
|
|
newRecord = false;
|
|
saveStatus = false;
|
|
engine.getGlobalVariable('telaInicial')();
|
|
engine.getField('listaPrincipal').refresh();
|
|
}
|
|
]]>
|
|
</onClickScript>
|
|
</ButtonWidget>
|
|
</HorizontalLayout>
|
|
</VerticalLayout>
|
|
</Panel>
|
|
</VerticalLayout>
|
|
</components>
|
|
</form>
|
|
</panel-form>
|