/**
  * @return mixed
  */
 public function disableAction()
 {
     $mainLayout = $this->initializeAdminArea();
     $id = $this->params()->fromRoute('id');
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $connection = $em->getConnection();
     $userDetails = $this->layout()->getVariable('userDetails');
     $helper = new ContrattiPubbliciControllerHelper();
     $helper->setConnection($connection);
     try {
         $helper->getConnection()->beginTransaction();
         $helper->updateAttivo($id, 0);
         $logWriter = new LogWriter($connection);
         $logWriter->writeLog(array('user_id' => $userDetails->id, 'module_id' => ModulesContainer::contratti_pubblici_id, 'message' => "Contratto reso disattivato sul sito pubblico. ID: " . $id, 'type' => 'info', 'backend' => 1));
         $helper->getConnection()->commit();
         if (is_object($this->getRequest()->getHeader('Referer'))) {
             return $this->redirect()->toUrl($this->getRequest()->getHeader('Referer')->getUri());
         }
     } catch (\Exception $e) {
         $logWriter = new LogWriter($connection);
         $logWriter->writeLog(array('user_id' => isset($userDetails->id) ? $userDetails->id : 1, 'module_id' => ModulesContainer::contratti_pubblici_id, 'message' => "Errore nell'operazione di resa visibile bando di gara sul sito pubblico. ID: " . $id, 'type' => 'error', 'reference_id' => $id, 'backend' => 1));
         $this->layout()->setVariables(array('messageType' => 'danger', 'messageTitle' => 'Errore verificato', 'messageText' => $e->getMessage(), 'templatePartial' => 'message.phtml'));
         $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->initializeAdminArea();
     $page = $this->params()->fromRoute('page');
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $helper = new ContrattiPubbliciControllerHelper();
     $sceltaContraenteWrapper = $helper->recoverWrapperRecordsPaginator(new SceltaContraenteGetterWrapper(new SceltaContraenteGetter($em)), array(), $page, null);
     $paginator = $sceltaContraenteWrapper->getPaginator();
     $paginatorRecords = $sceltaContraenteWrapper->setupRecords();
     $this->layout()->setVariables(array('tableTitle' => 'Voci scelta contraente sui contratti pubblici', 'tableDescription' => $paginator->getTotalItemCount() . ' voci scelta contraente in archivio', 'columns' => array("Nome", "Stato", " ", " "), 'paginator' => $paginator, 'records' => $this->formatRecordsToShowOnTable($paginatorRecords), 'dataTableActiveTitle' => 'Voci scelta contraente', 'formBreadCrumbCategory' => array(array('href' => $this->url()->fromRoute('admin/contratti-pubblici-summary', array('lang' => $this->params()->fromRoute('lang'))), 'title' => 'Elenco contratti pubblici', 'label' => 'Contratti pubblici')), 'templatePartial' => self::summaryTemplate));
     $this->layout()->setTemplate($mainLayout);
 }
 /**
  * Contratto details
  */
 public function detailsAction()
 {
     $mainLayout = $this->initializeFrontendWebsite();
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $id = $this->params()->fromRoute('id');
     try {
         $helper = new ContrattiPubbliciControllerHelper();
         $wrapper = $helper->recoverWrapperById(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('id' => $id, 'attivo' => 1, 'limit' => 1), $id);
         $attoRecord = $wrapper->getRecords();
         $helper->checkRecords($attoRecord, 'Nessun atto albo pretorio trovato');
         $wrapper->setEntityManager($em);
         $records = $wrapper->addAttachmentsFromRecords($attoRecord, array('moduleId' => ModulesContainer::albo_pretorio_id, 'noScaduti' => 1, 'orderBy' => 'a.position'));
         $this->layout()->setVariables(array('records' => $records, 'templatePartial' => 'contratti-pubblici/contratti-pubblici-details.phtml'));
     } catch (\Exception $e) {
         $logWriter = new LogWriter($em->getConnection());
         $logWriter->writeLog(array('user_id' => 0, 'module_id' => ModulesContainer::contratti_pubblici_id, 'message' => "Errore visualizzazione contratti pubblici sul sito pubblico", 'description' => $e->getMessage(), 'reference_id' => 0, 'type' => 'error', 'backend' => 0));
         $this->layout()->setVariables(array('messageType' => 'secondary', 'moduleLabel' => "Bandi di gara e contratti", 'messageTitle' => "Nessun bando di gara in archivio", 'messageText' => "Impossibile visualizzare i dati richiesti", 'templatePartial' => 'message.phtml'));
     }
     $this->layout()->setTemplate($mainLayout);
 }
 public function indexAction()
 {
     $mainLayout = $this->initializeAdminArea();
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $id = $this->params()->fromRoute('id');
     $lang = $this->params()->fromRoute('lang');
     $helper = new ContrattiPubbliciControllerHelper();
     $operatoriRecords = $helper->recoverWrapperRecordsById(new OperatoriGetterWrapper(new OperatoriGetter($em)), array('id' => $id, 'limit' => 1), $id);
     $form = new OperatoriForm();
     if ($operatoriRecords) {
         $form->setData($operatoriRecords[0]);
         $submitButtonValue = 'Modifica';
         $formTitle = $operatoriRecords[0]['nome'];
         $formAction = $this->url()->fromRoute('admin/contratti-pubblici-operatori-update', array('lang' => $lang));
     } else {
         $formTitle = 'Nuova azienda';
         $submitButtonValue = 'Inserisci';
         $formAction = $this->url()->fromRoute('admin/contratti-pubblici-operatori-insert', array('lang' => $lang));
     }
     $this->layout()->setVariables(array('form' => $form, 'formAction' => $formAction, 'formTitle' => $formTitle, 'formDescription' => 'Compila dati operatore abilitato a partecipare ai bandi di gara e contratti pubblici', 'submitButtonValue' => $submitButtonValue, 'formBreadCrumbCategory' => array(array('label' => 'Contratti pubblici', 'href' => $this->url()->fromRoute('admin/contratti-pubblici-summary', array('lang' => $lang)), 'title' => 'Elenco contratti pubblici'), array('label' => 'Aziende', 'href' => $this->url()->fromRoute('admin/contratti-pubblici-operatori-summary', array('lang' => $lang)), 'title' => 'Elenco aziende')), 'templatePartial' => self::formTemplate));
     $this->layout()->setTemplate($mainLayout);
 }
 public function indexAction()
 {
     $mainLayout = $this->initializeAdminArea();
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $id = $this->params()->fromRoute('id');
     $helper = new ContrattiPubbliciControllerHelper();
     $recordFromDb = $helper->recoverWrapperRecordsById(new SceltaContraenteGetterWrapper(new SceltaContraenteGetter($em)), array('csc.id' => $id, 'limit' => 1), $id);
     $form = new SceltaContraenteForm();
     if ($recordFromDb) {
         $form->setData($recordFromDb[0]);
         $formAction = $this->url()->fromRoute('admin/contratti-pubblici-scelta-contraente-update', array('lang' => $this->params()->fromRoute('lang')));
         $formTitle = 'Modifica voce scelta del contraente';
         $formDescription = 'Modifica dati e procedi';
         $formBreadCrumbTitle = 'Modifica';
     } else {
         $formAction = $this->url()->fromRoute('admin/contratti-pubblici-scelta-contraente-insert', array('lang' => $this->params()->fromRoute('lang')));
         $formTitle = 'Nuova voce scelta del contraente';
         $formDescription = 'Inserisci voce scelta contraente';
         $formBreadCrumbTitle = 'Nuova';
     }
     $this->layout()->setVariables(array('form' => $form, 'formAction' => $formAction, 'formTitle' => $formTitle, 'formDescription' => $formDescription, 'submitButtonValue' => 'Conferma', 'formBreadCrumbTitle' => $formBreadCrumbTitle, 'formBreadCrumbCategory' => array(array('href' => $this->url()->fromRoute('admin/contratti-pubblici-summary', array('lang' => $this->params()->fromRoute('lang'))), 'title' => 'Elenco contratti pubblici', 'label' => 'Contratti pubblici'), array('href' => $this->url()->fromRoute('admin/contratti-pubblici-scelta-contraente-summary', array('lang' => $this->params()->fromRoute('lang'))), 'title' => 'Elenco voci scelta contraente', 'label' => 'Scelta contraente')), 'templatePartial' => self::formTemplate));
     $this->layout()->setTemplate($mainLayout);
 }
 /**
  * @return \Zend\Http\Response
  */
 public function indexAction()
 {
     /**
      * @var \Doctrine\ORM\EntityManager $em
      */
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     /**
      * @var \Doctrine\DBAL\Connection $connection
      */
     $connection = $em->getConnection();
     $request = $this->getRequest();
     $post = array_merge_recursive($request->getPost()->toArray(), $request->getFiles()->toArray());
     if (!($request->isXmlHttpRequest() or $request->isPost())) {
         return $this->redirect()->toRoute('main');
     }
     $inputFilter = new ContrattiPubbliciFormInputFilter();
     $form = new ContrattiPubbliciForm();
     $form->setBindOnValidate(false);
     $form->setInputFilter($inputFilter->getInputFilter());
     $form->setData($post);
     $this->initializeAdminArea();
     $userDetails = $this->recoverUserDetails();
     $helper = new ContrattiPubbliciControllerHelper();
     $helper->setConnection($connection);
     $helper->getConnection()->beginTransaction();
     try {
         if (!$form->isValid()) {
             throw new NullException("The form is not valid");
         }
         $inputFilter->exchangeArray($form->getData());
         $helper->setLoggedUser($userDetails);
         $lastInsertId = $helper->insert($inputFilter);
         $logWriter = new LogWriter($connection);
         $logWriter->writeLog(array('type' => 'info', 'user_id' => $userDetails->id, 'module_id' => ModulesContainer::contratti_pubblici_id, 'message' => "Inserito il bando di gara " . $inputFilter->titolo, 'reference_id' => $lastInsertId, 'backend' => 1));
         $this->layout()->setVariables(array('messageType' => 'success', 'messageTitle' => 'Bando di gara inserito correttamente', 'messageText' => 'I dati sono stati processati correttamente dal sistema', 'showLinkResetFormAndShowIt' => 1, 'backToSummaryLink' => $this->url()->fromRoute('admin/contratti-pubblici-summary', array('lang' => 'it')), 'backToSummaryText' => "Elenco bandi di gara e contratti", 'attachmentsLink' => $this->url()->fromRoute('admin/attachments-summary', array('lang' => 'it', 'module' => 'contratti-pubblici', 'referenceId' => $lastInsertId)), 'insertAgainLabel' => "Inserisci un altro bando di gara"));
         $helper->getConnection()->commit();
     } catch (\Exception $e) {
         try {
             $helper->getConnection()->rollBack();
         } catch (\Doctrine\DBAL\ConnectionException $e) {
         }
         $logWriter = new LogWriter($connection);
         $logWriter->writeLog(array('user_id' => $userDetails->id, 'module_id' => ModulesContainer::contratti_pubblici_id, 'message' => "Errore inserimento nuovo bando di gara: " . $inputFilter->titolo, 'type' => 'error', 'description' => "Si è verificato un errore nell'inserimento del nuovo bando di gara: " . $e->getMessage(), 'backend' => 1));
         $this->layout()->setVariables(array('messageType' => 'danger', 'messageTitle' => 'Errore inserimento nuovo bando di gara: ' . $inputFilter->titolo, 'messageText' => 'Messaggio generato: ' . $e->getMessage(), 'form' => $form, 'formInputFilter' => $inputFilter->getInputFilter(), 'messageShowFormLink' => 1, 'messageShowForm' => 'Torna al form di inserimento dati'));
     }
     $this->layout()->setTemplate($this->layout()->getVariable('templateDir') . 'message.phtml');
 }
 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&agrave; inserito come <strong>disattivato</strong>. Occorrer&agrave; 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 jsonAction()
 {
     $this->initializeFrontendWebsite();
     $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default');
     $id = $this->params()->fromRoute('id');
     $helper = new ContrattiPubbliciControllerHelper();
     $wrapper = $helper->recoverWrapperById(new ContrattiPubbliciGetterWrapper(new ContrattiPubbliciGetter($em)), array('id' => $id, 'limit' => 1), $id);
     $wrapper->setEntityManager($em);
     $records = $wrapper->addAttachmentsFromRecords($wrapper->getRecords(), array());
     if (empty($records)) {
         return $this->redirectForUnvalidAccess();
     }
     $record = $records[0];
     return new JsonModel(array("Oggetto" => $record['titolo']));
 }