2015-12-01 07:06:34 +02:00
|
|
|
<?php
|
|
|
|
/*----------------------------------------------------------------------------------| www.giz.de |----/
|
|
|
|
Deutsche Gesellschaft für International Zusammenarbeit (GIZ) Gmb
|
|
|
|
/-------------------------------------------------------------------------------------------------------/
|
|
|
|
|
2016-06-27 11:46:34 +01:00
|
|
|
@version 3.4.2
|
|
|
|
@build 27th June, 2016
|
2015-12-01 07:06:34 +02:00
|
|
|
@created 15th June, 2012
|
|
|
|
@package Cost Benefit Projection
|
|
|
|
@subpackage companies.php
|
|
|
|
@author Llewellyn van der Merwe <http://www.vdm.io>
|
|
|
|
@owner Deutsche Gesellschaft für International Zusammenarbeit (GIZ) Gmb
|
|
|
|
@copyright Copyright (C) 2015. All Rights Reserved
|
|
|
|
@license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
|
|
|
|
|
|
|
/-------------------------------------------------------------------------------------------------------/
|
|
|
|
Cost Benefit Projection Tool.
|
|
|
|
/------------------------------------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
// No direct access to this file
|
|
|
|
defined('_JEXEC') or die('Restricted access');
|
|
|
|
|
|
|
|
// import Joomla controlleradmin library
|
|
|
|
jimport('joomla.application.component.controlleradmin');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Companies Controller
|
|
|
|
*/
|
|
|
|
class CostbenefitprojectionControllerCompanies extends JControllerAdmin
|
|
|
|
{
|
|
|
|
protected $text_prefix = 'COM_COSTBENEFITPROJECTION_COMPANIES';
|
|
|
|
/**
|
|
|
|
* Proxy for getModel.
|
|
|
|
* @since 2.5
|
|
|
|
*/
|
|
|
|
public function getModel($name = 'Company', $prefix = 'CostbenefitprojectionModel', $config = array())
|
|
|
|
{
|
|
|
|
$model = parent::getModel($name, $prefix, array('ignore_request' => true));
|
|
|
|
|
|
|
|
return $model;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function exportData()
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Check for request forgeries
|
2015-12-01 07:06:34 +02:00
|
|
|
JSession::checkToken() or die(JText::_('JINVALID_TOKEN'));
|
2016-01-14 09:44:50 +02:00
|
|
|
// check if export is allowed for this user.
|
2015-12-01 07:06:34 +02:00
|
|
|
$user = JFactory::getUser();
|
|
|
|
if ($user->authorise('company.export', 'com_costbenefitprojection') && $user->authorise('core.export', 'com_costbenefitprojection'))
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Get the input
|
2015-12-01 07:06:34 +02:00
|
|
|
$input = JFactory::getApplication()->input;
|
|
|
|
$pks = $input->post->get('cid', array(), 'array');
|
2016-01-14 09:44:50 +02:00
|
|
|
// Sanitize the input
|
2015-12-01 07:06:34 +02:00
|
|
|
JArrayHelper::toInteger($pks);
|
2016-01-14 09:44:50 +02:00
|
|
|
// Get the model
|
2015-12-01 07:06:34 +02:00
|
|
|
$model = $this->getModel('Companies');
|
2016-01-14 09:44:50 +02:00
|
|
|
// get the data to export
|
2015-12-01 07:06:34 +02:00
|
|
|
$data = $model->getExportData($pks);
|
|
|
|
if (CostbenefitprojectionHelper::checkArray($data))
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// now set the data to the spreadsheet
|
2015-12-01 07:06:34 +02:00
|
|
|
$date = JFactory::getDate();
|
|
|
|
CostbenefitprojectionHelper::xls($data,'Companies_'.$date->format('jS_F_Y'),'Companies exported ('.$date->format('jS F, Y').')','companies');
|
|
|
|
}
|
|
|
|
}
|
2016-01-14 09:44:50 +02:00
|
|
|
// Redirect to the list screen with error.
|
2015-12-01 07:06:34 +02:00
|
|
|
$message = JText::_('COM_COSTBENEFITPROJECTION_EXPORT_FAILED');
|
|
|
|
$this->setRedirect(JRoute::_('index.php?option=com_costbenefitprojection&view=companies', false), $message, 'error');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function importData()
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Check for request forgeries
|
2015-12-01 07:06:34 +02:00
|
|
|
JSession::checkToken() or die(JText::_('JINVALID_TOKEN'));
|
2016-01-14 09:44:50 +02:00
|
|
|
// check if import is allowed for this user.
|
2015-12-01 07:06:34 +02:00
|
|
|
$user = JFactory::getUser();
|
|
|
|
if ($user->authorise('company.import', 'com_costbenefitprojection') && $user->authorise('core.import', 'com_costbenefitprojection'))
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Get the import model
|
2015-12-01 07:06:34 +02:00
|
|
|
$model = $this->getModel('Companies');
|
2016-01-14 09:44:50 +02:00
|
|
|
// get the headers to import
|
2015-12-01 07:06:34 +02:00
|
|
|
$headers = $model->getExImPortHeaders();
|
|
|
|
if (CostbenefitprojectionHelper::checkObject($headers))
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Load headers to session.
|
2015-12-01 07:06:34 +02:00
|
|
|
$session = JFactory::getSession();
|
|
|
|
$headers = json_encode($headers);
|
|
|
|
$session->set('company_VDM_IMPORTHEADERS', $headers);
|
|
|
|
$session->set('backto_VDM_IMPORT', 'companies');
|
|
|
|
$session->set('dataType_VDM_IMPORTINTO', 'company');
|
2016-01-14 09:44:50 +02:00
|
|
|
// Redirect to import view.
|
2015-12-01 07:06:34 +02:00
|
|
|
$message = JText::_('COM_COSTBENEFITPROJECTION_IMPORT_SELECT_FILE_FOR_COMPANIES');
|
|
|
|
$this->setRedirect(JRoute::_('index.php?option=com_costbenefitprojection&view=import', false), $message);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2016-01-14 09:44:50 +02:00
|
|
|
// Redirect to the list screen with error.
|
2015-12-01 07:06:34 +02:00
|
|
|
$message = JText::_('COM_COSTBENEFITPROJECTION_IMPORT_FAILED');
|
|
|
|
$this->setRedirect(JRoute::_('index.php?option=com_costbenefitprojection&view=companies', false), $message, 'error');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function redirectToCombinedresults()
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Check for request forgeries
|
2015-12-01 07:06:34 +02:00
|
|
|
JSession::checkToken() or die(JText::_('JINVALID_TOKEN'));
|
2016-01-14 09:44:50 +02:00
|
|
|
// check if export is allowed for this user.
|
2015-12-01 07:06:34 +02:00
|
|
|
$user = JFactory::getUser();
|
|
|
|
if ($user->authorise('combinedresults.access', 'com_costbenefitprojection'))
|
|
|
|
{
|
2016-01-14 09:44:50 +02:00
|
|
|
// Get the input
|
2015-12-01 07:06:34 +02:00
|
|
|
$input = JFactory::getApplication()->input;
|
|
|
|
$pks = $input->post->get('cid', array(), 'array');
|
2016-01-14 09:44:50 +02:00
|
|
|
// Sanitize the input
|
2015-12-01 07:06:34 +02:00
|
|
|
JArrayHelper::toInteger($pks);
|
2016-01-14 09:44:50 +02:00
|
|
|
// convert to string
|
2015-12-01 07:06:34 +02:00
|
|
|
$ids = implode('_', $pks);
|
|
|
|
$this->setRedirect(JRoute::_('index.php?option=com_costbenefitprojection&view=combinedresults&cid='.$ids, false));
|
|
|
|
return;
|
|
|
|
}
|
2016-01-14 09:44:50 +02:00
|
|
|
// Redirect to the list screen with error.
|
2015-12-01 07:06:34 +02:00
|
|
|
$message = JText::_('COM_COSTBENEFITPROJECTION_ACCESS_TO_COMBINEDRESULTS_FAILED');
|
|
|
|
$this->setRedirect(JRoute::_('index.php?option=com_costbenefitprojection&view=companies', false), $message, 'error');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|