public function indexAction() { $mainLayout = $this->initializeFrontendWebsite(); $profondita = $this->params()->fromRoute('profondita'); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); $templateDir = $this->layout()->getVariable('templateDir'); $basicLayout = $this->layout()->getVariable('amministrazione_trasparente_basiclayout'); try { $helper = new ContenutiControllerHelper(); $sottosezioniRecords = $helper->recoverWrapperRecords(new SottoSezioniGetterWrapper(new SottoSezioniGetter($em)), array('attivo' => 1, 'profonditaDa' => $profondita, 'languageAbbreviation' => 'it', 'isAmmTrasparente' => 1, 'orderBy' => 'sottosezioni.posizione ASC')); $wrapperContenuti = $helper->recoverWrapper(new ContenutiGetterWrapper(new ContenutiGetter($em)), array('sottosezione' => $profondita, 'attivo' => 1, 'noscaduti' => 1, 'isAmmTrasparente' => 1, 'orderBy' => 'contenuti.posizione ASC')); $wrapperContenuti->setEntityManager($em); $contenutiRecords = $wrapperContenuti->addAttachmentsFromRecords($wrapperContenuti->getRecords(), array('moduleId' => ModulesContainer::amministrazione_trasparente_id, 'noscaduti' => 1, 'languageAbbreviation' => 'it', 'orderBy' => 'a.position')); $helper->checkRecords($contenutiRecords, "I dati relativi all'articolo richiesto non sono stati trovati"); $formSearch = new ContenutiFormSearch(); $formSearch->addAnno(); $formSearch->addCheckExpired(); $formSearch->addSubmitButton(); $formSearch->setData(array('anno' => date("Y"))); $this->layout()->setVariables(array('form' => $formSearch, 'sottoSezioni' => $sottosezioniRecords, 'contenuti' => !empty($contenutiRecords) ? $contenutiRecords : null, 'templatePartial' => 'amministrazione-trasparente/amministrazione-trasparente.phtml')); } catch (\Exception $e) { $this->layout()->setVariables(array('messageTitle' => 'Nessun articolo trovato', 'messageText' => 'Impossibile visualizzare i dati per la richiesta effettuata', 'moduleLabel' => 'Amministrazione trasparente', 'templatePartial' => 'message.phtml')); // TODO: log error } $this->layout()->setTemplate(isset($basicLayout) ? $templateDir . $basicLayout : $mainLayout); }
public function csvAction() { if ($this->getRequest()->isPost()) { $request = $this->getRequest(); $post = array_merge_recursive($request->getPost()->toArray(), $request->getFiles()->toArray()); $form = new ContenutiFormSearch(); $form->addSubmitButton(); $form->setBindOnValidate(false); $form->setData($post); if ($form->isValid()) { $sessionContainer = new SessionContainer(); $sessionContainer->offsetSet('contenutiFormSearch', $post); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); $wrapper = new ContenutiGetterWrapper(new ContenutiGetter($em)); $wrapper->setInput(array('limit' => 1500)); $wrapper->setupQueryBuilder(); $records = $wrapper->getRecords(); $csvExportHelper = new CsvExportHelper(); if (!empty($records)) { $arrayContent = array(); $arrayContent[] = array('Titolo', 'Sottotitolo', 'Testo'); foreach ($records as $record) { $arrayContent[] = array($record['titolo'], $record['sommario'], $record['testo']); } $content = $csvExportHelper->makeCsvLine($arrayContent); $response = $this->getResponse(); $response->getHeaders()->addHeaderLine('Content-Type', 'text/csv')->addHeaderLine('Content-Disposition', 'attachment; filename="contenuti_' . date("dmYHis") . '.csv"')->addHeaderLine('Accept-Ranges', 'bytes')->addHeaderLine('Content-Length', strlen($content)); $response->setContent($content); return $response; } } } return $this->redirectForUnvalidAccess(); }
/** * TODO: delete this method, use ContenutiSearchController * * Set session search for the summary * * @return mixed */ public function summarysearchAction() { if ($this->getRequest()->isPost()) { $formSearch = new ContenutiFormSearch(); $formSearch->addAnno(); $formSearch->addInHome(); $formSearch->addCheckExpired(); $sessioContainer = new SessionContainer(); $sessioContainer->offsetSet(ContenutiSearchController::sessionIdentifier, array('testo' => $this->params()->fromPost('testo'), 'sottosezioni' => $this->params()->fromPost('sottosezioni'), 'inhome' => $this->params()->fromPost('inhome'))); $referer = $this->getRequest()->getHeader('Referer'); if (is_object($referer)) { return $this->redirect()->toUrl($referer->getUri()); } } return $this->redirect()->toRoute('main'); }
/** * Set search session * * @return \Zend\Http\Response */ public function indexAction() { if ($this->getRequest()->isPost()) { $request = $this->getRequest(); $post = $request->getPost()->toArray(); $inputFilter = new ContenutiFormSearchInpuFilter(); $formSearch = new ContenutiFormSearch(); $formSearch->addAnno(); //$formSearch->addInHome(); //$formSearch->addSottosezioni(); $formSearch->addCheckExpired(); $formSearch->setData($post); if ($formSearch->isValid()) { $inputFilter->exchangeArray($formSearch->getData()); $sessioContainer = new SessionContainer(); $sessioContainer->offsetSet(self::sessionIdentifier, array('testo' => $inputFilter->testo, 'sottosezioni' => $inputFilter->sottosezioni, 'inhome' => $inputFilter->inhome)); $referer = $this->getRequest()->getHeader('Referer'); if (is_object($referer)) { return $this->redirect()->toUrl($referer->getUri()); } } $mainLayout = $this->initializeFrontendWebsite(); $moduleUrl = $this->url()->fromRoute('main', array('lang' => 'it')); $referer = $this->getRequest()->getHeader('Referer'); $refererUrl = is_object($referer) ? $referer->getUri() : $moduleUrl; $this->layout()->setVariables(array('formMessages' => $formSearch->getMessages(), 'refererUrl' => $refererUrl, 'moduleUrl' => $moduleUrl, 'moduleLabel' => "Contenuti", 'templatePartial' => 'form-message.phtml')); $this->layout()->setTemplate($mainLayout); } else { $referer = $this->getRequest()->getHeader('Referer'); if (is_object($referer)) { return $this->redirect()->toUrl($referer->getUri()); } return $this->redirect()->toRoute('main'); } }
public function indexAction() { $mainLayout = $this->initializeAdminArea(); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); $page = $this->params()->fromRoute('page'); $perPage = $this->params()->fromRoute('perPage'); $configurations = $this->layout()->getVariable('configurations'); $userDetails = $this->layout()->getVariable('userDetails'); $userRole = isset($userDetails->role) ? $userDetails->role : ''; $userId = isset($userDetails->id) ? $userDetails->id : 1; $languageSelection = $this->params()->fromRoute('languageSelection'); $modulename = $this->params()->fromRoute('modulename'); $isAmmTrasparente = $modulename != 'contenuti' ? 1 : 0; $sessionContainer = new SessionContainer(); $sessionSearch = $sessionContainer->offsetGet(ContenutiSearchController::sessionIdentifier); $helper = new ContenutiControllerHelper(); /* Detect form switch language */ if (!empty($configurations['isMultiLanguage']) == 1 and $modulename == 'contenuti') { $helper->setLanguagesGetterWrapper(new LanguagesGetterWrapper(new LanguagesGetter($em))); $formLanguage = $helper->setupLanguageFormSearch(new LanguagesFormSearch(), array('status' => 1), $languageSelection); } try { $wrapper = $helper->recoverWrapperRecordsPaginator(new ContenutiGetterWrapper(new ContenutiGetter($em)), array_merge(array('showToAll' => $userRole == 'WebMaster' ? null : 1, 'utente' => $userRole == 'WebMaster' ? null : $userId, 'languageAbbreviation' => $languageSelection, 'isAmmTrasparente' => $isAmmTrasparente, 'inhome' => isset($sessionSearch['inhome']) ? $sessionSearch['inhome'] : null, 'sottosezione' => isset($sessionSearch['sottosezioni']) ? $sessionSearch['sottosezioni'] : null, 'freeSearch' => isset($sessionSearch['testo']) ? $sessionSearch['testo'] : null, 'orderBy' => 'contenuti.id DESC'), !empty($sessionSearch) ? $sessionSearch : array()), $page, $perPage); $sottoSezioniRecords = $helper->recoverWrapperRecords(new SottoSezioniGetterWrapper(new SottoSezioniGetter($em)), array('isAmmTrasparente' => $isAmmTrasparente, 'showToAll' => $userRole == 'WebMaster' ? null : 1, 'languageAbbreviation' => $languageSelection)); $helper->checkRecords($sottoSezioniRecords, 'Nessuna sottosezione presente, verificare i parametri di ricerca e se sono presenti i dati'); $sottoSezioniRecordsForDropDown = $helper->formatSottoSezioniGetterWrapperRecordsForDropdown($sottoSezioniRecords); $wrapper->setEntityManager($em); $paginatorRecords = $wrapper->addAttachmentsToPaginatorRecords($wrapper->setupRecords(), array('moduleId' => $modulename == 'contenuti' ? ModulesContainer::contenuti_id : ModulesContainer::amministrazione_trasparente_id, 'orderBy' => 'a.position')); $formSearch = new ContenutiFormSearch(); $formSearch->addSottosezioni($sottoSezioniRecordsForDropDown); $formSearch->addInHome(); $formSearch->addSubmitButton(); $formSearch->setData(array_merge(array('languageSelection' => $languageSelection), !empty($sessionSearch) ? $sessionSearch : array())); $paginator = $wrapper->getPaginator(); $paginatorRecordsCount = $paginator->getTotalItemCount(); } catch (\Exception $e) { $this->layout()->setVariables(array('showMessage' => 1, 'messageType' => 'danger', 'messageTitle' => 'Si è verificato un problema', 'messageText' => $e->getMessage(), 'templatePartial' => 'message.phtml')); } $this->layout()->setVariables(array('tableTitle' => $modulename == 'contenuti' ? 'Contenuti' : 'Amministrazione trasparente', 'tableDescription' => !empty($paginatorRecordsCount) ? $paginatorRecordsCount . ' articoli in archivio' : null, 'paginator' => !empty($paginator) ? $paginator : null, 'records' => !empty($paginatorRecords) ? $this->formatRecordsToShowOnTable($paginatorRecords) : null, 'templatePartial' => 'datatable/datatable_contenuti.phtml', 'formSearch' => !empty($formSearch) ? $formSearch : null, 'formLanguage' => isset($formLanguage) ? $formLanguage : null, 'sessionSearch' => isset($sessionSearch) ? $sessionSearch : null, 'columns' => array("Sezione", "Sotto sezione", "Titolo", 'Date', 'Inserito da', " ", $userDetails->acl->hasResource("contenuti_update") ? " " : null, $userDetails->acl->hasResource("contenuti_delete") ? " " : null, $userDetails->acl->hasResource("contenuti_homepage") ? " " : null, $userDetails->acl->hasResource("contenuti_attachments") ? " " : null, ($isAmmTrasparente == 1 and $userDetails->acl->hasResource("amministrazione_trsparente_tabelle")) ? " " : null))); $this->layout()->setTemplate($mainLayout); }