ET
Dificuldade criação de coluna calculada a partir de uma condição
Olá a todos, estou tendo dificuldade em criar uma coluna em um datagrid para um cadastro mestre/detalhe. A partir de uma condição IF/ELSE. O que acontece é que quando a condição é verdadeira, é executado o trecho de código do if, mas se for falso ele retorna um cálculo totalmente diferente. Não consigo encontrar onde estou errando. Alguém poderia me ajudar?
Segue código:
Segue código:
- <?php
- /**
- * NotasForm Master/Detail
- * @author <your name here>
- */
- class NotasForm extends TPage
- {
- protected $form; // form
- protected $detail_list;
- /**
- * Page constructor
- */
- public function __construct()
- {
- parent::__construct();
- // creates the form
- $this->form = new BootstrapFormBuilder('form_Notas');
- $this->form->setFormTitle('Cadastrar Notas');
- // master fields
- $id = new TEntry('id');
- $aluno_id = new TDBUniqueSearch('aluno_id', 'cp', 'Aluno', 'id', 'nome');
- $serie_id = new TDBCombo('serie_id', 'cp', 'Serie', 'id', 'ano');
- $grau = new TDBCombo('grau', 'cp', 'Serie', 'id', 'grau');
- $turma = new TEntry('turma');
- $turno = new TCombo('turno');
- // add the combo filds Turno
- $turno->addItems(array('Manhã'=>'Manhã',
- 'Tarde'=>'Tarde',
- 'Noite'=>'Noite'
- ));
- $aluno_id->addValidation('Aluno', new TRequiredValidator());
- $serie_id->addValidation('Série', new TRequiredValidator());
- $grau->addValidation('Grau', new TRequiredValidator());
- $turma->addValidation('Turma', new TRequiredValidator());
- $turno->addValidation('Turno', new TRequiredValidator());
- // detail fields
- $detail_uniqid = new THidden('detail_uniqid');
- $detail_id = new THidden('detail_id');
- $detail_disciplina = new TCombo('detail_disciplina');
- $detail_unid_1 = new TSpinner('detail_unid_1');
- $detail_unid_2 = new TSpinner('detail_unid_2');
- $detail_unid_3 = new TSpinner('detail_unid_3');
- $detail_unid_4 = new TSpinner('detail_unid_4');
- $detail_nota_rec = new TSpinner('detail_nota_rec');
- if (!empty($id))
- {
- $id->setEditable(FALSE);
- }
- // add the combo filds Turno
- $detail_disciplina->addItems(array('Português'=>'Português',
- 'Matemática'=>'Matemática',
- 'História'=>'História',
- 'Inglês'=>'Inglês',
- 'Geografia'=>'Geografia',
- 'Religião'=>'Religião',
- 'Ciências'=>'Ciências',
- 'Educação Física'=>'Educação Física',
- 'Direitos da Cidadania'=>'Direitos da Cidadania',
- 'Artes'=>'Artes',
- 'Condutas'=>'Condutas',
- 'Faltas'=>'Faltas'
- ));
- $detail_disciplina->setValue('Português');
- $detail_disciplina->setSize('38%');
- $detail_unid_1->setRange(0,100,0.1);
- $detail_unid_2->setRange(0,100,0.1);
- $detail_unid_3->setRange(0,100,0.1);
- $detail_unid_4->setRange(0,100,0.1);
- $detail_nota_rec->setRange(0,100,0.1);
- // master fields
- $this->form->addContent( ['<h4>Aluno</h4><hr>'] );
- $this->form->addFields( [ new TLabel('Campos em vermelho são obrigatórios.', '#ff0000') ]);
- $this->form->addFields( [new TLabel('Código')], [$id] );
- $this->form->addFields( [new TLabel('Aluno', '#ff0000')], [$aluno_id] );
- $this->form->addFields( [new TLabel('Série', '#ff0000')], [$serie_id], [new TLabel('Grau', '#ff0000')], [$grau], [new TLabel('Turno', '#ff0000')], [$turno] );
- // set sizes
- $id->setSize('100');
- // detail fields
- $this->form->addContent( ['<h4>Notas</h4><hr>'] );
- $this->form->addFields( [$detail_uniqid] );
- $this->form->addFields( [$detail_id] );
- $this->form->addFields( [new TLabel('Disciplinas', '#ff0000')], [$detail_disciplina] );
- $this->form->addFields( [new TLabel('Unidade 1')], [$detail_unid_1], [new TLabel('Unidade 2')], [$detail_unid_2] );
- $this->form->addFields( [new TLabel('Unidade 3')], [$detail_unid_3], [new TLabel('Unidade 4')], [$detail_unid_4] );
- $this->form->addFields( [new TLabel('Nota de Recuperação')], [$detail_nota_rec]);
- $add = TButton::create('add', [$this, 'onDetailAdd'], 'Adicionar Notas', 'fa:plus-circle green');
- $add->getAction()->setParameter('static','1');
- $this->form->addFields( [], [$add] );
- $this->detail_list = new BootstrapDatagridWrapper(new TDataGrid);
- $this->detail_list->setId('NotasItem_list');
- $this->detail_list->generateHiddenFields();
- $this->detail_list->style = "min-width: 700px; width:100%;margin-bottom: 10px";
- // items
- $this->detail_list->addColumn( new TDataGridColumn('uniqid', 'Uniqid', 'center') )->setVisibility(false);
- $this->detail_list->addColumn( new TDataGridColumn('id', 'Id', 'center') )->setVisibility(false);
- $this->detail_list->addColumn( new TDataGridColumn('disciplina', 'Disciplina', 'center', 100) );
- $this->detail_list->addColumn( new TDataGridColumn('unid_1', 'Unidade 1', 'center', 100) );
- $this->detail_list->addColumn( new TDataGridColumn('unid_2', 'Unidade 2', 'center', 100) );
- $this->detail_list->addColumn( new TDataGridColumn('unid_3', 'Unidade 3', 'center', 100) );
- $this->detail_list->addColumn( new TDataGridColumn('unid_4', 'Unidade 4', 'center', 100) );
- $this->detail_list->addColumn( $column_media_anual = new TDataGridColumn('= ( {unid_1} + {unid_2} + {unid_3} + {unid_4} ) / 4', 'Média anual', 'center', 100));
- $formata_valor = function($valor, $objeto, $row) {
- if (is_numeric($valor))
- {
- return number_format($valor, 1, ".", ".");
- }
- return $valor;
- };
- $column_media_anual->setTransformer($formata_valor);
- $this->detail_list->addColumn( new TDataGridColumn('nota_rec', 'Nota de Recuperação', 'center', 100) );
- //AQUI É ONDE ESTOU TENDO A DIFICULDADE
- if ('nota_rec' != '0.00'){
- $this->detail_list->addColumn( $column_media_final_pos_rec = new TDataGridColumn('= ((( {unid_1} + {unid_2} + {unid_3} + {unid_4} ) / 4 + {nota_rec}) / 2)', 'Média final pós Recuperação', 'center', 100));
- }else {
- $this->detail_list->addColumn( $column_media_final_pos_rec = new TDataGridColumn('nota_rec', 'Média final pós Recuperação', 'center', 100));
- }
- $formata_valor = function($valor, $objeto, $row) {
- if (is_numeric($valor))
- {
- return number_format($valor, 1, ".", ".");
- }
- return $valor;
- };
- $column_media_final_pos_rec->setTransformer($formata_valor);
- // detail actions
- $action1 = new TDataGridAction([$this, 'onDetailEdit'] );
- $action1->setFields( ['uniqid', '*'] );
- $action2 = new TDataGridAction([$this, 'onDetailDelete']);
- $action2->setField('uniqid');
- // add the actions to the datagrid
- $this->detail_list->addAction($action1, _t('Edit'), 'fa:edit blue');
- $this->detail_list->addAction($action2, _t('Delete'), 'far:trash-alt red');
- $this->detail_list->createModel();
- $panel = new TPanelGroup;
- $panel->add($this->detail_list);
- $panel->getBody()->style = 'overflow-x:auto';
- $this->form->addContent( [$panel] );
- $this->form->addAction( 'Salvar', new TAction([$this, 'onSave'], ['static'=>'1']), 'fa:save green');
- $this->form->addAction( 'Limpar', new TAction([$this, 'onClear']), 'fa:eraser red');
- // create the page container
- $container = new TVBox;
- $container->style = 'width: 100%';
- // $container->add(new TXMLBreadCrumb('menu.xml', __CLASS__));
- $container->add($this->form);
- parent::add($container);
- }
- /**
- * Clear form
- * @param $param URL parameters
- */
- public function onClear($param)
- {
- $this->form->clear(TRUE);
- }
- /**
- * Add detail item
- * @param $param URL parameters
- */
- public function onDetailAdd( $param )
- {
- try
- {
- $this->form->validate();
- $data = $this->form->getData();
- /** validation sample
- if (empty($data->fieldX))
- {
- throw new Exception('The field fieldX is required');
- }
- **/
- $uniqid = !empty($data->detail_uniqid) ? $data->detail_uniqid : uniqid();
- $grid_data = [];
- $grid_data['uniqid'] = $uniqid;
- $grid_data['id'] = $data->detail_id;
- $grid_data['disciplina'] = $data->detail_disciplina;
- $grid_data['unid_1'] = $data->detail_unid_1;
- $grid_data['unid_2'] = $data->detail_unid_2;
- $grid_data['unid_3'] = $data->detail_unid_3;
- $grid_data['unid_4'] = $data->detail_unid_4;
- $grid_data['nota_rec'] = $data->detail_nota_rec;
- // insert row dynamically
- $row = $this->detail_list->addItem( (object) $grid_data );
- $row->id = $uniqid;
- TDataGrid::replaceRowById('NotasItem_list', $uniqid, $row);
- // clear detail form fields
- $data->detail_uniqid = '';
- $data->detail_id = '';
- $data->detail_disciplina = 'Português';
- $data->detail_unid_1 = '0.00';
- $data->detail_unid_2 = '0.00';
- $data->detail_unid_3 = '0.00';
- $data->detail_unid_4 = '0.00';
- $data->detail_nota_rec = '0.00';
- // send data, do not fire change/exit events
- TForm::sendData( 'form_Notas', $data, false, false );
- }
- catch (Exception $e)
- {
- $this->form->setData( $this->form->getData());
- new TMessage('error', $e->getMessage());
- }
- }
- /**
- * Edit detail item
- * @param $param URL parameters
- */
- public static function onDetailEdit( $param )
- {
- $data = new stdClass;
- $data->detail_uniqid = $param['uniqid'];
- $data->detail_id = $param['id'];
- $data->detail_disciplina = $param['disciplina'];
- $data->detail_unid_1 = $param['unid_1'];
- $data->detail_unid_2 = $param['unid_2'];
- $data->detail_unid_3 = $param['unid_3'];
- $data->detail_unid_4 = $param['unid_4'];
- $data->detail_nota_rec = $param['nota_rec'];
- // send data, do not fire change/exit events
- TForm::sendData( 'form_Notas', $data, false, false );
- }
- /**
- * Delete detail item
- * @param $param URL parameters
- */
- public static function onDetailDelete( $param )
- {
- // clear detail form fields
- $data = new stdClass;
- $data->detail_uniqid = '';
- $data->detail_id = '';
- $data->detail_disciplina = 'Português';
- $data->detail_unid_1 = '0.00';
- $data->detail_unid_2 = '0.00';
- $data->detail_unid_3 = '0.00';
- $data->detail_unid_4 = '0.00';
- $data->detail_nota_rec = '0.00';
- // send data, do not fire change/exit events
- TForm::sendData( 'form_Notas', $data, false, false );
- // remove row
- TDataGrid::removeRowById('NotasItem_list', $param['uniqid']);
- }
- /**
- * Load Master/Detail data from database to form
- */
- public function onEdit($param)
- {
- try
- {
- TTransaction::open('cp');
- if (isset($param['key']))
- {
- $key = $param['key'];
- $object = new Notas($key);
- $items = NotasItem::where('notas_id', '=', $key)->load();
- foreach( $items as $item )
- {
- $item->uniqid = uniqid();
- $row = $this->detail_list->addItem( $item );
- $row->id = $item->uniqid;
- }
- $this->form->setData($object);
- TTransaction::close();
- }
- else
- {
- $this->form->clear(TRUE);
- }
- }
- catch (Exception $e) // in case of exception
- {
- new TMessage('error', $e->getMessage());
- TTransaction::rollback();
- }
- }
- /**
- * Save the Master/Detail data from form to database
- */
- public function onSave($param)
- {
- try
- {
- // open a transaction with database
- TTransaction::open('cp');
- $data = $this->form->getData();
- $this->form->validate();
- $master = new Notas;
- $master->fromArray( (array) $data);
- $master->store();
- NotasItem::where('notas_id', '=', $master->id)->delete();
- if( $param['NotasItem_list_disciplina'] )
- {
- foreach( $param['NotasItem_list_disciplina'] as $key => $item_id )
- {
- $detail = new NotasItem;
- $detail->disciplina = $param['NotasItem_list_disciplina'][$key];
- $detail->unid_1 = $param['NotasItem_list_unid_1'][$key];
- $detail->unid_2 = $param['NotasItem_list_unid_2'][$key];
- $detail->unid_3 = $param['NotasItem_list_unid_3'][$key];
- $detail->unid_4 = $param['NotasItem_list_unid_4'][$key];
- $detail->nota_rec = $param['NotasItem_list_nota_rec'][$key];
- //$detail->media_fin_rec = $param['NotasItem_list_media_fin_rec'][$key];
- $detail->notas_id = $master->id;
- $detail->store();
- }
- }
- TTransaction::close(); // close the transaction
- TForm::sendData('form_Notas', (object) ['id' => $master->id]);
- new TMessage('info', AdiantiCoreTranslator::translate('Record saved'));
- }
- catch (Exception $e) // in case of exception
- {
- new TMessage('error', $e->getMessage());
- $this->form->setData( $this->form->getData() ); // keep form data
- TTransaction::rollback();
- }
- }
- }
- ?>
Você está comparando 2 strings fixas. O resultado sempre será true.
Essa definição está no construtor, lembre que ele é chamado uma única vez a cada execução, então se a ideia é comparar para cada registro da grid, não vai funcionar.
Acredito que possa usar um transformer nessa coluna pra fazer a verificação.
Nataniel, modifiquei o código desta maneira:
Mas é retornado o valor 1 para a verificação com o if.