public function indexAction() { $mainLayout = $this->initializeAdminArea(); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); $page = $this->params()->fromRoute('page'); $perPage = $this->params()->fromRoute('perpage'); $userDetails = $this->layout()->getVariable('userDetails'); $sessionContainer = new SessionContainer(); try { $formPostedValues = $sessionContainer->offsetGet('statoCivileFormSearch'); $request = $this->getRequest(); if ($request->isPost()) { $post = array_merge_recursive($request->getPost()->toArray(), $request->getFiles()->toArray()); } else { $post = $formPostedValues; } $statoCivileArticoliInput = array('numero' => isset($post['numero']) ? $post['numero'] : null, 'anno' => isset($post['anno']) ? $post['anno'] : null, 'sezioneId' => isset($post['sezione']) ? $post['sezione'] : null, 'noScaduti' => isset($post['expired']) ? $post['expired'] : null, 'textSearch' => isset($post['testo']) ? $post['testo'] : null, 'orderBy' => 'sca.id DESC'); $helper = new StatoCivileControllerHelper(); $yearsList = $helper->setupYears(new StatoCivileGetterWrapper(new StatoCivileGetter($em)), array_merge($statoCivileArticoliInput, array('fields' => 'DISTINCT(sca.anno) AS anno'))); $sezioniRecords = $helper->recoverWrapperRecords(new StatoCivileSezioniGetterWrapper(new StatoCivileSezioniGetter($em)), array()); $helper->checkRecords($sezioniRecords, "Nessuna sezione in archivio"); $sezioniRecordsForDropDown = $helper->formatForDropwdown($sezioniRecords, 'id', 'nome'); $formSearch = new StatoCivileFormSearch(); $formSearch->addTesto(); $formSearch->addProgressivo(); $formSearch->addNumeroAtto(); $formSearch->addMese(); $formSearch->addSezioni($sezioniRecordsForDropDown); $formSearch->addSubmitButton(); $formSearch->addCheckExpired(); $formSearch->addAnni($yearsList); if ($this->getRequest()->isPost()) { $formSearch->setBindOnValidate(false); $formSearch->setData($post); $sessionContainer->offsetSet('statoCivileFormSearch', $post); } elseif (!empty($formPostedValues)) { $formSearch->setData($formPostedValues); } $wrapper = $helper->recoverWrapperRecordsPaginator(new StatoCivileGetterWrapper(new StatoCivileGetter($em)), $statoCivileArticoliInput, $page, $perPage); $wrapper->setEntityManager($em); $attiRecords = $wrapper->addAttachmentsFromRecords($wrapper->setupRecords()); $paginator = $wrapper->getPaginator(); $paginatorCount = $paginator->getTotalItemCount(); $this->layout()->setVariables(array('tableTitle' => 'Stato civile', 'tableDescription' => $paginatorCount . ' atti stato civile in archivio', 'columns' => array("Titolo", "Numero / Anno", "Sezione", "Inserito il", "Scadenza", "Inserito da", " ", " ", " ", " ", " ", " "), 'formSearch' => $formSearch, 'records' => $this->formatRecords($attiRecords), 'paginator' => $paginator, 'templatePartial' => 'datatable/datatable_statocivile.phtml')); } catch (\Exception $e) { $this->layout()->setVariables(array('messageType' => 'warning', 'messageTitle' => 'Errore verificato', 'messageText' => $e->getMessage(), 'templatePartial' => 'message.phtml')); } $this->layout()->setTemplate($mainLayout); }