/controllers/admin/AdminQuickAccessesController.php
PHP | 237 lines | 194 code | 18 blank | 25 comment | 19 complexity | dfc4383ec10a8187e69e4c1a209ec0f3 MD5 | raw file
Possible License(s): CC-BY-SA-3.0, LGPL-3.0
- <?php
- /*
- * 2007-2014 PrestaShop
- *
- * NOTICE OF LICENSE
- *
- * This source file is subject to the Open Software License (OSL 3.0)
- * that is bundled with this package in the file LICENSE.txt.
- * It is also available through the world-wide-web at this URL:
- * http://opensource.org/licenses/osl-3.0.php
- * If you did not receive a copy of the license and are unable to
- * obtain it through the world-wide-web, please send an email
- * to license@prestashop.com so we can send you a copy immediately.
- *
- * DISCLAIMER
- *
- * Do not edit or add to this file if you wish to upgrade PrestaShop to newer
- * versions in the future. If you wish to customize PrestaShop for your
- * needs please refer to http://www.prestashop.com for more information.
- *
- * @author PrestaShop SA <contact@prestashop.com>
- * @copyright 2007-2014 PrestaShop SA
- * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
- * International Registered Trademark & Property of PrestaShop SA
- */
- class AdminQuickAccessesControllerCore extends AdminController
- {
- public function __construct()
- {
- $this->bootstrap = true;
- $this->table = 'quick_access';
- $this->className = 'QuickAccess';
- $this->lang = true;
- $this->addRowAction('edit');
- $this->addRowAction('delete');
- $this->context = Context::getContext();
- if (!Tools::getValue('realedit'))
- $this->deleted = false;
- $this->bulk_actions = array(
- 'delete' => array(
- 'text' => $this->l('Delete selected'),
- 'confirm' => $this->l('Delete selected items?'),
- 'icon' => 'icon-trash'
- )
- );
- $this->fields_list = array(
- 'id_quick_access' => array(
- 'title' => $this->l('ID'),
- 'align' => 'center',
- 'class' => 'fixed-width-xs'
- ),
- 'name' => array(
- 'title' => $this->l('Name')
- ),
- 'link' => array(
- 'title' => $this->l('Link')
- ),
- 'new_window' => array(
- 'title' => $this->l('New window'),
- 'align' => 'center',
- 'type' => 'bool',
- 'active' => 'new_window',
- 'class' => 'fixed-width-sm'
- )
- );
- $this->fields_form = array(
- 'legend' => array(
- 'title' => $this->l('Quick Access menu'),
- 'icon' => 'icon-align-justify'
- ),
- 'input' => array(
- array(
- 'type' => 'text',
- 'label' => $this->l('Name'),
- 'name' => 'name',
- 'lang' => true,
- 'maxlength' => 32,
- 'required' => true,
- 'hint' => $this->l('Forbidden characters:').' <>;=#{}'
- ),
- array(
- 'type' => 'text',
- 'label' => $this->l('URL'),
- 'name' => 'link',
- 'maxlength' => 128,
- 'required' => true,
- 'hint' => $this->l('If it\'s a URL that comes from your Back Office, you MUST remove the security token.')
- ),
- array(
- 'type' => 'switch',
- 'label' => $this->l('Open in new window'),
- 'name' => 'new_window',
- 'required' => false,
- 'values' => array(
- array(
- 'id' => 'new_window_on',
- 'value' => 1,
- 'label' => '<img src="../img/admin/enabled.gif" alt="'.$this->l('Enabled').'" title="'.$this->l('Enabled').'" />'
- ),
- array(
- 'id' => 'new_window_off',
- 'value' => 0,
- 'label' => '<img src="../img/admin/disabled.gif" alt="'.$this->l('Disabled').'" title="'.$this->l('Disabled').'" />'
- )
- )
- )
- ),
- 'submit' => array(
- 'title' => $this->l('Save'),
- )
- );
- parent::__construct();
- }
- public function initPageHeaderToolbar()
- {
- if (empty($this->display))
- $this->page_header_toolbar_btn['new_quick_access'] = array(
- 'href' => self::$currentIndex.'&addquick_access&token='.$this->token,
- 'desc' => $this->l('Add new quick access', null, null, false),
- 'icon' => 'process-icon-new'
- );
- parent::initPageHeaderToolbar();
- }
- public function initProcess()
- {
- if ((isset($_GET['new_window'.$this->table]) || isset($_GET['new_window'])) && Tools::getValue($this->identifier))
- {
- if ($this->tabAccess['edit'] === '1')
- $this->action = 'newWindow';
- else
- $this->errors[] = Tools::displayError('You do not have permission to edit this.');
- }
- parent::initProcess();
- }
-
- public function getQuickAccessesList()
- {
- $links = QuickAccess::getQuickAccesses($this->context->language->id);
- return Tools::jsonEncode(array_map(array($this, 'getLinkToken'), $links));
- }
- public function getLinkToken($item){
- $url = parse_url($item['link']);
- parse_str($url['query'], $query);
- $controller = $query['controller'];
- $item['token'] = Tools::getAdminTokenLite($controller);
- return $item;
- }
- public function addQuickLink()
- {
- if (!isset($this->className) || empty($this->className))
- return false;
- $this->validateRules();
- if (count($this->errors) <= 0)
- {
- $this->object = new $this->className();
- $this->copyFromPost($this->object, $this->table);
- $exists = Db::getInstance()->getValue('SELECT id_quick_access FROM '._DB_PREFIX_.'quick_access WHERE link = "'.pSQL($this->object->link).'"');
- if ($exists)
- return true;
- $this->beforeAdd($this->object);
- if (method_exists($this->object, 'add') && !$this->object->add())
- {
- $this->errors[] = Tools::displayError('An error occurred while creating an object.').
- ' <b>'.$this->table.' ('.Db::getInstance()->getMsgError().')</b>';
- }
- /* voluntary do affectation here */
- elseif (($_POST[$this->identifier] = $this->object->id) && $this->postImage($this->object->id) && !count($this->errors) && $this->_redirect)
- {
- PrestaShopLogger::addLog(sprintf($this->l('%s addition', 'AdminTab', false, false), $this->className), 1, null, $this->className, (int)$this->object->id, true, (int)$this->context->employee->id);
- $this->afterAdd($this->object);
- }
- }
- $this->errors = array_unique($this->errors);
- if (!empty($this->errors))
- {
- d($this->errors);
- return false;
- }
- return $this->getQuickAccessesList();
- }
- public function processDelete()
- {
- parent::processDelete();
- return $this->getQuickAccessesList();
- }
- public function ajaxProcessGetUrl()
- {
- if (Tools::strtolower(Tools::getValue('method')) === 'add')
- {
- $params['new_window'] = 0;
- $params['name_'.(int)Configuration::get('PS_LANG_DEFAULT')] = Tools::getValue('name');
- $params['link'] = 'index.php?'.Tools::getValue('url');
- $params['submitAddquick_access'] = 1;
- unset($_POST['name']);
- $_POST = array_merge($_POST, $params);
- die($this->addQuickLink());
- }
- elseif (Tools::strtolower(Tools::getValue('method')) === 'remove')
- {
- $params['deletequick_access'] = 1;
- $_POST = array_merge($_POST, $params);
- die($this->processDelete());
- }
- }
- public function processNewWindow()
- {
- if (Validate::isLoadedObject($object = $this->loadObject()))
- {
- if ($object->toggleNewWindow())
- $this->redirect_after = self::$currentIndex.'&conf=5&token='.$this->token;
- else
- $this->errors[] = Tools::displayError('An error occurred while updating new window property.');
- }
- else
- $this->errors[] = Tools::displayError('An error occurred while updating the new window property for this object.').
- ' <b>'.$this->table.'</b> '.
- Tools::displayError('(cannot load object)');
- return $object;
- }
- }