* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision$ * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ /** * @since 1.5.0 */ class GroupShopCore extends ObjectModel { public $name; public $active; public $share_customer; public $share_stock; public $share_order; public $deleted; /** * @see ObjectModel::$definition */ public static $definition = array( 'table' => 'group_shop', 'primary' => 'id_group_shop', 'fields' => array( 'name' => array('type' => self::TYPE_STRING, 'validate' => 'isGenericName', 'required' => true, 'size' => 64), 'share_customer' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'share_order' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'share_stock' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'active' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), 'deleted' => array('type' => self::TYPE_BOOL, 'validate' => 'isBool'), ), ); private static $assoTables = array( 'attribute_group' => array('type' => 'group_shop'), 'attribute' => array('type' => 'group_shop'), 'feature' => array('type' => 'group_shop'), 'group' => array('type' => 'group_shop'), 'manufacturer' => array('type' => 'group_shop'), 'supplier' => array('type' => 'group_shop'), 'zone' => array('type' => 'group_shop'), 'tax_rules_group' => array('type' => 'group_shop'), ); /** * @see ObjectModel::getFields() * @return array */ public function getFields() { if (!$this->share_customer || !$this->share_stock) $this->share_order = false; return parent::getFields(); } public static function getGroupShops($active = true) { $groups = new Collection('GroupShop'); $groups->where('deleted', '=', false); if ($active) $groups->where('active', '=', true); return $groups; } public function delete() { if (!$res = parent::delete()) return false; foreach (GroupShop::getAssoTables() as $table_name => $row) { $id = 'id_'.$row['type']; if ($row['type'] == 'fk_group_shop') $id = 'id_group_shop'; else $table_name .= '_'.$row['type']; $res &= Db::getInstance()->execute('DELETE FROM `'._DB_PREFIX_.$table_name.'` WHERE `'.$id.'`='.(int)$this->id); } return $res; } public static function getAssoTables() { return self::$assoTables; } /** * @return int Total of groupshops */ public static function getTotalGroupShops($active = true) { return count(GroupShop::getGroupShops($active)); } public function haveShops() { return (bool)$this->getTotalShops(); } public function getTotalShops() { $sql = 'SELECT COUNT(*) FROM '._DB_PREFIX_.'shop s WHERE id_group_shop='.(int)$this->id; return (int)Db::getInstance()->getValue($sql); } /** * Return a group shop ID from group shop name * * @param string $name * @return int */ public static function getIdByName($name) { $sql = 'SELECT id_group_shop FROM '._DB_PREFIX_.'group_shop WHERE name = \''.pSQL($name).'\''; return (int)Db::getInstance()->getValue($sql); } /** * Return the list of group shop by id * * @param int $id * @param string $identifier * @param string $table * @return array */ public static function getGroupShopById($id, $identifier, $table) { $sql = sprintf(' SELECT `id_group_shop`, `%s` FROM `'._DB_PREFIX_.'%s_group_shop` WHERE `%s` = %d' , $identifier, $table, $identifier, $id); return Db::getInstance()->executeS($sql); } public function copyGroupShopData($old_id, $tables_import = false, $deleted = false) { foreach (GroupShop::getAssoTables() as $table_name => $row) { if ($tables_import && !isset($tables_import[$table_name])) continue; $id = 'id_'.$row['type']; if ($row['type'] == 'fk_group_shop') $id = 'id_group_shop'; else $table_name .= '_'.$row['type']; if (!$deleted) { $res = Db::getInstance()->getRow('SELECT * FROM `'._DB_PREFIX_.$table_name.'` WHERE `'.$id.'` = '.(int)$old_id); if ($res) { unset($res[$id]); if (isset($row['primary'])) unset($res[$row['primary']]); $keys = implode(', ', array_keys($res)); $sql = 'INSERT IGNORE INTO `'._DB_PREFIX_.$table_name.'` ('.$keys.', '.$id.') (SELECT '.$keys.', '.(int)$this->id.' FROM '._DB_PREFIX_.$table_name.' WHERE `'.$id.'` = '.(int)$old_id.')'; Db::getInstance()->execute($sql); } } else { //Db::getInstance()->execute('UPDATE `'._DB_PREFIX_.$table_name.'` SET WHERE `'.$id.'`='.(int)$old_id); } } } }