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();
     $sessionSearch = $sessionContainer->offsetGet(ContrattiPubbliciSearchController::sessionIdentifier);
     try {
         $helper = new ContrattiPubbliciControllerHelper();
         $wrapper = $helper->recoverWrapperRecordsPaginator(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('cig' => isset($sessionSearch['cig']) ? $sessionSearch['cig'] : null, 'anno' => isset($sessionSearch['anno']) ? $sessionSearch['anno'] : null, 'importo' => isset($sessionSearch['importo']) ? $sessionSearch['importo'] : null, 'settoreId' => isset($sessionSearch['settore']) ? $sessionSearch['settore'] : null, 'orderBy' => 'cc.id DESC'), $page, $perPage);
         $yearsRecords = $helper->recoverWrapperRecords(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('fields' => 'DISTINCT(cc.anno) AS anno', 'orderBy' => 'cc.anno'));
         $helper->checkRecords($yearsRecords, 'Nessun contratto pubblico in archivio');
         if (!empty($yearsRecords)) {
             $yearsArray = array();
             foreach ($yearsRecords as $year) {
                 if (isset($year['anno'])) {
                     $yearsArray[$year['anno']] = $year['anno'];
                 }
             }
         }
         $wrapperSettori = new UsersSettoriGetterWrapper(new UsersSettoriGetter($em));
         $wrapperSettori->setInput(array());
         $wrapperSettori->setupQueryBuilder();
         $settoriRecords = $wrapperSettori->getRecords();
         $settori = array();
         foreach ($settoriRecords as $settore) {
             if (isset($settore['id']) and isset($settore['nome']) and isset($settore['surname'])) {
                 $settori[$settore['id']] = $settore['nome'] . ' ' . $settore['name'] . ' ' . $settore['surname'];
             }
         }
         $formSearch = new ContrattiPubbliciFormSearch();
         $formSearch->addMainFormElements();
         $formSearch->addYears($yearsArray);
         $formSearch->addSettori($settori);
         $formSearch->addSubmit();
         if ($sessionSearch) {
             $formSearch->setData(array('cig' => isset($sessionSearch['cig']) ? $sessionSearch['cig'] : null, 'anno' => isset($sessionSearch['anno']) ? $sessionSearch['anno'] : null, 'importo' => isset($sessionSearch['importo']) ? $sessionSearch['importo'] : null, 'settore' => isset($sessionSearch['settore']) ? $sessionSearch['settore'] : null));
         }
         $paginator = $wrapper->getPaginator();
         $helper = new ContrattiPubbliciControllerHelper();
         $wrapperDisattivati = $helper->recoverWrapperRecords(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('fields' => '(SELECT COUNT(contratti.id) FROM Application\\Entity\\ZfcmsComuniContratti contratti WHERE contratti.attivo = 0) AS disattivati', 'cig' => isset($sessionSearch['cig']) ? $sessionSearch['cig'] : null, 'anno' => isset($sessionSearch['anno']) ? $sessionSearch['anno'] : null, 'importo' => isset($sessionSearch['importo']) ? $sessionSearch['importo'] : null, 'settoreId' => isset($sessionSearch['settore']) ? $sessionSearch['settore'] : null, 'orderBy' => 'cc.id DESC'), $page, $perPage);
         if (!empty($wrapperDisattivati)) {
             $disattivati = $wrapperDisattivati[0]['disattivati'];
         } else {
             $disattivati = 0;
         }
         $wrapper->setEntityManager($em);
         $wrapperRecords = $wrapper->addAttachmentsFromRecords($wrapper->setupRecords(), array('moduleId' => ModulesContainer::contratti_pubblici_id));
         $paginatorRecords = $this->formatArticoliRecords($wrapperRecords);
         $this->layout()->setVariables(array('tableTitle' => 'Contratti pubblici', 'tableDescription' => $paginator->getTotalItemCount() . " contratti in archivio. " . $disattivati . ' disattivati \\ non visibili online.', 'formSearch' => $formSearch, 'columns' => array("Oggetto del bando", "Struttura proponente \\ responsabili", "Aggiudicatario", "Scelta del contraente", "Importo somme liquidate Euro", "Tempi", " ", $userDetails->acl->hasResource("contratti_pubblici_operatori_management") ? " " : null, $userDetails->acl->hasResource("contratti_pubblici_update") ? " " : null, $userDetails->acl->hasResource("contratti_pubblici_delete") ? " " : null, $userDetails->acl->hasResource("contratti_pubblici_home") ? " " : null, $userDetails->acl->hasResource("contratti_pubblici_attachments") ? " " : null), 'paginator' => $paginator, 'sessionSearch' => $sessionSearch, 'records' => $paginatorRecords, 'templatePartial' => 'datatable/datatable_contratti_pubblici.phtml'));
     } catch (\Exception $e) {
         $this->layout()->setVariables(array('messageType' => 'warning', 'messageTitle' => 'Problema verificato', 'messageText' => $e->getMessage(), 'templatePartial' => 'message.phtml'));
     }
     $this->layout()->setTemplate($mainLayout);
 }
 public function indexAction()
 {
     $mainLayout = $this->initializeFrontendWebsite();
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $page = $this->params()->fromRoute('page');
     $templateDir = $this->layout()->getVariable('templateDir');
     $basicLayout = $this->layout()->getVariable('contratti_pubblici_basiclayout');
     $sessionContainer = new SessionContainer();
     $sessionSearch = $sessionContainer->offsetGet(ContrattiPubbliciSearchController::sessionIdentifier);
     try {
         $helper = new ContrattiPubbliciControllerHelper();
         $wrapper = $helper->recoverWrapperRecordsPaginator(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('anno' => isset($sessionSearch['anno']) ? $sessionSearch['anno'] : null, 'cig' => isset($sessionSearch['cig']) ? $sessionSearch['cig'] : null, 'importo' => isset($sessionSearch['importo']) ? $sessionSearch['importo'] : null, 'annullato' => 0, 'pubblicare' => 1, 'attivo' => 1), $page, null);
         $wrapper->setEntityManager($em);
         $contrattiWithAttachment = $wrapper->addAttachmentsToPaginatorRecords($wrapper->setupRecords(), array('moduleId' => ModulesContainer::contratti_pubblici_id, 'noScaduti' => 1, 'orderBy' => 'a.position'));
         $contrattiRecords = $wrapper->addListaPartecipanti($contrattiWithAttachment);
         $contrattiPaginator = $wrapper->getPaginator();
         $yearsRecords = $helper->recoverWrapperRecords(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('fields' => 'DISTINCT(cc.anno) AS anno', 'orderBy' => 'cc.anno'));
         if (!empty($yearsRecords)) {
             $yearsArray = array();
             foreach ($yearsRecords as $year) {
                 $yearsArray[$year['anno']] = $year['anno'];
             }
         } else {
             $yearsArray = array();
         }
         $settoriRecords = $helper->recoverWrapperRecords(new UsersSettoriGetterWrapper(new UsersSettoriGetter($em)), array());
         $settori = array();
         foreach ($settoriRecords as $settore) {
             $settori[$settore['id']] = $settore['nome'] . ' ' . $settore['name'] . ' ' . $settore['surname'];
         }
         $form = new ContrattiPubbliciFormSearch();
         $form->addYears($yearsArray);
         $form->addMainFormElements();
         $form->addSettori($settori);
         $form->addSubmit();
         if ($sessionSearch) {
             $form->setData(array('cig' => isset($sessionSearch['cig']) ? $sessionSearch['cig'] : null, 'anno' => isset($sessionSearch['anno']) ? $sessionSearch['anno'] : null, 'importo' => isset($sessionSearch['importo']) ? $sessionSearch['importo'] : null, 'settore' => isset($sessionSearch['settore']) ? $sessionSearch['settore'] : null));
         }
         $this->layout()->setVariables(array('sessionSearch' => $sessionSearch, 'form' => $form, 'emptyRecords' => count($contrattiRecords), 'records' => $contrattiRecords, 'paginator' => $contrattiPaginator, 'paginator_total_item_count' => $contrattiPaginator->getTotalItemCount(), 'templatePartial' => 'contratti-pubblici/contratti-pubblici.phtml'));
     } catch (\Exception $e) {
     }
     $this->layout()->setTemplate(isset($basicLayout) ? $templateDir . $basicLayout : $mainLayout);
 }