133 lines
4.3 KiB
PHP
133 lines
4.3 KiB
PHP
<?php
|
|
/**
|
|
* 2007-2015 IQIT-COMMERCE.COM
|
|
*
|
|
* NOTICE OF LICENSE
|
|
*
|
|
* @author IQIT-COMMERCE.COM <support@iqit-commerce.com>
|
|
* @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;
|
|
}
|
|
}
|