<?php/** * PerdcompList Listing * @author <your name here> */class PerdcompList extends TStandardList{ protected $form; // registration form protected $datagrid; // listing protected $pageNavigation; protected $formgrid; protected $deleteButton; protected $transformCallback; /** * Page constructor */ public function __construct() { parent::__construct(); parent::setDatabase('perdcomp'); // defines the database parent::setActiveRecord('Perdcomp'); // defines the active record parent::setDefaultOrder('perdcomp_id', 'asc'); // defines the default order // parent::setCriteria($criteria) // define a standard filter parent::addFilterField('perdcomp_id', '=', 'perdcomp_id'); // filterField, operator, formField parent::addFilterField('DataCriacao', 'like', 'DataCriacao'); // filterField, operator, formField parent::addFilterField('DataTransmissao', 'like', 'DataTransmissao'); // filterField, operator, formField parent::addFilterField('Sequencial', 'like', 'Sequencial'); // filterField, operator, formField parent::addFilterField('Nr_Perdcomp', 'like', 'Nr_Perdcomp'); // filterField, operator, formField parent::addFilterField('TipoDocumento_id', 'like', 'TipoDocumento_id'); // filterField, operator, formField parent::addFilterField('OrigemDocumento_id', 'like', 'OrigemDocumento_id'); // filterField, operator, formField parent::addFilterField('TipoCredito_id', 'like', 'TipoCredito_id'); // filterField, operator, formField parent::addFilterField('SaldoDeclarado', 'like', 'SaldoDeclarado'); // filterField, operator, formField parent::addFilterField('Exercicio', 'like', 'Exercicio'); // filterField, operator, formField parent::addFilterField('TipoImposto_id', 'like', 'TipoImposto_id'); // filterField, operator, formField // creates the form $this->form = new TQuickForm('form_search_Perdcomp'); $this->form->class = 'tform'; // change CSS class $this->form->style = 'display: table;width:100%'; // change style $this->form->setFormTitle('Filtro Perdcomp'); // create the form fields $perdcomp_id = new TEntry('perdcomp_id'); $DataCriacao = new TDate('DataCriacao'); $DataTransmissao = new TDate('DataTransmissao'); $Nr_Perdcomp = new TEntry('Nr_Perdcomp'); $TipoDocumento_id = new
">TDBSeekButton('TipoDocumento_id', 'perdcomp', $this->form->getName(), 'TipoDocumento', 'TipoDocumentoDescricao', 'TipoDocumento_id', 'tipo_documento'); $TipoDocumentoDescricao = new TEntry('tipo_documento'); $TipoCredito_id = new
">TDBSeekButton('TipoCredito_id', 'perdcomp', $this->form->getName(), 'TipoCredito', 'TipoCreditoDescricao', 'TipoCredito_id', 'tipo_credito'); $TipoCreditoDescricao = new TEntry('tipo_credito'); $OrigemDocumento_id = new
">TDBSeekButton('OrigemDocumento_id', 'perdcomp', $this->form->getName(), 'OrigemDocumento', 'OrigemDocumentoDescricao', 'OrigemDocumento_id', 'origem_documento'); $OrigemDocumentoDescricao = new TEntry('origem_documento'); $TipoImposto_id = new
">TDBSeekButton('TipoImposto_id', 'perdcomp', $this->form->getName(), 'TipoImposto', 'TipoImpostoDescricao', 'TipoImposto_id', 'tipo_imposto'); $TipoImpostoDescricao = new TEntry('tipo_imposto'); $Exercicio = new TEntry('Exercicio'); $TipoDocumentoDescricao->setEditable(FALSE); $TipoDocumento_id->setSize('40'); $TipoDocumentoDescricao->setSize('500'); $TipoCreditoDescricao->setEditable(FALSE); $TipoCredito_id->setSize('40'); $TipoCreditoDescricao->setSize('500'); $OrigemDocumentoDescricao->setEditable(FALSE); $OrigemDocumento_id->setSize('40'); $OrigemDocumentoDescricao->setSize('500'); $TipoImpostoDescricao->setEditable(FALSE); $TipoImposto_id->setSize('40'); $TipoImpostoDescricao->setSize('500'); // add the fields $this->form->addQuickField('Código:', $perdcomp_id, 80 ); $this->form->addQuickField('Data Criação', $DataCriacao, 80 ); $this->form->addQuickField('Data Transmissão:', $DataTransmissao, 80 ); $this->form->addQuickField('Nº Perdcomp:', $Nr_Perdcomp, 500 ); $this->form->addQuickFields('Tipo Documento:', [ $TipoDocumento_id, $TipoDocumentoDescricao ] ); $this->form->addQuickFields('Tipo Crédito:', [ $TipoCredito_id, $TipoCreditoDescricao] ); $this->form->addQuickFields('Origem Documento:', [ $OrigemDocumento_id, $OrigemDocumentoDescricao ] ); $this->form->addQuickFields('Tipo Imposto:', [ $TipoImposto_id, $TipoImpostoDescricao] ); $this->form->addQuickField('Exercício', $Exercicio, 100 ); // keep the form filled during navigation with session data $this->form->setData( TSession::getValue('Perdcomp_filter_data') ); // add the search form actions $this->form->addQuickAction(_t('Find'), new TAction(array($this, 'onSearch')), 'fa:search'); $this->form->addQuickAction(_t('New'), new TAction(array('PerdcompForm', 'onEdit')), 'bs:plus-sign green'); // creates a DataGrid $this->datagrid = new TDataGrid; // $this->datagrid->enablePopover('Image', "<img src='{photo_path}'>"); $this->datagrid->style = 'width: 100%'; $this->datagrid->datatable = 'true'; // $this->datagrid->enablePopover('Popover', 'Hi <b> {name} </b>'); // creates the datagrid columns $column_check = new TDataGridColumn('check', '', 'center'); $column_perdcomp_id = new TDataGridColumn('perdcomp_id', 'Código', 'right'); $column_DataCriacao = new TDataGridColumn('DataCriacao', 'Data Criação', 'left'); $column_DataTransmissao = new TDataGridColumn('DataTransmissao', 'Data Transmissão', 'left'); $column_Nr_Perdcomp = new TDataGridColumn('Nr_Perdcomp', 'Nº Perdcomp', 'left'); $column_TipoDocumento_id = new TDataGridColumn('tipo_documento', 'Tipo Documento', 'left'); $column_TipoCredito_id = new TDataGridColumn('tipo_credito', 'Tipo Crédito', 'left'); $column_TipoImposto_id = new TDataGridColumn('tipo_imposto', 'Tipo Imposto', 'left'); $column_OrigemDocumento_id = new TDataGridColumn('origem_documento', 'Origem Documento', 'left'); $column_SaldoDeclarado = new TDataGridColumn('SaldoDeclarado', 'Saldo Declarado', 'right'); $column_Exercicio = new TDataGridColumn('Exercicio', 'Exercício', 'right'); $column_ValorCompensado = new TDataGridColumn('ValorCompensado', 'Valor Compensado', 'right'); $column_Sequencial = new TDataGridColumn('Sequencial', 'Sequencial', 'left'); $column_Competencia = new TDataGridColumn('Competencia', 'Competência', 'left'); $column_PerdcompOriginal = new TDataGridColumn('PerdcompOriginal', 'Perdcomp Original', 'left'); $column_Situacao = new TDataGridColumn('Situacao', 'Situação', 'left'); $column_Cancelamento = new TDataGridColumn('Cancelamento', 'Cancelamento', 'left'); $column_CreditoOriginalInicial = new TDataGridColumn('CreditoOriginalInicial', 'Crédito Original Inicial', 'right'); $column_CreditoOriginalUtilizadoCompensacoes = new TDataGridColumn('Credito Original Utilizado Compensações', 'Creditooriginalutilizadocompensacoes', 'right'); $column_CreditoOriginalDisponivel = new TDataGridColumn('Crédito Original Disponível', 'Crédito Original Disponível', 'right'); $column_CreditoOriginalTransmissao = new TDataGridColumn('Credito Original Transmissão', 'Crédito Original Transmissão', 'right'); $column_SelicAcumulada = new TDataGridColumn('Selic Acumulada', 'Selic Acumulada', 'right'); $column_CreditoAtualizado = new TDataGridColumn('CreditoAtualizado', 'Crédito Atualizado', 'right'); $column_DebitosDocumento = new TDataGridColumn('DebitosDocumento', 'Débitos Documento', 'right'); $column_CreditoOriginalUtilizadoDocumento = new TDataGridColumn('CreditoOriginalUtilizadoDocumento', 'Crédito Original Utilizado Documento', 'right'); $column_SaldoCreditoOriginal = new TDataGridColumn('SaldoCreditoOriginal', 'Saldo Crédito Original', 'right'); $column_system_unit_id = new TDataGridColumn('system_unit_id', 'Empresa', 'right'); $column_Ged = new TDataGridColumn('Ged', 'Ged', 'left'); // add the columns to the DataGrid $this->datagrid->addColumn($column_check); $this->datagrid->addColumn($column_perdcomp_id); $this->datagrid->addColumn($column_DataCriacao); $this->datagrid->addColumn($column_DataTransmissao); $this->datagrid->addColumn($column_Sequencial); $this->datagrid->addColumn($column_Nr_Perdcomp); $this->datagrid->addColumn($column_TipoDocumento_id); $this->datagrid->addColumn($column_OrigemDocumento_id); $this->datagrid->addColumn($column_TipoCredito_id); $this->datagrid->addColumn($column_TipoImposto_id); $this->datagrid->addColumn($column_SaldoDeclarado); $this->datagrid->addColumn($column_ValorCompensado); $this->datagrid->addColumn($column_Exercicio); $this->datagrid->addColumn($column_Competencia); $this->datagrid->addColumn($column_PerdcompOriginal); $this->datagrid->addColumn($column_Situacao); $this->datagrid->addColumn($column_Cancelamento); $this->datagrid->addColumn($column_CreditoOriginalInicial); $this->datagrid->addColumn($column_CreditoOriginalUtilizadoCompensacoes); $this->datagrid->addColumn($column_CreditoOriginalDisponivel); $this->datagrid->addColumn($column_CreditoOriginalTransmissao); $this->datagrid->addColumn($column_SelicAcumulada); $this->datagrid->addColumn($column_CreditoAtualizado); $this->datagrid->addColumn($column_DebitosDocumento); $this->datagrid->addColumn($column_CreditoOriginalUtilizadoDocumento); $this->datagrid->addColumn($column_SaldoCreditoOriginal); $this->datagrid->addColumn($column_Ged); $this->datagrid->addColumn($column_system_unit_id); $order_perdcomp_id = new TAction(array($this, 'onReload')); $order_perdcomp_id->setParameter('order', 'perdcomp_id'); $column_perdcomp_id->setAction($order_perdcomp_id); $order_DataCriacao = new TAction(array($this, 'onReload')); $order_DataCriacao->setParameter('order', 'DataCriacao'); $column_DataCriacao->setAction($order_DataCriacao); $order_DataTransmissao = new TAction(array($this, 'onReload')); $order_DataTransmissao->setParameter('order', 'DataTransmissao'); $column_DataTransmissao->setAction($order_DataTransmissao); // define the transformer method over image $column_Ged->setTransformer(function($value, $object, $row){ $link = new THyperLink($value,'tmp/1/' . $value, 'blue', 12, 'biu'); return $link; }); $column_Competencia->setTransformer( function($value, $object, $row) { $date = new DateTime($value); return $date->format('d/m/Y'); }); // define the transformer method over image $column_DataCriacao->setTransformer( function($value, $object, $row) { $date = new DateTime($value); return $date->format('d/m/Y'); }); // define the transformer method over image $column_DataTransmissao->setTransformer( function($value, $object, $row) { $date = new DateTime($value); return $date->format('d/m/Y'); }); // define the transformer method over image $column_SaldoDeclarado->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_ValorCompensado->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_CreditoOriginalInicial->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_CreditoOriginalUtilizadoCompensacoes->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_CreditoOriginalDisponivel->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_CreditoOriginalTransmissao->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_CreditoAtualizado->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_DebitosDocumento->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_CreditoOriginalUtilizadoDocumento->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // define the transformer method over image $column_SaldoCreditoOriginal->setTransformer( function($value, $object, $row) { return 'R$ ' . number_format($value, 2, ',', '.'); }); // create EDIT action $action_edit = new TDataGridAction(array('PerdcompForm', 'onEdit')); $action_edit->setButtonClass('btn btn-default'); $action_edit->setLabel(_t('Edit')); $action_edit->setImage('fa:pencil-square-o blue fa-lg'); $action_edit->setField('perdcomp_id'); $this->datagrid->addAction($action_edit); // create DELETE action $action_del = new TDataGridAction(array($this, 'onDelete')); $action_del->setButtonClass('btn btn-default'); $action_del->setLabel(_t('Delete')); $action_del->setImage('fa:trash-o red fa-lg'); $action_del->setField('perdcomp_id'); $this->datagrid->addAction($action_del); // create the datagrid model $this->datagrid->createModel(); // create the page navigation $this->pageNavigation = new TPageNavigation; $this->pageNavigation->setAction(new TAction(array($this, 'onReload'))); $this->pageNavigation->setWidth($this->datagrid->getWidth()); $this->datagrid->disableDefaultClick(); // put datagrid inside a form $this->formgrid = new TForm; $this->formgrid->add($this->datagrid); // creates the delete collection button $this->deleteButton = new TButton('delete_collection'); $this->deleteButton->setAction(new TAction(array($this, 'onDeleteCollection')), AdiantiCoreTranslator::translate('Delete selected')); $this->deleteButton->setImage('fa:remove red'); $this->formgrid->addField($this->deleteButton); $gridpack = new TVBox; $gridpack->style = 'width: 100%'; $gridpack->add($this->formgrid); $gridpack->add($this->deleteButton)->style = 'background:whiteSmoke;border:1px solid #cccccc; padding: 3px;padding: 5px;'; $this->transformCallback = array($this, 'onBeforeLoad'); // vertical box container $container = new TVBox; $container->style = 'width: 90%'; // $container->add(new TXMLBreadCrumb('menu.xml', __CLASS__)); $container->add($this->form); // $container->add($this->datagrid); $container->add($gridpack); $container->add($this->pageNavigation); parent::add($container); } public function onBeforeLoad($objects, $param) { // update the action parameters to pass the current page to action // without this, the action will only work for the first page $deleteAction = $this->deleteButton->getAction(); $deleteAction->setParameters($param); // important! $gridfields = array( $this->deleteButton ); foreach ($objects as $object) { $object->check = new TCheckButton('check' . $object->perdcomp_id); $object->check->setIndexValue('on'); $gridfields[] = $object->check; // important } $this->formgrid->setFields($gridfields); }} </your></your>
No controller "LoginForm" ao se logar o sistema grava na variável de sessão o userid, recupere assim $userId = TSession::getValue('userid').
Se observar o modelo "SystemUser" poderá ver que há um relacionamento com "SystemUnit", uma vez recuperado um objeto "SystemUser", vc poderá obter a unit.
Exemplo:
$user = new SystemUser(TSession::getValue('userid'));
$unitId = $user->unit->id;
e assim por diante
Marcelo,
Certo. Mas como gravar no banco de dados, ao clicar em salvar?
No seu model e banco de dados vc deve ter os campos: system_user_id e system_unit_id.
Antes de salvar ($obj->store()), vc associa, por exemplo: