* @copyright 2007-2015 IQIT-COMMERCE.COM * @license GNU General Public License version 2 * * You can not resell or redistribute this software. */ class IqitMenuLinks { public static function gets($id_lang, $id_shop, $id_iqitmenulinks = null) { $sql = 'SELECT l.id_iqitmenulinks, l.new_window, s.name, ll.link, ll.label FROM ' . _DB_PREFIX_ . 'iqitmenulinks l LEFT JOIN ' . _DB_PREFIX_ . 'iqitmenulinks_lang ll ON (l.id_iqitmenulinks = ll.id_iqitmenulinks AND ll.id_lang = ' . (int) $id_lang . ' AND ll.id_shop=' . (int) $id_shop . ') LEFT JOIN ' . _DB_PREFIX_ . 'shop s ON l.id_shop = s.id_shop WHERE 1 ' . ((!is_null($id_iqitmenulinks)) ? ' AND l.id_iqitmenulinks = "' . (int) $id_iqitmenulinks . '"' : '') . ' AND l.id_shop IN (0, ' . (int) $id_shop . ')'; return Db::getInstance()->executeS($sql); } public static function get($id_iqitmenulinks, $id_lang, $id_shop) { return self::gets($id_lang, $id_shop, $id_iqitmenulinks); } public static function getLinkLang($id_iqitmenulinks, $id_shop) { $ret = Db::getInstance()->executeS('SELECT l.id_iqitmenulinks, l.new_window, ll.link, ll.label, ll.id_lang FROM ' . _DB_PREFIX_ . 'iqitmenulinks l LEFT JOIN ' . _DB_PREFIX_ . 'iqitmenulinks_lang ll ON (l.id_iqitmenulinks = ll.id_iqitmenulinks AND ll.id_shop=' . (int) $id_shop . ') WHERE 1 ' . ((!is_null($id_iqitmenulinks)) ? ' AND l.id_iqitmenulinks = "' . (int) $id_iqitmenulinks . '"' : '') . ' AND l.id_shop IN (0, ' . (int) $id_shop . ')'); $link = array(); $label = array(); $new_window = false; foreach ($ret as $line) { $link[$line['id_lang']] = Tools::safeOutput($line['link']); $label[$line['id_lang']] = Tools::safeOutput($line['label']); $new_window = (bool) $line['new_window']; } return array('link' => $link, 'label' => $label, 'new_window' => $new_window); } public static function add($link, $label, $id_shop, $newWindow = 0) { if (!is_array($label)) { return false; } if (!is_array($link)) { return false; } Db::getInstance()->insert( 'iqitmenulinks', array( 'new_window' => (int) $newWindow, 'id_shop' => (int) $id_shop, ) ); $id_iqitmenulinks = Db::getInstance()->Insert_ID(); $result = true; foreach ($label as $id_lang => $label) { $result &= Db::getInstance()->insert( 'iqitmenulinks_lang', array( 'id_iqitmenulinks' => (int) $id_iqitmenulinks, 'id_lang' => (int) $id_lang, 'id_shop' => (int) $id_shop, 'label' => pSQL($label), 'link' => pSQL($link[$id_lang]), ) ); } return $result; } public static function update($link, $labels, $id_shop, $id_link, $newWindow = 0) { if (!is_array($labels)) { return false; } if (!is_array($link)) { return false; } Db::getInstance()->update( 'iqitmenulinks', array( 'new_window' => (int) $newWindow, 'id_shop' => (int) $id_shop, ), 'id_iqitmenulinks = ' . (int) $id_link ); foreach ($labels as $id_lang => $label) { Db::getInstance()->update( 'iqitmenulinks_lang', array( 'id_shop' => (int) $id_shop, 'label' => pSQL($label), 'link' => pSQL($link[$id_lang]), ), 'id_iqitmenulinks = ' . (int) $id_link . ' AND id_lang = ' . (int) $id_lang ); } return true; } public static function remove($id_iqitmenulinks, $id_shop) { $result = true; $result &= Db::getInstance()->delete('iqitmenulinks', 'id_iqitmenulinks = ' . (int) $id_iqitmenulinks . ' AND id_shop = ' . (int) $id_shop); $result &= Db::getInstance()->delete('iqitmenulinks_lang', 'id_iqitmenulinks = ' . (int) $id_iqitmenulinks); return $result; } }