* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 8005 $ * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0) * International Registered Trademark & Property of PrestaShop SA */ if (!defined('_PS_VERSION_')) exit; class LoyaltyModule extends ObjectModel { public $id_loyalty_state; public $id_customer; public $id_order; public $id_discount; public $discount_value; public $date_add; public $date_upd; protected $fieldsRequired = array('id_customer', 'discount_value'); protected $fieldsValidate = array('id_loyalty_state' => 'isInt', 'id_customer' => 'isInt', 'id_discount' => 'isInt', 'id_order' => 'isInt', 'discount_value' => 'isFloat'); protected $table = 'loyalty'; protected $identifier = 'id_loyalty'; public function getFields() { parent::validateFields(); $fields['id_loyalty_state'] = (int)$this->id_loyalty_state; $fields['id_customer'] = (int)$this->id_customer; $fields['id_order'] = (int)$this->id_order; $fields['id_discount'] = (int)$this->id_discount; $fields['discount_value'] = (float)$this->discount_value; $fields['date_add'] = pSQL($this->date_add); $fields['date_upd'] = pSQL($this->date_upd); return $fields; } public function save($nullValues = false, $autodate = true) { parent::save($nullValues, $autodate); $this->historize(); } public static function getByOrderId($id_order) { if (!Validate::isUnsignedId($id_order)) return false; $result = Db::getInstance()->getRow(' SELECT f.id_loyalty FROM `'._DB_PREFIX_.'loyalty` f WHERE f.id_order = '.(int)($id_order)); return isset($result['id_loyalty']) ? $result['id_loyalty'] : false; } public static function getOrderDiscountValue($order) { if (!Validate::isLoadedObject($order)) return false; return self::getCartDiscountValue(new Cart((int)$order->id_cart)); } public static function getCartDiscountValue($cart, $newProduct = NULL) { $total = 0; if (Validate::isLoadedObject($cart)) { $cartProducts = $cart->getProducts(); $taxesEnabled = Product::getTaxCalculationMethod(); if (isset($newProduct) AND !empty($newProduct)) { $cartProductsNew['id_product'] = (int)$newProduct->id; if ($taxesEnabled == PS_TAX_EXC) $cartProductsNew['price'] = number_format($newProduct->getPrice(false, (int)($newProduct->getIdProductAttributeMostExpensive())), 2, '.', ''); else $cartProductsNew['price_wt'] = number_format($newProduct->getPrice(true, (int)($newProduct->getIdProductAttributeMostExpensive())), 2, '.', ''); $cartProductsNew['cart_quantity'] = 1; $cartProducts[] = $cartProductsNew; } foreach ($cartProducts AS $product) { if (!(int)(Configuration::get('PS_LOYALTY_NONE_AWARD')) AND Product::isDiscounted((int)$product['id_product'])) { global $smarty; if (isset($smarty) AND is_object($newProduct) AND $product['id_product'] == $newProduct->id) $smarty->assign('no_pts_discounted', 1); continue; } $total += ($taxesEnabled == PS_TAX_EXC ? $product['price'] : $product['price_wt'])* (int)($product['cart_quantity']); } foreach ($cart->getDiscounts(false) AS $discount) $total -= $discount['value_real']; } return self::getDiscountValueByPrice($total); } /*public static function getVoucherValue($nbPoints, $id_currency = NULL) { global $cookie; if (empty($id_currency)) $id_currency = (int)$cookie->id_currency; return (int)$nbPoints * (float)Tools::convertPrice(Configuration::get('PS_LOYALTY_POINT_VALUE'), new Currency((int)$id_currency)); }*/ public static function getVoucherValueByPercentOfOrder($orders, $id_currency = NULL) { global $cookie; if (empty($id_currency)) $id_currency = (int)$cookie->id_currency; $value = 0; if ($orders && !empty($orders)) { foreach ($orders as $key => $order) { $value += $order['discount_value']; } } return (float)Tools::convertPrice($value, new Currency((int)$id_currency)); } public static function getDiscountValueByPrice($price) { global $cookie; if (Configuration::get('PS_CURRENCY_DEFAULT') != $cookie->id_currency) { $currency = new Currency((int)($cookie->id_currency)); if ($currency->conversion_rate) $price = $price / $currency->conversion_rate; } $discount_value = (float)(((float)Configuration::get('PS_LOYALTY_PERCENT_VALUE') * $price) / 100); return $discount_value; } /*public static function getPointsByCustomer($id_customer) { return Db::getInstance()->getValue(' SELECT SUM(f.points) points FROM `'._DB_PREFIX_.'loyalty` f WHERE f.id_customer = '.(int)($id_customer).' AND f.id_loyalty_state IN ('.(int)(LoyaltyStateModule::getValidationId()).', '.(int)(LoyaltyStateModule::getNoneAwardId()).')') + Db::getInstance()->getValue(' SELECT SUM(f.points) points FROM `'._DB_PREFIX_.'loyalty` f WHERE f.id_customer = '.(int)($id_customer).' AND f.id_loyalty_state = '.(int)LoyaltyStateModule::getCancelId().' AND points < 0'); }*/ public static function getAllByIdCustomer($id_customer, $id_lang, $onlyValidate = false, $pagination = false, $nb = 10, $page = 1) { $query = ' SELECT f.id_order AS id, f.date_add AS date, (o.total_paid - o.total_shipping) total_without_shipping, f.discount_value, f.id_loyalty, f.id_loyalty_state, fsl.name state FROM `'._DB_PREFIX_.'loyalty` f LEFT JOIN `'._DB_PREFIX_.'orders` o ON (f.id_order = o.id_order) LEFT JOIN `'._DB_PREFIX_.'loyalty_state_lang` fsl ON (f.id_loyalty_state = fsl.id_loyalty_state AND fsl.id_lang = '.(int)($id_lang).') WHERE f.id_customer = '.(int)($id_customer); if ($onlyValidate === true) $query .= ' AND f.id_loyalty_state = '.(int)LoyaltyStateModule::getValidationId(); $query .= ' GROUP BY f.id_loyalty '. ($pagination ? 'LIMIT '.(((int)($page) - 1) * (int)($nb)).', '.(int)($nb) : ''); return Db::getInstance()->ExecuteS($query); } public static function getNbOrdersByIdCustomer($id_customer, $notCancel = true) { $query = ' SELECT COUNT(f.`id_loyalty`) FROM `'._DB_PREFIX_.'loyalty` f -- LEFT JOIN `'._DB_PREFIX_.'orders` o ON (f.id_order = o.id_order) WHERE f.`id_customer` = '.(int)($id_customer); if ($notCancel === true) $query .= ' AND f.id_loyalty_state != '.(int)LoyaltyStateModule::getCancelId(); return Db::getInstance()->getValue($query); } public static function getAllByIdCustomerCustom($id_customer, $id_lang, $onlyValidate = false, $pagination = false, $nb = 10, $page = 1, $onlyDefault = false) { $percent = (float)(Configuration::get('PS_LOYALTY_PERCENT_VALUE') / 100); $query = ' SELECT f.id_order AS id, f.date_add AS date, (o.total_paid - o.total_shipping) total_without_shipping, (('.(float)$percent.' * (o.total_paid - o.total_shipping))) as reduc_value, f.discount_value, f.id_loyalty, f.id_loyalty_state, fsl.name state FROM `'._DB_PREFIX_.'loyalty` f LEFT JOIN `'._DB_PREFIX_.'orders` o ON (f.id_order = o.id_order) LEFT JOIN `'._DB_PREFIX_.'loyalty_state_lang` fsl ON (f.id_loyalty_state = fsl.id_loyalty_state AND fsl.id_lang = '.(int)($id_lang).') WHERE f.id_customer = '.(int)($id_customer).' '.(($onlyValidate)?'':' AND f.id_loyalty_state != '.(int)LoyaltyStateModule::getCancelId()); if ($onlyValidate) { $query .= ' AND (f.id_loyalty_state = '.(int)LoyaltyStateModule::getCancelId().' OR f.id_loyalty_state = '.(int)LoyaltyStateModule::getValidationId().')'; } elseif ($onlyDefault){ $query .= ' AND f.id_loyalty_state = '.(int)LoyaltyStateModule::getDefaultId(); } $query .= ' GROUP BY f.id_loyalty '. ($pagination ? 'LIMIT '.(((int)($page) - 1) * (int)($nb)).', '.(int)($nb) : ''); return Db::getInstance()->ExecuteS($query); } public static function getDiscountByIdCustomer($id_customer, $last=false) { $query = ' SELECT f.id_discount AS id_discount, f.date_upd AS date_add FROM `'._DB_PREFIX_.'loyalty` f LEFT JOIN `'._DB_PREFIX_.'orders` o ON (f.`id_order` = o.`id_order`) WHERE f.`id_customer` = '.(int)($id_customer).' AND f.`id_discount` > 0 AND o.`valid` = 1'; if ($last === true) $query.= ' ORDER BY f.id_loyalty DESC LIMIT 0,1'; $query.= ' GROUP BY f.id_discount'; return Db::getInstance()->ExecuteS($query); } public static function registerDiscountCustom($discount, $orders) { if (!Validate::isLoadedObject($discount)) die(Tools::displayError('Incorrect object Discount.')); foreach ($orders AS $item) { $f = new LoyaltyModule((int)$item['id_loyalty']); if ($f->discount_value == 0) { continue; } $f->id_discount = (int)$discount->id; $f->discount_value = $f->discount_value; $f->id_loyalty_state = (int)LoyaltyStateModule::getConvertId(); $f->save(); } } /*public static function getOrdersByIdDiscount($id_discount) { $items = Db::getInstance()->ExecuteS(' SELECT f.id_order AS id_order, f.points AS points, f.date_upd AS date FROM `'._DB_PREFIX_.'loyalty` f WHERE f.id_discount = '.(int)($id_discount).' AND f.id_loyalty_state = '.(int)(LoyaltyStateModule::getConvertId())); if (!empty($items) AND is_array($items)) { foreach ($items AS $key => $item) { $order = new Order((int)$item['id_order']); $items[$key]['id_currency'] = (int)$order->id_currency; $items[$key]['id_lang'] = (int)$order->id_lang; $items[$key]['total_paid'] = $order->total_paid; $items[$key]['total_shipping'] = $order->total_shipping; } return $items; } return false; }*/ public static function getOrdersByIdDiscountCustom($id_discount) { $items = Db::getInstance()->ExecuteS(' SELECT f.id_order AS id_order, f.discount_value, f.date_upd AS date FROM `'._DB_PREFIX_.'loyalty` f WHERE f.id_discount = '.(int)($id_discount).' AND f.id_loyalty_state = '.(int)(LoyaltyStateModule::getConvertId()) ); if (!empty($items) AND is_array($items)) { foreach ($items AS $key => $item) { $order = new Order((int)$item['id_order']); $items[$key]['id_currency'] = (int)$order->id_currency; $items[$key]['id_lang'] = (int)$order->id_lang; $items[$key]['total_paid'] = $order->total_paid; $items[$key]['total_shipping'] = $order->total_shipping; $items[$key]['discount_value'] = $item['discount_value']; } return $items; } return false; } /* Register all transaction in a specific history table */ private function historize() { Db::getInstance()->Execute(' INSERT INTO `'._DB_PREFIX_.'loyalty_history` (`id_loyalty`, `id_loyalty_state`, `discount_value`, `date_add`) VALUES ('.(int)($this->id).', '.(int)($this->id_loyalty_state).', '.(float)($this->discount_value).', NOW())'); } }