public function indexAction() { $mainLayout = $this->initializeAdminArea(); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); $lang = $this->params()->fromRoute('lang'); $id = $this->params()->fromRoute('id'); try { $helper = new ContrattiPubbliciControllerHelper(); $sceltaContraenteRecords = $helper->recoverWrapperRecords(new SceltaContraenteGetterWrapper(new SceltaContraenteGetter($em)), array('orderBy' => '')); $helper->checkRecords($sceltaContraenteRecords, "Nessuna opzione di scelta contraente rilevata"); $sceltaContraenteRecordsForDropDown = $helper->formatForDropwdown($sceltaContraenteRecords, 'id', 'nomeScelta'); $responsabiliProcRecords = $helper->recoverWrapperRecords(new UsersRespProcGetterWrapper(new UsersRespProcGetter($em)), array('orderBy' => '')); $helper->checkRecords($responsabiliProcRecords, "Nessuna responsabile di procedimento rilevato"); $responsabiliProcRecordsForDropDown = $helper->formatUsersRespProcRecords($responsabiliProcRecords); $contrattoRecord = $helper->recoverWrapperRecordsById(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('id' => $id, 'limit' => 1), $id); $usersSettoriRecords = $helper->recoverWrapperRecords(new UsersSettoriGetterWrapper(new UsersSettoriGetter($em)), array()); $helper->checkRecords($usersSettoriRecords, 'Nessun settore presente'); $usersSettoriRecordsForDropDown = $helper->formatForDropwdown($usersSettoriRecords, 'id', 'nome'); $form = new ContrattiPubbliciForm(); $form->addDetermina(); $form->addImporti(); $form->addStrutturaProponenteLabel(); $form->addResponsabili($responsabiliProcRecordsForDropDown); $form->addSceltaContraente($sceltaContraenteRecordsForDropDown); $form->addSettori($usersSettoriRecordsForDropDown); $form->addDatePubblicazione(); $form->addNumeroOfferte(); $form->addDataInizioFineLavori(); // $form->addUsersSelect(); // TODO: add user selection if (!empty($contrattoRecord)) { $formAction = $this->url()->fromRoute('admin/contratti-pubblici-update', array('lang' => $lang)); $formTitle = 'Modifica bando'; $formDescription = 'È consigliabile inserire testi brevi sul tema trattato, possibilmente in minuscolo.'; $form->setData($contrattoRecord[0]); } else { $form->setData(array("dataInserimento" => date("Y-m-d H:i:s"))); $formAction = $this->url()->fromRoute('admin/contratti-pubblici-insert', array('lang' => $lang)); $formTitle = 'Nuovo bando'; $formDescription = "Il bando verrà inserito come <strong>disattivato</strong>. Occorrerà attivare lo stesso dall'elenco."; } $this->layout()->setVariables(array('form' => $form, 'formAction' => $formAction, 'formTitle' => $formTitle, 'formDescription' => $formDescription, 'formBreadCrumbCategory' => 'Contratti pubblici', 'formBreadCrumbCategoryLink' => $this->url()->fromRoute('admin/contratti-pubblici-summary', array('lang' => $lang)), 'formLabelSpanWidth' => 3, 'formControlSpanWidth' => 9, 'templatePartial' => self::formTemplate)); } catch (NullException $e) { $this->layout()->setVariables(array('templatePartial' => 'message.phtml', 'messageType' => 'warning', 'messageTitle' => 'Errore verificato', 'messageText' => $e->getMessage())); } $this->layout()->setTemplate($mainLayout); }
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); }