194 lines
6.9 KiB
PHP
194 lines
6.9 KiB
PHP
<?php
|
|
/**
|
|
* 2007-2019 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-2019 PrestaShop SA
|
|
* @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0)
|
|
* International Registered Trademark & Property of PrestaShop SA
|
|
*/
|
|
class ReassuranceActivity extends ObjectModel
|
|
{
|
|
const TYPE_LINK_NONE = 0;
|
|
const TYPE_LINK_CMS_PAGE = 1;
|
|
const TYPE_LINK_URL = 2;
|
|
|
|
public $id;
|
|
public $icon;
|
|
public $custom_icon;
|
|
public $title;
|
|
public $description;
|
|
public $status;
|
|
public $position;
|
|
public $id_shop;
|
|
public $type_link;
|
|
public $link;
|
|
public $id_cms;
|
|
public $date_add;
|
|
public $date_upd;
|
|
|
|
/**
|
|
* @see ObjectModel::$definition
|
|
*/
|
|
public static $definition = array(
|
|
'table' => 'psreassurance',
|
|
'primary' => 'id_psreassurance',
|
|
'multilang' => true,
|
|
'multilang_shop' => true,
|
|
'fields' => array(
|
|
'icon' => array('type' => self::TYPE_STRING, 'shop' => true, 'validate' => 'isCleanHtml', 'size' => 255),
|
|
'custom_icon' => array('type' => self::TYPE_STRING, 'shop' => true, 'validate' => 'isCleanHtml', 'size' => 255),
|
|
'title' => array('type' => self::TYPE_STRING, 'shop' => true, 'lang' => true, 'validate' => 'isCleanHtml', 'size' => 255),
|
|
'description' => array('type' => self::TYPE_HTML, 'shop' => true, 'lang' => true, 'validate' => 'isCleanHtml', 'size' => 2000),
|
|
'status' => array('type' => self::TYPE_BOOL, 'shop' => true, 'validate' => 'isBool', 'required' => true),
|
|
'position' => array('type' => self::TYPE_INT, 'shop' => true, 'validate' => 'isunsignedInt', 'required' => false),
|
|
'type_link' => array('type' => self::TYPE_INT, 'shop' => true, 'validate' => 'isunsignedInt', 'required' => false),
|
|
'id_cms' => array('type' => self::TYPE_INT, 'shop' => true, 'validate' => 'isunsignedInt', 'required' => false),
|
|
'link' => array('type' => self::TYPE_STRING, 'shop' => true, 'lang' => true, 'validate' => 'isUrl', 'required' => false, 'size' => 255),
|
|
'date_add' => array('type' => self::TYPE_DATE, 'shop' => true, 'validate' => 'isDate'),
|
|
'date_upd' => array('type' => self::TYPE_DATE, 'shop' => true, 'validate' => 'isDate'),
|
|
),
|
|
);
|
|
|
|
/**
|
|
* @param int $id_lang
|
|
* @param int $id_shop
|
|
*
|
|
* @return array
|
|
*
|
|
* @throws PrestaShopDatabaseException
|
|
*/
|
|
public static function getAllBlockByLang($id_lang = 1, $id_shop = 1)
|
|
{
|
|
$sql = 'SELECT * FROM `' . _DB_PREFIX_ . 'psreassurance` pr
|
|
LEFT JOIN ' . _DB_PREFIX_ . 'psreassurance_lang prl ON (pr.id_psreassurance = prl.id_psreassurance)
|
|
WHERE prl.id_lang = "' . (int) $id_lang . '" AND prl.id_shop = "' . (int) $id_shop . '"
|
|
ORDER BY pr.position';
|
|
|
|
$result = Db::getInstance()->executeS($sql);
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* @param array $psr_languages
|
|
* @param int $type_link
|
|
* @param int $id_cms
|
|
*/
|
|
public function handleBlockValues($psr_languages, $type_link, $id_cms)
|
|
{
|
|
$languages = Language::getLanguages();
|
|
$newValues = [];
|
|
|
|
foreach ($psr_languages as $key => $value) {
|
|
$newValues[$key] = [
|
|
'title' => $value->title,
|
|
'description' => $value->description,
|
|
'url' => $value->url,
|
|
];
|
|
}
|
|
|
|
foreach ($languages as $language) {
|
|
if (false === array_key_exists($language['id_lang'], $newValues)) {
|
|
continue;
|
|
}
|
|
|
|
$this->title[$language['id_lang']] = $newValues[$language['id_lang']]['title'];
|
|
$this->description[$language['id_lang']] = $newValues[$language['id_lang']]['description'];
|
|
|
|
if ($type_link === self::TYPE_LINK_URL) {
|
|
$this->link[$language['id_lang']] = $newValues[$language['id_lang']]['url'];
|
|
} else {
|
|
$this->link[$language['id_lang']] = '';
|
|
}
|
|
}
|
|
|
|
if (!empty($id_cms) && $type_link === self::TYPE_LINK_CMS_PAGE) {
|
|
$this->id_cms = $id_cms;
|
|
$link = Context::getContext()->link;
|
|
|
|
foreach ($languages as $language) {
|
|
$this->link[$language['id_lang']] = $link->getCMSLink(
|
|
$id_cms,
|
|
null,
|
|
null,
|
|
$language['id_lang']
|
|
);
|
|
}
|
|
}
|
|
|
|
if ($type_link == 'undefined') {
|
|
$type_link = self::TYPE_LINK_NONE;
|
|
}
|
|
|
|
$this->type_link = $type_link;
|
|
}
|
|
|
|
/**
|
|
* @param int $id_shop
|
|
*
|
|
* @return array
|
|
*
|
|
* @throws PrestaShopDatabaseException
|
|
*/
|
|
public static function getAllBlockByShop($id_shop = 1)
|
|
{
|
|
$result = [];
|
|
|
|
$sql = 'SELECT * FROM `' . _DB_PREFIX_ . 'psreassurance` pr
|
|
LEFT JOIN ' . _DB_PREFIX_ . 'psreassurance_lang prl ON (pr.id_psreassurance = prl.id_psreassurance)
|
|
WHERE prl.id_shop = "' . (int) $id_shop . '"
|
|
GROUP BY prl.id_lang, pr.id_psreassurance
|
|
ORDER BY pr.position';
|
|
|
|
$dbResult = Db::getInstance()->executeS($sql);
|
|
|
|
foreach ($dbResult as $key => $value) {
|
|
$result[$value['id_lang']][$value['id_psreassurance']]['title'] = $value['title'];
|
|
$result[$value['id_lang']][$value['id_psreassurance']]['description'] = $value['description'];
|
|
$result[$value['id_lang']][$value['id_psreassurance']]['url'] = $value['link'];
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* @param int $id_lang
|
|
* @param int $id_shop
|
|
*
|
|
* @return array
|
|
*
|
|
* @throws PrestaShopDatabaseException
|
|
*/
|
|
public static function getAllBlockByStatus($id_lang = 1, $id_shop = 1)
|
|
{
|
|
$sql = 'SELECT * FROM `' . _DB_PREFIX_ . 'psreassurance` pr
|
|
LEFT JOIN ' . _DB_PREFIX_ . 'psreassurance_lang prl ON (pr.id_psreassurance = prl.id_psreassurance)
|
|
WHERE
|
|
prl.id_lang = "' . (int) $id_lang . '"
|
|
AND prl.id_shop = "' . (int) $id_shop . '"
|
|
AND pr.status = 1
|
|
ORDER BY pr.position';
|
|
|
|
$result = Db::getInstance()->executeS($sql);
|
|
|
|
return $result;
|
|
}
|
|
}
|