Thibault GUILLAUME d9f5569c48 publicite
2015-10-27 13:06:14 +01:00

220 lines
5.6 KiB
PHP

<?php
class Publication extends ObjectModel
{
public $id;
public $id_publication;
public $name;
public $id_block_ads;
public $id_shop;
public $content;
public $link;
public $active;
public $date_from;
public $date_to;
public $date_add;
public $date_upd;
public $pages = null;
public $pages_infos = null;
public static $definition = array(
'table' => 'ads_publication',
'primary' => 'id_publication',
'multilang' => true,
'fields' => array(
'id_block_ads' => array('type' => self::TYPE_INT, 'validate' => 'isInt'),
'name' => array('type' => self::TYPE_STRING, 'validate' => 'isGenericName'),
'id_shop' => array('type' => self::TYPE_INT, 'validate' => 'isInt'),
'content' => array('type' => self::TYPE_NOTHING, 'lang' => true, 'validate' => 'isAnything'),
'link' => array('type' => self::TYPE_STRING, 'lang' => true, 'validate' => 'isAnything'),
'date_from' => array('type' => self::TYPE_DATE, 'validate' => 'isDateFormat'),
'date_to' => array('type' => self::TYPE_DATE, 'validate' => 'isDateFormat'),
'active' => array('type' => self::TYPE_INT, 'validate' => 'isInt'),
'date_add' => array('type' => self::TYPE_DATE, 'validate' => 'isDate'),
'date_upd' => array('type' => self::TYPE_DATE, 'validate' => 'isDate'),
),
);
public function __construct($id = NULL, $id_lang = NULL, $id_shop = NULL)
{
parent::__construct($id, $id_lang, $id_shop);
$this->id_image = ($this->id && file_exists(_ADS_IMG_DIR_.(int)$this->id.'.jpg')) ? (int)$this->id : false;
$this->image_dir = _ADS_IMG_DIR_;
}
public function getInfos($page_name = null)
{
if(!Validate::isLoadedObject($this))
$this->pages_infos = array();
if($this->pages_infos === null)
{
$array_tmp = array();
$sql = 'SELECT *
FROM '._DB_PREFIX_.'ads_publication_other
WHERE id_publication = '.(int)$this->id.'';
$infos = Db::getInstance()->executeS($sql);
foreach($infos as $info)
{
$array_tmp[$info['page_name']][] = $info['id_free'];
}
$this->pages_infos = $array_tmp;
}
if(empty($page_name))
return $this->pages_infos;
if(isset($this->pages_infos[$page_name]))
return $this->pages_infos[$page_name];
return array();
}
public function getInfosWithValues($page_name)
{
$infos = $this->getInfos($page_name);
if(count($infos) == 0)
return array();
$id_lang = Context::getContext()->language->id;
if($page_name == 'postcms')
{
$sql = '
SELECT c.id_post as id, lc.title as content
FROM `'._DB_PREFIX_.'cmsps_posts` c
LEFT JOIN `'._DB_PREFIX_.'cmsps_posts_lang` lc
ON c.`id_post` = lc.`id_post`
AND lc.id_lang = '.$id_lang.'
WHERE c.id_post IN ('.implode(',', $infos).')';
}
elseif($page_name == 'postedito')
{
$sql = '
SELECT c.id_edito as id, lc.title as content
FROM `'._DB_PREFIX_.'cmsps_editos` c
LEFT JOIN `'._DB_PREFIX_.'cmsps_editos_lang` lc
ON c.`id_edito` = lc.`id_edito`
AND lc.id_lang = '.$id_lang.'
WHERE c.id_edito IN ('.implode(',', $infos).')
GROUP BY c.id_edito';
}
elseif($page_name == 'categorycms')
{
$sql = '
SELECT c.id_category as id, lc.title as content
FROM `'._DB_PREFIX_.'cmsps_categories` c
LEFT JOIN `'._DB_PREFIX_.'cmsps_categories_lang` lc
ON c.`id_category` = lc.`id_category`
AND lc.id_lang = '.$id_lang.'
LEFT JOIN `'._DB_PREFIX_.'cmsps_categories_shop` ls
ON c.`id_category` = ls.`id_category`
WHERE c.`id_category` IN ('.implode(',', $infos).')
GROUP BY c.id_category';
}
$res = Db::getInstance()->executeS($sql);
return $res;
}
public function getSelectedPages()
{
if(!Validate::isLoadedObject($this))
$this->pages = array();
if($this->pages === null)
{
$sql = 'SELECT page_name
FROM '._DB_PREFIX_.'ads_publication_page
WHERE id_publication = '.(int)$this->id;
$pages = Db::getInstance()->executeS($sql);
$pages = array_map(function($line){ return $line['page_name']; }, $pages);
$this->pages = $pages;
}
return $this->pages;
}
public function setPages($pages = array())
{
$this->pages = $pages;
if(Validate::isLoadedObject($this))
{
Db::getInstance()->execute('
DELETE FROM '._DB_PREFIX_.'ads_publication_page
WHERE id_publication = '.$this->id);
$req = array();
foreach($pages as $page_name)
$req[] = array(
'id_publication' => $this->id,
'page_name' => $page_name
);
Db::getInstance()->insert('ads_publication_page', $req);
}
}
public function setPageInfo($page_name, $infos)
{
$this->pages_infos[$page_name] = $infos;
if(Validate::isLoadedObject($this))
{
Db::getInstance()->execute('
DELETE FROM '._DB_PREFIX_.'ads_publication_other
WHERE id_publication = '.$this->id.'
AND page_name = "'.pSQL($page_name).'"');
$req = array();
foreach($infos as $info)
$req[] = array(
'id_publication' => $this->id,
'page_name' => $page_name,
'id_free' => $info
);
Db::getInstance()->insert('ads_publication_other', $req);
}
}
public static function getAllPages()
{
return array(
'index',
'postcms', //Article
'categorycms', //Category d'article
'postedito', //Article mise en forme différent
);
}
public static function getPageNameTranslated($page_name)
{
$array = array(
'index' => 'Page d\'accueil',
'postcms' => 'Article', //Article
'categorycms' => 'Catégorie d\'article', //Category d'article
'postedito' => 'Edito', //Article mise en forme différent
);
return isset($array[$page_name]) ? $array[$page_name] : $page_name;
}
public static function getPageNeedInfos()
{
return array(
'postcms',
'categorycms',
'postedito'
);
}
}