/modules/blockadvertising/blockadvertising.php
PHP | 291 lines | 198 code | 40 blank | 53 comment | 40 complexity | 2c3cd2ac597244ea21e8d52d7ef8b48a MD5 | raw file
- <?php
- /*
- * 2007-2016 PrestaShop
- *
- * NOTICE OF LICENSE
- *
- * This source file is subject to the Academic Free License (AFL 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/afl-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-2016 PrestaShop SA
- * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0)
- * International Registered Trademark & Property of PrestaShop SA
- */
- if (!defined('_PS_VERSION_'))
- exit;
- class BlockAdvertising extends Module
- {
- /* Title associated to the image */
- public $adv_title;
- /* Link associated to the image */
- public $adv_link;
- /* Name of the image without extension */
- public $adv_imgname;
- /* Image path with extension */
- public $adv_img;
- public function __construct()
- {
- $this->name = 'blockadvertising';
- $this->tab = 'advertising_marketing';
- $this->version = '0.10.1';
- $this->author = 'PrestaShop';
- $this->need_instance = 0;
- $this->bootstrap = true;
- parent::__construct();
- $this->displayName = $this->l('Advertising block');
- $this->description = $this->l('Adds an advertisement block to selected sections of your e-commerce website.');
- $this->ps_versions_compliancy = array('min' => '1.6', 'max' => '1.6.99.99');
- $this->initialize();
- }
- /*
- * Set the properties of the module, like the link to the image and the title (contextual to the current shop context)
- */
- protected function initialize()
- {
- $this->adv_imgname = 'advertising';
- if ((Shop::getContext() == Shop::CONTEXT_GROUP || Shop::getContext() == Shop::CONTEXT_SHOP)
- && file_exists(_PS_MODULE_DIR_.$this->name.'/img/'.$this->adv_imgname.'-g'.$this->context->shop->getContextShopGroupID().'.'.Configuration::get('BLOCKADVERT_IMG_EXT'))
- )
- $this->adv_imgname .= '-g'.$this->context->shop->getContextShopGroupID();
- if (Shop::getContext() == Shop::CONTEXT_SHOP
- && file_exists(_PS_MODULE_DIR_.$this->name.'/img/'.$this->adv_imgname.'-s'.$this->context->shop->getContextShopID().'.'.Configuration::get('BLOCKADVERT_IMG_EXT'))
- )
- $this->adv_imgname .= '-s'.$this->context->shop->getContextShopID();
- // If none of them available go default
- if ($this->adv_imgname == 'advertising')
- $this->adv_img = Tools::getMediaServer($this->name)._MODULE_DIR_.$this->name.'/img/fixtures/'.$this->adv_imgname.'.jpg';
- else
- $this->adv_img = Tools::getMediaServer($this->name)._MODULE_DIR_.$this->name.'/img/'.$this->adv_imgname.'.'.Configuration::get('BLOCKADVERT_IMG_EXT');
- $this->adv_link = htmlentities(Configuration::get('BLOCKADVERT_LINK'), ENT_QUOTES, 'UTF-8');
- $this->adv_title = htmlentities(Configuration::get('BLOCKADVERT_TITLE'), ENT_QUOTES, 'UTF-8');
- }
- public function install()
- {
- if (!parent::install())
- return false;
- // Hook the module either on the left or right column
- $theme = new Theme(Context::getContext()->shop->id_theme);
- if ((!$theme->default_left_column || !$this->registerHook('leftColumn'))
- && (!$theme->default_right_column || !$this->registerHook('rightColumn'))
- )
- {
- // If there are no colums implemented by the template, throw an error and uninstall the module
- $this->_errors[] = $this->l('This module needs to be hooked to a column, but your theme does not implement one');
- parent::uninstall();
- return false;
- }
- Configuration::updateGlobalValue('BLOCKADVERT_LINK', 'http://www.prestashop.com/');
- Configuration::updateGlobalValue('BLOCKADVERT_TITLE', 'PrestaShop');
- // Try to update with the extension of the image that exists in the module directory
- foreach (scandir(_PS_MODULE_DIR_.$this->name) as $file)
- if (in_array($file, array('advertising.jpg', 'advertising.gif', 'advertising.png')))
- Configuration::updateGlobalValue('BLOCKADVERT_IMG_EXT', substr($file, strrpos($file, '.') + 1));
- return true;
- }
- public function uninstall()
- {
- Configuration::deleteByName('BLOCKADVERT_LINK');
- Configuration::deleteByName('BLOCKADVERT_TITLE');
- Configuration::deleteByName('BLOCKADVERT_IMG_EXT');
- return (parent::uninstall());
- }
- /**
- * delete the contextual image (it is not allowed to delete the default image)
- *
- * @return void
- */
- private function _deleteCurrentImg()
- {
- // Delete the image file
- if ($this->adv_imgname != 'advertising' && file_exists(_PS_MODULE_DIR_.$this->name.'/img/'.$this->adv_imgname.'.'.Configuration::get('BLOCKADVERT_IMG_EXT')))
- unlink(_PS_MODULE_DIR_.$this->name.'/img/'.$this->adv_imgname.'.'.Configuration::get('BLOCKADVERT_IMG_EXT'));
- // Update the extension to the global value or the shop group value if available
- Configuration::deleteFromContext('BLOCKADVERT_IMG_EXT');
- Configuration::updateValue('BLOCKADVERT_IMG_EXT', Configuration::get('BLOCKADVERT_IMG_EXT'));
- // Reset the properties of the module
- $this->initialize();
- }
- public function postProcess()
- {
- if (Tools::isSubmit('submitDeleteImgConf'))
- $this->_deleteCurrentImg();
- $errors = '';
- if (Tools::isSubmit('submitAdvConf'))
- {
- if (isset($_FILES['adv_img']) && isset($_FILES['adv_img']['tmp_name']) && !empty($_FILES['adv_img']['tmp_name']))
- {
- if ($error = ImageManager::validateUpload($_FILES['adv_img'], Tools::convertBytes(ini_get('upload_max_filesize'))))
- $errors .= $error;
- else
- {
- Configuration::updateValue('BLOCKADVERT_IMG_EXT', substr($_FILES['adv_img']['name'], strrpos($_FILES['adv_img']['name'], '.') + 1));
- // Set the image name with a name contextual to the shop context
- $this->adv_imgname = 'advertising';
- if (Shop::getContext() == Shop::CONTEXT_GROUP)
- $this->adv_imgname = 'advertising-g'.(int)$this->context->shop->getContextShopGroupID();
- elseif (Shop::getContext() == Shop::CONTEXT_SHOP)
- $this->adv_imgname = 'advertising-s'.(int)$this->context->shop->getContextShopID();
- // Copy the image in the module directory with its new name
- if (!move_uploaded_file($_FILES['adv_img']['tmp_name'], _PS_MODULE_DIR_.$this->name.'/img/'.$this->adv_imgname.'.'.Configuration::get('BLOCKADVERT_IMG_EXT')))
- $errors .= $this->l('File upload error.');
- }
- }
- // If the link is not set, then delete it in order to use the next default value (either the global value or the group value)
- if ($link = Tools::getValue('adv_link'))
- Configuration::updateValue('BLOCKADVERT_LINK', $link);
- elseif (Shop::getContext() == Shop::CONTEXT_SHOP || Shop::getContext() == Shop::CONTEXT_GROUP)
- Configuration::deleteFromContext('BLOCKADVERT_LINK');
- // If the title is not set, then delete it in order to use the next default value (either the global value or the group value)
- if ($title = Tools::getValue('adv_title'))
- Configuration::updateValue('BLOCKADVERT_TITLE', $title);
- elseif (Shop::getContext() == Shop::CONTEXT_SHOP || Shop::getContext() == Shop::CONTEXT_GROUP)
- Configuration::deleteFromContext('BLOCKADVERT_TITLE');
- // Reset the module properties
- $this->initialize();
- $this->_clearCache('blockadvertising.tpl');
- if (!$errors)
- Tools::redirectAdmin(AdminController::$currentIndex.'&configure='.$this->name.'&token='.Tools::getAdminTokenLite('AdminModules').'&conf=6');
- echo $this->displayError($errors);
- }
- }
- /**
- * getContent used to display admin module form
- *
- * @return string content
- */
- public function getContent()
- {
- $this->postProcess();
- return $this->renderForm();
- }
- public function hookRightColumn($params)
- {
- if (!$this->isCached('blockadvertising.tpl', $this->getCacheId()))
- $this->smarty->assign(
- array(
- 'image' => $this->context->link->protocol_content.$this->adv_img,
- 'adv_link' => $this->adv_link,
- 'adv_title' => $this->adv_title,
- )
- );
- return $this->display(__FILE__, 'blockadvertising.tpl', $this->getCacheId());
- }
- public function hookLeftColumn($params)
- {
- return $this->hookRightColumn($params);
- }
- public function hookHeader($params)
- {
- $this->context->controller->addCSS($this->_path.'blockadvertising.css', 'all');
- }
- public function renderForm()
- {
- $fields_form = array(
- 'form' => array(
- 'legend' => array(
- 'title' => $this->l('Configuration'),
- 'icon' => 'icon-cogs'
- ),
- 'input' => array(
- array(
- 'type' => 'file',
- 'label' => $this->l('Image for the advertisement'),
- 'name' => 'adv_img',
- 'desc' => $this->l('By default the image will appear in the left column. The recommended dimensions are 155 x 163px.'),
- 'thumb' => $this->context->link->protocol_content.$this->adv_img,
- ),
- array(
- 'type' => 'text',
- 'label' => $this->l('Target link for the image'),
- 'name' => 'adv_link',
- ),
- array(
- 'type' => 'text',
- 'label' => $this->l('Title of the target link'),
- 'name' => 'adv_title',
- 'desc' => $this->l('This title will be displayed when you mouse over the advertisement block in your shop.')
- ),
- ),
- 'submit' => array(
- 'title' => $this->l('Save'),
- )
- ),
- );
- $helper = new HelperForm();
- $helper->show_toolbar = false;
- $helper->table = $this->table;
- $lang = new Language((int)Configuration::get('PS_LANG_DEFAULT'));
- $helper->default_form_language = $lang->id;
- $helper->allow_employee_form_lang = Configuration::get('PS_BO_ALLOW_EMPLOYEE_FORM_LANG') ? Configuration::get('PS_BO_ALLOW_EMPLOYEE_FORM_LANG') : 0;
- $this->fields_form = array();
- $helper->identifier = $this->identifier;
- $helper->submit_action = 'submitAdvConf';
- $helper->currentIndex = $this->context->link->getAdminLink('AdminModules', false).'&configure='.$this->name.'&tab_module='.$this->tab.'&module_name='.$this->name;
- $helper->token = Tools::getAdminTokenLite('AdminModules');
- $helper->tpl_vars = array(
- 'fields_value' => $this->getConfigFieldsValues(),
- 'languages' => $this->context->controller->getLanguages(),
- 'id_language' => $this->context->language->id
- );
- return $helper->generateForm(array($fields_form));
- }
- public function getConfigFieldsValues()
- {
- return array(
- 'adv_link' => Tools::getValue('adv_link', Configuration::get('BLOCKADVERT_LINK')),
- 'adv_title' => Tools::getValue('adv_title', Configuration::get('BLOCKADVERT_TITLE')),
- );
- }
- }