* @copyright 2007-2013 PrestaShop SA * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ class SceneCore extends ObjectModel { /** @var string Name */ public $name; /** @var boolean Active Scene */ public $active = true; /** @var array Zone for image map */ public $zones = array(); /** @var array list of category where this scene is available */ public $categories = array(); /** @var array Products */ public $products; /** * @see ObjectModel::$definition */ public static $definition = array( 'table' => 'scene', 'primary' => 'id_scene', 'multilang' => true, 'fields' => array( 'active' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool', 'required' => true), // Lang fields 'name' => array('type' => self::TYPE_STRING, 'lang' => true, 'validate' => 'isGenericName', 'required' => true, 'size' => 100), ), ); protected static $feature_active = null; public function __construct($id = null, $id_lang = null, $lite_result = true, $hide_scene_position = false) { parent::__construct($id, $id_lang); if (!$lite_result) $this->products = $this->getProducts(true, (int)$id_lang, false); if ($hide_scene_position) $this->name = Scene::hideScenePosition($this->name); $this->image_dir = _PS_SCENE_IMG_DIR_; } public function update($null_values = false) { if (!$this->updateZoneProducts()) return false; if (!$this->updateCategories()) return false; if (parent::update($null_values)) { // Refresh cache of feature detachable Configuration::updateGlobalValue('PS_SCENE_FEATURE_ACTIVE', Scene::isCurrentlyUsed($this->def['table'], true)); return true; } return false; } public function add($autodate = true, $null_values = false) { if (!empty($this->zones)) $this->addZoneProducts($this->zones); if (!empty($this->categories)) $this->addCategories($this->categories); if (parent::add($autodate, $null_values)) { // Put cache of feature detachable only if this new scene is active else we keep the old value if ($this->active) Configuration::updateGlobalValue('PS_SCENE_FEATURE_ACTIVE', '1'); return true; } return false; } public function delete() { $this->deleteZoneProducts(); $this->deleteCategories(); if (parent::delete()) { return $this->deleteImage() && Configuration::updateGlobalValue('PS_SCENE_FEATURE_ACTIVE', Scene::isCurrentlyUsed($this->def['table'], true)); } return false; } public function deleteImage($force_delete = false) { // Hack to prevent the main scene image from being deleted in AdminController::uploadImage() when a thumb image is uploaded if (isset($_FILES['thumb']) && (!isset($_FILES['image']) || empty($_FILES['image']['name']))) return true; if (parent::deleteImage()) { if (file_exists($this->image_dir.'thumbs/'.$this->id.'-thumb_scene.'.$this->image_format) && !unlink($this->image_dir.'thumbs/'.$this->id.'-thumb_scene.'.$this->image_format)) return false; } else return false; return true; } public function addCategories($categories) { $data = array(); foreach ($categories as $category) { $data[] = array( 'id_scene' => (int)$this->id, 'id_category' => (int)$category, ); } return Db::getInstance()->insert('scene_category', $data); } public function deleteCategories() { return Db::getInstance()->execute(' DELETE FROM `'._DB_PREFIX_.'scene_category` WHERE `id_scene` = '.(int)$this->id); } public function updateCategories() { if (!$this->deleteCategories()) return false; if (!empty($this->categories) && !$this->addCategories($this->categories)) return false; return true; } public function addZoneProducts($zones) { $data = array(); foreach ($zones as $zone) { $data[] = array( 'id_scene' => (int)$this->id, 'id_product' => (int)$zone['id_product'], 'x_axis' => (int)$zone['x1'], 'y_axis' => (int)$zone['y1'], 'zone_width' => (int)$zone['width'], 'zone_height' => (int)$zone['height'], ); } return Db::getInstance()->insert('scene_products', $data); } public function deleteZoneProducts() { return Db::getInstance()->execute(' DELETE FROM `'._DB_PREFIX_.'scene_products` WHERE `id_scene` = '.(int)$this->id); } public function updateZoneProducts() { if (!$this->deleteZoneProducts()) return false; if ($this->zones && !$this->addZoneProducts($this->zones)) return false; return true; } /** * Get all scenes of a category * * @return array Products */ public static function getScenes($id_category, $id_lang = null, $only_active = true, $lite_result = true, $hide_scene_position = true, Context $context = null) { if (!Scene::isFeatureActive()) return array(); if (!$context) $context = Context::getContext(); $id_lang = is_null($id_lang) ? $context->language->id : $id_lang; $sql = 'SELECT s.* FROM `'._DB_PREFIX_.'scene_category` sc LEFT JOIN `'._DB_PREFIX_.'scene` s ON (sc.id_scene = s.id_scene) '.Shop::addSqlAssociation('scene', 's').' LEFT JOIN `'._DB_PREFIX_.'scene_lang` sl ON (sl.id_scene = s.id_scene) WHERE sc.id_category = '.(int)$id_category.' AND sl.id_lang = '.(int)$id_lang .($only_active ? ' AND s.active = 1' : '').' ORDER BY sl.name ASC'; $scenes = Db::getInstance(_PS_USE_SQL_SLAVE_)->executeS($sql); if (!$lite_result && $scenes) foreach ($scenes as &$scene) $scene = new Scene($scene['id_scene'], $id_lang, false, $hide_scene_position); return $scenes; } /** * Get all products of this scene * * @return array Products */ public function getProducts($only_active = true, $id_lang = null, $lite_result = true, Context $context = null) { if (!Scene::isFeatureActive()) return array(); if (!$context) $context = Context::getContext(); $id_lang = is_null($id_lang) ? $context->language->id : $id_lang; $products = Db::getInstance()->executeS(' SELECT s.* FROM `'._DB_PREFIX_.'scene_products` s LEFT JOIN `'._DB_PREFIX_.'product` p ON (p.id_product = s.id_product) '.Shop::addSqlAssociation('product', 'p').' WHERE s.id_scene = '.(int)$this->id.($only_active ? ' AND product_shop.active = 1' : '')); if (!$lite_result && $products) foreach ($products as &$product) { $product['details'] = new Product($product['id_product'], !$lite_result, $id_lang); $product['link'] = $context->link->getProductLink( $product['details']->id, $product['details']->link_rewrite, $product['details']->category, $product['details']->ean13 ); $cover = Product::getCover($product['details']->id); if (is_array($cover)) $product = array_merge($cover, $product); } return $products; } /** * Get categories where scene is indexed * * @param integer $id_scene Scene id * @return array Categories where scene is indexed */ public static function getIndexedCategories($id_scene) { return Db::getInstance()->executeS(' SELECT `id_category` FROM `'._DB_PREFIX_.'scene_category` WHERE `id_scene` = '.(int)$id_scene); } /** * Hide scene prefix used for position * * @param string $name Scene name * @return string Name without position */ public static function hideScenePosition($name) { return preg_replace('/^[0-9]+\./', '', $name); } /** * This method is allow to know if a feature is used or active * @since 1.5.0.1 * @return bool */ public static function isFeatureActive() { return Configuration::get('PS_SCENE_FEATURE_ACTIVE'); } }