* @copyright 2007-2015 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 RangePriceCore extends ObjectModel { public $id_carrier; public $delimiter1; public $delimiter2; /** * @see ObjectModel::$definition */ public static $definition = array( 'table' => 'range_price', 'primary' => 'id_range_price', 'fields' => array( 'id_carrier' => array('type' => self::TYPE_INT, 'validate' => 'isInt', 'required' => true), 'delimiter1' => array('type' => self::TYPE_FLOAT, 'validate' => 'isUnsignedFloat', 'required' => true), 'delimiter2' => array('type' => self::TYPE_FLOAT, 'validate' => 'isUnsignedFloat', 'required' => true), ), ); protected $webserviceParameters = array( 'objectsNodeName' => 'price_ranges', 'objectNodeName' => 'price_range', 'fields' => array( 'id_carrier' => array('xlink_resource' => 'carriers'), ) ); /** * Override add to create delivery value for all zones * @see classes/ObjectModelCore::add() * * @param bool $null_values * @param bool $autodate * @return bool Insertion result */ public function add($autodate = true, $null_values = false) { if (!parent::add($autodate, $null_values) || !Validate::isLoadedObject($this)) { return false; } $carrier = new Carrier((int)$this->id_carrier); $price_list = array(); foreach ($carrier->getZones() as $zone) { $price_list[] = array( 'id_range_price' => (int)$this->id, 'id_range_weight' => 0, 'id_carrier' => (int)$this->id_carrier, 'id_zone' => (int)$zone['id_zone'], 'price' => 0, ); } $carrier->addDeliveryPrice($price_list); return true; } /** * Get all available price ranges * * @return array Ranges */ public static function getRanges($id_carrier) { return Db::getInstance(_PS_USE_SQL_SLAVE_)->executeS(' SELECT * FROM `'._DB_PREFIX_.'range_price` WHERE `id_carrier` = '.(int)$id_carrier.' ORDER BY `delimiter1` ASC'); } public static function rangeExist($id_carrier, $delimiter1, $delimiter2) { return Db::getInstance(_PS_USE_SQL_SLAVE_)->getValue(' SELECT count(*) FROM `'._DB_PREFIX_.'range_price` WHERE `id_carrier` = '.(int)$id_carrier.' AND `delimiter1` = '.(float)$delimiter1.' AND `delimiter2`='.(float)$delimiter2); } public static function isOverlapping($id_carrier, $delimiter1, $delimiter2, $id_rang = null) { return Db::getInstance(_PS_USE_SQL_SLAVE_)->getValue(' SELECT count(*) FROM `'._DB_PREFIX_.'range_price` WHERE `id_carrier` = '.(int)$id_carrier.' AND ((`delimiter1` >= '.(float)$delimiter1.' AND `delimiter1` < '.(float)$delimiter2.') OR (`delimiter2` > '.(float)$delimiter1.' AND `delimiter2` < '.(float)$delimiter2.') OR ('.(float)$delimiter1.' > `delimiter1` AND '.(float)$delimiter1.' < `delimiter2`) OR ('.(float)$delimiter2.' < `delimiter1` AND '.(float)$delimiter2.' > `delimiter2`) ) '.(!is_null($id_rang) ? ' AND `id_range_price` != '.(int)$id_rang : '')); } }