'small', 'width' => 400, 'height' => 260 ), array( 'name' => 'big', 'width' => 770, 'height' => 500 ) ); /** * @see ObjectModel::$definition */ public static $definition = array( 'table' => 'cmsps_posts', 'primary' => 'id_post', 'multilang' => TRUE, 'multilang_shop' => TRUE, 'fields' => array( 'id_category' => array('type' => self::TYPE_INT, 'validate' => 'isInt', 'required' => TRUE), 'active' => array('type' => self::TYPE_INT, 'validate' => 'isInt'), 'show_home' => array('type' => self::TYPE_INT, 'validate' => 'isInt'), 'trick' => array('type' => self::TYPE_INT, 'validate' => 'isInt'), 'is_video' => array('type' => self::TYPE_INT, 'validate' => 'isInt'), 'note' => array('type' => self::TYPE_INT, 'validate' => 'isInt'), 'video' => array('type' => self::TYPE_HTML, 'validate' => 'isCleanPerso'), 'amazon' => array('type' => self::TYPE_HTML, 'validate' => 'isCleanPerso'), // Lang fields 'title' => array('type' => self::TYPE_STRING, 'lang' => TRUE, 'validate' => 'isGenericName', 'required' => TRUE), 'slug' => array('type' => self::TYPE_STRING, 'lang' => TRUE, 'validate' => 'isGenericName'), 'intro' => array('type' => self::TYPE_HTML, 'lang' => TRUE, 'validate' => 'isCleanHtml'), 'content' => array('type' => self::TYPE_HTML, 'lang' => TRUE, 'validate' => 'isCleanHtml'), 'meta_title' => array('type' => self::TYPE_STRING, 'lang' => TRUE, 'validate' => 'isGenericName'), 'meta_desc' => array('type' => self::TYPE_STRING, 'lang' => TRUE, 'validate' => 'isGenericName'), 'date_add' => array('type' => self::TYPE_DATE), 'date_upd' => array('type' => self::TYPE_DATE) ), ); public function __construct($id = NULL, $id_lang = NULL, $id_shop = NULL) { parent::__construct($id, $id_lang, $id_shop); } public static function getPostHome($id_lang, $limit = 14) { $collection_post = new Collection('CmsPsPost', $id_lang); $collection_post->where('show_home', '=', 1); $collection_post->where('active', '=', 1); $collection_post->orderBy('date_add', 'DESC'); $collection_post->setPageSize(14); $posts = $collection_post->getResults(); return self::injectsData($posts); } public static function getVideoPost($id_lang, $limit = 10) { $collection_post = new Collection('CmsPsPost', $id_lang); $collection_post->where('is_video', '=', 1); $collection_post->where('active', '=', 1); $collection_post->orderBy('date_add', 'DESC'); $collection_post->setPageSize($limit); $posts = $collection_post->getResults(); return self::injectsData($posts); } /** * Associated data for each obj Post before display on Front * * @param array Array of CmsPsPost Object * @return array array of post object with data associated */ public static function injectsData($articles, $full = FALSE) { $array = TRUE; if(!is_array($articles)) { $array = FALSE; $articles = array($articles); } foreach ($articles as $key => $article) { $article->new = $article->isNew(); $article->id = $article->id_post; if (file_exists(_PS_ROOT_DIR_.'/img/cms_post/'.$article->id_post.'/small.jpg')) { $article->have_image = true; } else { $article->have_image = false; } if ($full) { $article->products = $article->loadProductRelation(); } } if(!$array) { return $articles[0]; } return $articles; } /** * Load Product relation for display */ public function loadProductRelation() { $id_lang = Context::getContext()->language->id; $relation_product = $this->getRelations('postcms_product'); $products = array(); if(!empty($relation_product)) { $collection_product = new Collection('Product', $id_lang, Context::getContext()->shop->id); $collection_product->where('id_product', 'IN', $relation_product); $collection_product->where('active', '=', 1); $products = $collection_product->getResults(); } foreach ($products as $key => $product) { $products[$key] = $product->loadReductionInfo(); } return $products; } /** * Load PostCms relation for display */ public function loadPostCmsRelation($limit) { $id_lang = Context::getContext()->language->id; $relation_post = $this->getRelations('postcms'); $articles = array(); if(!empty($relation_post)) { $collection_product = new Collection('CmsPsPost', $id_lang); $collection_product->where('id_post', 'IN', $relation_post); $collection_product->where('active', '=', 1); $collection_product->setPageSize($limit); $articles = $collection_product->getResults(); } return $articles; } public function isNew() { $date = new DateTime(); $date->modify('-15 days'); $date_post = new DateTime($this->date_add); if ($date_post > $date) { return TRUE; } else { return FALSE; } } public function deleteRelations($type_relation, $id_group = NULL) { if(empty($type_relation)) { return FALSE; } if ($type_relation == 'cms_extrafields_'.$id_group) { if (!Validate::IsInt($id_group)) return false; return (bool) Db::getInstance()->delete('cmsps_posts_relation_extrafields', 'id_post = '. $this->id . ' and id_group = '.(int)$id_group); } elseif ($type_relation == 'postcms') { return (bool) Db::getInstance()->delete('cmsps_posts_relation', 'id_post = '. $this->id); } elseif ($type_relation == 'postcms_product') { return (bool) Db::getInstance()->delete('cmsps_posts_relation_product', 'id_post = '. $this->id); } elseif ($type_relation == 'postcms_pack') { return (bool) Db::getInstance()->delete('cmsps_posts_relation_pack', 'id_post = '. $this->id); } } public function addRelation($id_relation, $type_relation, $id_group = NULL) { if(empty($type_relation)) { return FALSE; } if ($type_relation == 'postcms') { return Db::getInstance()->execute(' INSERT INTO `'._DB_PREFIX_.'cmsps_posts_relation` VALUES ( '.(int)$this->id.', '.(int)$id_relation.' ) '); } elseif ($type_relation == 'postcms_product') { return Db::getInstance()->execute(' INSERT INTO `'._DB_PREFIX_.'cmsps_posts_relation_product` VALUES ( '.(int)$this->id.', '.(int)$id_relation.' ) '); } elseif ($type_relation == 'postcms_pack') { return Db::getInstance()->execute(' INSERT INTO `'._DB_PREFIX_.'cmsps_posts_relation_pack` VALUES ( '.(int)$this->id.', '.(int)$id_relation.' ) '); } elseif ($type_relation == 'cms_extrafields_'.$id_group) { if (!Validate::IsInt($id_group)) return false; return Db::getInstance()->execute(' INSERT INTO `'._DB_PREFIX_.'cmsps_posts_relation_extrafields` VALUES ( '.(int)$this->id.', '.(int)$id_group.', '.(int)$id_relation.' ) '); } } public function getRelations($page_name = null) { if(!Validate::isLoadedObject($this)) return array(); $array_tmp = array(); if($page_name == 'postcms') { $sql = 'SELECT `id_relation` FROM '._DB_PREFIX_.'cmsps_posts_relation WHERE id_post = '.(int)$this->id.''; $infos = Db::getInstance()->executeS($sql); foreach($infos as $info) { $array_tmp[$info['id_relation']] = $info['id_relation']; } } elseif ($page_name == 'postcms_product') { $sql = 'SELECT `id_product` FROM '._DB_PREFIX_.'cmsps_posts_relation_product WHERE id_post = '.(int)$this->id.''; $infos = Db::getInstance()->executeS($sql); foreach($infos as $info) { $array_tmp[$info['id_product']] = $info['id_product']; } } elseif ($page_name == 'postcms_pack') { $sql = 'SELECT `id_pack` FROM '._DB_PREFIX_.'cmsps_posts_relation_pack WHERE id_post = '.(int)$this->id.''; $infos = Db::getInstance()->executeS($sql); foreach($infos as $info) { $array_tmp[$info['id_pack']] = $info['id_pack']; } } return $array_tmp; } public function getInfosWithValues($page_name) { $infos = $this->getRelations($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).')'; } else if ($page_name == 'postcms_product') { $sql = ' SELECT p.id_product as id, pl.name as content FROM `'._DB_PREFIX_.'product` p LEFT JOIN `'._DB_PREFIX_.'product_lang` pl ON p.`id_product` = pl.`id_product` AND pl.id_lang = '.$id_lang.' WHERE p.id_product IN ('.implode(',', $infos).')'; } else if ($page_name == 'postcms_pack') { $sql = ' SELECT p.id_pack as id, p.title as content FROM `'._DB_PREFIX_.'cms_pack` p WHERE p.id_pack IN ('.implode(',', $infos).')'; } $res = Db::getInstance()->executeS($sql); return $res; } // EXTRAFIELDS CMS public function getRelationsExtra($id_group) { $array_tmp = array(); $sql = 'SELECT `id_value` FROM '._DB_PREFIX_.'cmsps_posts_relation_extrafields WHERE id_post = '.(int)$this->id.' AND id_group = '.(int)$id_group; $infos = Db::getInstance()->executeS($sql); foreach($infos as $info) { $array_tmp[$info['id_value']] = $info['id_value']; } return $array_tmp; } public function getInfosWithValuesExtra($page_name) { $id_group = str_replace('cms_extrafields_', '', $page_name); if(!Validate::isInt($id_group)) return array(); $infos = $this->getRelationsExtra($id_group); if ($infos) { return Db::getInstance()->executeS(' SELECT p.id_cmsps_extrafields_value as id, p.value as content FROM `'._DB_PREFIX_.'cmsps_extrafields_value_lang` p WHERE p.id_cmsps_extrafields_value IN ('.implode(',', $infos).')' ); } else { return array(); } } public static function search($query, $limit, $id_lang) { $keywords = explode(' ', $query); $result = array(); $query_posts = ' SELECT p.`id_post` FROM `'._DB_PREFIX_.'cmsps_posts` p LEFT JOIN `'._DB_PREFIX_.'cmsps_posts_lang` pl ON(p.`id_post` = pl.`id_post`) WHERE p.`active` = 1 '; foreach ($keywords as $key => $keyword) { $query_posts.= 'AND ( pl.`title` LIKE "%'.pSql($keyword).'%" )'; } $query_posts.= ' ORDER BY p.`note` DESC LIMIT '.(int)$limit ; $ids_title = Db::getInstance()->executeS($query_posts); $ids_exclude = array_map(function($elem) { return $elem['id_post']; }, $ids_title); $query_posts_content = ' SELECT p.`id_post` FROM `'._DB_PREFIX_.'cmsps_posts` p LEFT JOIN `'._DB_PREFIX_.'cmsps_posts_lang` pl ON(p.`id_post` = pl.`id_post`) WHERE p.`active` = 1 '; $query_posts_content .= ' AND p.`id_post` NOT IN ("'.implode(',', $ids_exclude).'")'; foreach ($keywords as $key => $keyword) { $query_posts_content.= 'AND ( pl.`content` LIKE "%'.pSql($keyword).'%" )'; } $query_posts_content.= ' ORDER BY p.`note` DESC LIMIT '.(int)$limit ; $ids_content = Db::getInstance()->executeS($query_posts_content); $ids = array_merge($ids_title, $ids_content); if ($ids) { foreach ($ids as $key => $id) { $result[] = new CmsPsPost($id['id_post'], $id_lang); } } if ($result) return self::injectsData($result); return $result; } public static function specificSearch($tags, $id_lang, $id_category = 1, $limit = 1) { $result = false; $query_posts = ' SELECT p.`id_post` FROM `'._DB_PREFIX_.'cmsps_posts` p LEFT JOIN `'._DB_PREFIX_.'cmsps_posts_lang` pl ON(p.`id_post` = pl.`id_post`) WHERE p.`active` = 1 AND p.`id_category`='.(int)$id_category; foreach ($tags as $key => $value) { $query_posts .= ' AND p.`id_post` IN ( SELECT prx.`id_post` FROM `'._DB_PREFIX_.'cmsps_posts_relation_extrafields` prx WHERE prx.`id_value` = '.(int)$value.')'; } $query_posts .= ' GROUP BY p.`id_post` ORDER BY p.`note` DESC LIMIT '.(int)$limit; $bestPost = Db::getInstance()->executeS($query_posts); if ($bestPost) { $result = new CmsPsPost($bestPost[0]['id_post'], $id_lang); } if ($result) return self::injectsData($result); return $result; } public static function getPostRelationWithProduct($id_product, $limit = 3, $id_lang) { $relations = array(); $ids = Db::getInstance()->executeS(' SELECT r.`id_post` FROM `'._DB_PREFIX_.'cmsps_posts_relation_product` r LEFT JOIN `'._DB_PREFIX_.'cmsps_posts` c ON(r.`id_post` = c.`id_post`) WHERE r.`id_product` ='.(int)$id_product.' ORDER BY c.`note` DESC LIMIT '.(int)$limit ); foreach ($ids as $key => $id) { $relations[] = new CmsPsPost($id['id_post'], $id_lang); } return self::injectsData($relations); } }