103 lines
3.0 KiB
PHP
Raw Normal View History

2015-07-29 17:53:14 +02:00
<?php
class CmsPsEdito extends ObjectModel {
public $id_edito;
public $date_add;
public $date_upd;
public $active;
public $title;
public $slug;
public $intro;
public $content;
public $meta_title;
public $meta_desc;
/**
* @see ObjectModel::$definition
*/
public static $definition = array(
'table' => 'cmsps_editos',
'primary' => 'id_edito',
'multilang' => TRUE,
'multilang_shop' => TRUE,
'fields' => array(
'active' => array('type' => self::TYPE_INT, 'validate' => 'isInt'),
// 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);
}
2015-07-30 15:08:21 +02:00
public static function getLast($id_lang) {
$collection_post = new Collection('CmsPsEdito', $id_lang);
$collection_post->where('active', '=', 1);
$collection_post->orderby('date_add', 'DESC');
$collection_post->setPageSize(1);
$edito = $collection_post->getFirst();
return $edito;
}
2015-08-20 11:47:21 +02:00
public static function getAllEditos($id_lang, $limit = 10, $num_page, $total = FALSE, $order_by = 'date_add') {
$collection_post = new Collection('CmsPsEdito', $id_lang);
$collection_post->where('active', '=', 1);
$collection_post->orderBy($order_by, 'DESC');
$collection_post->setPageSize($limit);
$collection_post->setPageNumber($num_page);
if($total) {
return $collection_post->count();
}
return $articles = $collection_post->getResults();
}
public static function search($query, $limit, $id_lang)
{
2015-10-19 16:33:26 +02:00
$keywords = explode(' ', $query);
$result = array();
$query_posts = '
SELECT p.`id_edito`
FROM `'._DB_PREFIX_.'cmsps_editos` p
LEFT JOIN `'._DB_PREFIX_.'cmsps_editos_lang` pl ON(p.`id_edito` = pl.`id_edito`)
WHERE p.`active` = 1
2015-10-19 16:33:26 +02:00
';
foreach ($keywords as $key => $keyword) {
$query_posts.= 'AND (
pl.`title` LIKE "%'.pSql($keyword).'%"
OR pl.`content` LIKE "%'.pSql($keyword).'%"
)';
}
$query_posts.= '
ORDER BY p.`date_add` DESC
LIMIT '.(int)$limit
;
$ids = Db::getInstance()->executeS($query_posts);
if ($ids) {
foreach ($ids as $key => $id) {
$result[] = new CmsPsEdito($id['id_edito'], $id_lang);
}
}
return $result;
}
2015-07-30 15:08:21 +02:00
2015-07-29 17:53:14 +02:00
}