* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 8783 $ * @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 BlockLink03 extends Module { /* @var boolean error */ protected $error = false; public function __construct() { $this->moduletable = 'blocklink03'; $this->name = 'blocklink03'; $this->tab = 'front_office_features'; $this->version = '1.5'; $this->author = 'PrestaShop'; $this->need_instance = 0; parent::__construct(); $this->displayName = $this->l('Link block'); $this->description = $this->l('Adds a block with additional links.'); $this->confirmUninstall = $this->l('Are you sure you want to delete all your links ?'); } public function install() { if (!parent::install() OR !$this->registerHook('leftColumn') OR !Db::getInstance()->Execute(' CREATE TABLE '._DB_PREFIX_.$this->moduletable.' ( `id_blocklink` int(2) NOT NULL AUTO_INCREMENT, `url` varchar(255) NOT NULL, `new_window` TINYINT(1) NOT NULL, PRIMARY KEY(`id_blocklink`)) ENGINE='._MYSQL_ENGINE_.' default CHARSET=utf8') OR !Db::getInstance()->Execute(' CREATE TABLE '._DB_PREFIX_.$this->moduletable.'_lang ( `id_blocklink` int(2) NOT NULL, `id_lang` int(2) NOT NULL, `text` varchar(64) NOT NULL, PRIMARY KEY(`id_blocklink`, `id_lang`)) ENGINE='._MYSQL_ENGINE_.' default CHARSET=utf8') OR !Configuration::updateValue('PS_BLOCKLINK03_TITLE', array('1' => 'Block link', '2' => 'Bloc lien'))) return false; return true; } public function uninstall() { if (!parent::uninstall() OR !Db::getInstance()->Execute('DROP TABLE '._DB_PREFIX_.$this->moduletable) OR !Db::getInstance()->Execute('DROP TABLE '._DB_PREFIX_.$this->moduletable.'_lang') OR !Configuration::deleteByName('PS_BLOCKLINK03_TITLE') OR !Configuration::deleteByName('PS_BLOCKLINK03_URL')) return false; return true; } public function hookLeftColumn($params) { global $cookie, $smarty; $links = $this->getLinks(); $smarty->assign(array( 'blocklink_links' => $links, 'title' => Configuration::get('PS_BLOCKLINK03_TITLE', $cookie->id_lang), 'url' => Configuration::get('PS_BLOCKLINK03_URL'), 'lang' => 'text_'.$cookie->id_lang )); /*if (!$links) return false;*/ return $this->display(__FILE__, $this->moduletable.'.tpl'); } public function hookRightColumn($params) { return $this->hookLeftColumn($params); } public function hookFooter($params) { return $this->hookLeftColumn($params); } public function hookTop($params) { return $this->hookLeftColumn($params); } public function getLinks() { global $cookie; include_once dirname(__FILE__).'/../privatesales/Sale.php'; $result = array(); /* Get id and url */ $ventes = Sale::getSales(TRUE, NULL, NULL, TRUE, FALSE, FALSE, '`date_start` DESC'); //print_r($ventes); $i = 0; foreach ($ventes AS $vente) { if (count(array_intersect($cookie->isLogged()? Customer::getGroupsStatic($cookie->id_customer): array(1), $vente->groups)) == 0) continue; //print_r($vente); $result[$i]['id'] = $vente->id; $result[$i]['id_category'] = $vente->id_category; $result[$i]['url'] = $vente->alias[1]; $result[$i]['title'] = $vente->title[1]; $result[$i]['text_2'] = $vente->title[1]; $result[$i]['newWindow'] = false; $i++; } // if (!$links = Db::getInstance()->ExecuteS('SELECT `id_blocklink`, `url`, `new_window` FROM '._DB_PREFIX_.$this->moduletable.((int)(Configuration::get('PS_BLOCKLINK_ORDERWAY')) == 1 ? ' ORDER BY `id_blocklink` DESC' : ''))) // return false; // $i = 0; // foreach ($links AS $link) // { // $result[$i]['id'] = $link['id_blocklink']; // $result[$i]['url'] = $link['url']; // $result[$i]['newWindow'] = $link['new_window']; // /* Get multilingual text */ // if (!$texts = Db::getInstance()->ExecuteS('SELECT `id_lang`, `text` FROM '._DB_PREFIX_.$this->moduletable.'_lang WHERE `id_blocklink`='.(int)($link['id_blocklink']))) // return false; // foreach ($texts AS $text) // $result[$i]['text_'.$text['id_lang']] = $text['text']; // $i++; // } return $result; } public function addLink() { /* Url registration */ if (!Db::getInstance()->Execute('INSERT INTO '._DB_PREFIX_.$this->moduletable.' VALUES (NULL, \''.pSQL($_POST['url']).'\', '.((isset($_POST['newWindow']) AND $_POST['newWindow']) == 'on' ? 1 : 0).')') OR !$lastId = mysql_insert_id()) return false; /* Multilingual text */ $languages = Language::getLanguages(); $defaultLanguage = (int)(Configuration::get('PS_LANG_DEFAULT')); if (!$languages) return false; foreach ($languages AS $language) if (!empty($_POST['text_'.$language['id_lang']])) { if (!Db::getInstance()->Execute('INSERT INTO '._DB_PREFIX_.$this->moduletable.'_lang VALUES ('.(int)($lastId).', '.(int)($language['id_lang']).', \''.pSQL($_POST['text_'.$language['id_lang']]).'\')')) return false; } else if (!Db::getInstance()->Execute('INSERT INTO '._DB_PREFIX_.$this->moduletable.'_lang VALUES ('.(int)($lastId).', '.(int)($language['id_lang']).', \''.pSQL($_POST['text_'.$defaultLanguage]).'\')')) return false; return true; } public function updateLink() { /* Url registration */ if (!Db::getInstance()->Execute('UPDATE '._DB_PREFIX_.$this->moduletable.' SET `url`=\''.pSQL($_POST['url']).'\', `new_window`='.(isset($_POST['newWindow']) ? 1 : 0).' WHERE `id_blocklink`='.(int)($_POST['id']))) return false; /* Multilingual text */ $languages = Language::getLanguages(); $defaultLanguage = (int)(Configuration::get('PS_LANG_DEFAULT')); if (!$languages) return false; if (!Db::getInstance()->Execute('DELETE FROM '._DB_PREFIX_.$this->moduletable.'_lang WHERE `id_blocklink` = '.(int)($_POST['id']))) return false ; foreach ($languages AS $language) if (!empty($_POST['text_'.$language['id_lang']])) { if (!Db::getInstance()->Execute('INSERT INTO '._DB_PREFIX_.$this->moduletable.'_lang VALUES ('.(int)($_POST['id']).', '.(int)($language['id_lang']).', \''.pSQL($_POST['text_'.$language['id_lang']]).'\')')) return false; } else if (!Db::getInstance()->Execute('INSERT INTO '._DB_PREFIX_.$this->moduletable.'_lang VALUES ('.(int)($_POST['id']).', '.$language['id_lang'].', \''.pSQL($_POST['text_'.$defaultLanguage]).'\')')) return false; return true; } public function deleteLink() { return (Db::getInstance()->Execute('DELETE FROM '._DB_PREFIX_.$this->moduletable.' WHERE `id_blocklink`='.(int)($_GET['id'])) AND Db::getInstance()->Execute('DELETE FROM '._DB_PREFIX_.$this->moduletable.'_lang WHERE `id_blocklink`='.(int)($_GET['id']))); } public function updateTitle() { $languages = Language::getLanguages(); $result = array(); foreach ($languages AS $language) $result[$language['id_lang']] = $_POST['title_'.$language['id_lang']]; if (!Configuration::updateValue('PS_BLOCKLINK03_TITLE', $result)) return false; return Configuration::updateValue('PS_BLOCKLINK03_URL', $_POST['title_url']); } public function getContent() { $this->_html = '
'.$this->l('ID').' | '.$this->l('Text').' | '.$this->l('URL').' | '.$this->l('Actions').' |
---|---|---|---|
'.$this->l('There are no links.').' | |||
'.$link['id'].' | '.$link['text_'.$cookie->id_lang].' | '.$link['url'].' |