* @copyright 2007-2014 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 ThemeCore extends ObjectModel { public $name; public $directory; public $responsive; public $default_left_column; public $default_right_column; public $product_per_page; const CACHE_FILE_CUSTOMER_THEMES_LIST = '/config/xml/customer_themes_list.xml'; const CACHE_FILE_MUST_HAVE_THEMES_LIST = '/config/xml/must_have_themes_list.xml'; /** @var int access rights of created folders (octal) */ public static $access_rights = 0775; /** * @see ObjectModel::$definition */ public static $definition = array( 'table' => 'theme', 'primary' => 'id_theme', 'fields' => array( 'name' => array('type' => self::TYPE_STRING, 'validate' => 'isGenericName', 'size' => 64, 'required' => true), 'directory' => array('type' => self::TYPE_STRING, 'validate' => 'isDirName', 'size' => 64, 'required' => true), 'responsive' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'default_left_column' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'default_right_column' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'product_per_page' => array('type' => self::TYPE_INT, 'validate' => 'isInt') ), ); public static function getThemes() { $themes = new PrestaShopCollection('Theme'); $themes->orderBy('name'); return $themes; } /** * return an array of all available theme (installed or not) * * @param boolean $installed_only * @return array string (directory) */ public static function getAvailable($installed_only = true) { static $dirlist = array(); $available_theme = array(); if (empty($dirlist)) { $themes = scandir(_PS_ALL_THEMES_DIR_); foreach ($themes as $theme) if (is_dir(_PS_ALL_THEMES_DIR_.DIRECTORY_SEPARATOR.$theme) && $theme[0] != '.') $dirlist[] = $theme; } if ($installed_only) { $themes = Theme::getThemes(); foreach ($themes as $theme_obj) $themes_dir[] = $theme_obj->directory; foreach ($dirlist as $theme) if (false !== array_search($theme, $themes_dir)) $available_theme[] = $theme; } else $available_theme = $dirlist; return $available_theme; } /** * check if a theme is used by a shop * * @return boolean */ public function isUsed() { return Db::getInstance()->getValue('SELECT count(*) FROM '._DB_PREFIX_.'shop WHERE id_theme = '.(int)$this->id); } /** * add only theme if the directory exists * * @param bool $null_values * @param bool $autodate * @return boolean Insertion result */ public function add($autodate = true, $null_values = false) { if (!is_dir(_PS_ALL_THEMES_DIR_.$this->directory)) return false; return parent::add($autodate, $null_values); } /** * @param $directory * * @return bool|Theme */ public static function getByDirectory($directory) { if (is_string($directory) && strlen($directory) > 0 && file_exists(_PS_ALL_THEMES_DIR_.$directory) && is_dir(_PS_ALL_THEMES_DIR_.$directory)) { $res = Db::getInstance()->getRow('SELECT * FROM '._DB_PREFIX_.'theme WHERE directory="'.pSQL($directory).'"'); if (!$res) return false; return new Theme($res['id_theme']); } } /** * update the table PREFIX_theme_meta for the current theme * @param array $metas * @param bool $full_update If true, all the meta of the theme will be deleted prior the insert, otherwise only the current $metas will be deleted * */ public function updateMetas($metas, $full_update = false) { if ($full_update) Db::getInstance()->delete(_DB_PREFIX_ . 'theme_meta', 'id_theme='.(int)$this->id); $values = array(); if ($this->id > 0) { foreach ($metas as $meta) { if (!$full_update) Db::getInstance()->delete(_DB_PREFIX_ . 'theme_meta', 'id_theme='.(int)$this->id.' AND id_meta='.(int)$meta['id_meta']); $values[] = array( 'id_theme' => (int)$this->id, 'id_meta' => (int)$meta['id_meta'], 'left_column' => (int)$meta['left'], 'right_column' => (int)$meta['right'] ); } Db::getInstance()->insert('theme_meta', $values); } } public function hasColumns($page) { return Db::getInstance()->getRow(' SELECT IFNULL(left_column, default_left_column) as left_column, IFNULL(right_column, default_right_column) as right_column FROM '._DB_PREFIX_.'theme t LEFT JOIN '._DB_PREFIX_.'theme_meta tm ON (t.id_theme = tm.id_theme) LEFT JOIN '._DB_PREFIX_.'meta m ON (m.id_meta = tm.id_meta) WHERE t.id_theme ='.(int)$this->id.' AND m.page = "'.pSQL($page).'"'); } public function hasLeftColumn($page = null) { return (bool)Db::getInstance()->getValue( 'SELECT IFNULL( ( SELECT left_column FROM '._DB_PREFIX_.'theme t LEFT JOIN '._DB_PREFIX_.'theme_meta tm ON ( t.id_theme = tm.id_theme ) LEFT JOIN '._DB_PREFIX_.'meta m ON ( m.id_meta = tm.id_meta ) WHERE t.id_theme ='.(int)$this->id.' AND m.page = "'.pSQL($page).'" ) , default_left_column ) FROM '._DB_PREFIX_.'theme WHERE id_theme ='.(int)$this->id ); } public function hasRightColumn($page = null) { return (bool)Db::getInstance()->getValue( 'SELECT IFNULL( ( SELECT right_column FROM '._DB_PREFIX_.'theme t LEFT JOIN '._DB_PREFIX_.'theme_meta tm ON ( t.id_theme = tm.id_theme ) LEFT JOIN '._DB_PREFIX_.'meta m ON ( m.id_meta = tm.id_meta ) WHERE t.id_theme ='.(int)$this->id.' AND m.page = "'.pSQL($page).'" ) , default_right_column ) FROM '._DB_PREFIX_.'theme WHERE id_theme ='.(int)$this->id); } /** * @return array|bool */ public function getMetas() { if (!Validate::isUnsignedId($this->id) || $this->id == 0) return false; return Db::getInstance()->executeS('SELECT * FROM '._DB_PREFIX_.'theme_meta WHERE id_theme = '.(int)$this->id); } /** * @return bool */ public function removeMetas() { if (!Validate::isUnsignedId($this->id) || $this->id == 0) return false; return Db::getInstance()->delete(_DB_PREFIX_ . 'theme_meta', 'id_theme = '.(int)$this->id); } public function toggleResponsive() { // Object must have a variable called 'responsive' if (!array_key_exists('responsive', $this)) throw new PrestaShopException('property "responsive" is missing in object '.get_class($this)); // Update only responsive field $this->setFieldsToUpdate(array('responsive' => true)); // Update active responsive on object $this->responsive = !(int)$this->responsive; // Change responsive to active/inactive return $this->update(false); } public function toggleDefaultLeftColumn() { if (!array_key_exists('default_left_column', $this)) throw new PrestaShopException('property "default_left_column" is missing in object '.get_class($this)); $this->setFieldsToUpdate(array('default_left_column' => true)); $this->default_left_column = !(int)$this->default_left_column; return $this->update(false); } public function toggleDefaultRightColumn() { if (!array_key_exists('default_right_column', $this)) throw new PrestaShopException('property "default_right_column" is missing in object '.get_class($this)); $this->setFieldsToUpdate(array('default_right_column' => true)); $this->default_right_column = !(int)$this->default_right_column; return $this->update(false); } }