From 5a6ff9c962c082a63f1093b2cc9c2dec7c0e26bd Mon Sep 17 00:00:00 2001 From: Michael RICOIS Date: Tue, 27 Feb 2018 17:48:02 +0100 Subject: [PATCH] Remove credit expired --- modules/loyalty/LoyaltyModule.php | 16 ++++++++++++---- modules/loyalty/loyalty-program.php | 20 +++++++++++--------- 2 files changed, 23 insertions(+), 13 deletions(-) diff --git a/modules/loyalty/LoyaltyModule.php b/modules/loyalty/LoyaltyModule.php index 43961ef1..7c9b611a 100755 --- a/modules/loyalty/LoyaltyModule.php +++ b/modules/loyalty/LoyaltyModule.php @@ -210,9 +210,12 @@ class LoyaltyModule extends ObjectModel SELECT f.`id_loyalty`,f.`id_loyalty_state`,f.`discount_value` FROM `'._DB_PREFIX_.'loyalty` f WHERE f.`id_customer` = '.(int)($id_customer); - if ($notCancel === true) + if ($notCancel === true) { $query .= ' AND f.id_loyalty_state != '.(int)LoyaltyStateModule::getCancelId(); + } + $query .= ' AND f.date_add > (NOW() - INTERVAL 1 YEAR)'; + return Db::getInstance()->ExecuteS($query); } @@ -238,11 +241,15 @@ class LoyaltyModule extends ObjectModel AND oh.`id_order_history` = (SELECT MAX(`id_order_history`) FROM `ps_order_history` moh WHERE moh.`id_order` = f.`id_order` GROUP BY moh.`id_order`) AND oh.`id_order_state` != 8 '.(($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 .= ' AND f.date_add > (NOW() - INTERVAL 1 YEAR)'; + $query .= ' GROUP BY f.id_loyalty '. ($pagination ? 'LIMIT '.(((int)($page) - 1) * (int)($nb)).', '.(int)($nb) : ''); @@ -268,10 +275,11 @@ class LoyaltyModule extends ObjectModel public static function registerDiscountCustom($discount, $orders) { - if (!Validate::isLoadedObject($discount)) + if (!Validate::isLoadedObject($discount)) { die(Tools::displayError('Incorrect object Discount.')); - foreach ($orders AS $item) - { + } + + foreach ($orders AS $item) { $f = new LoyaltyModule((int)$item['id_loyalty']); if ($f->discount_value == 0) { diff --git a/modules/loyalty/loyalty-program.php b/modules/loyalty/loyalty-program.php index 6aea1b64..ce53704d 100755 --- a/modules/loyalty/loyalty-program.php +++ b/modules/loyalty/loyalty-program.php @@ -54,7 +54,7 @@ if ($displayorders && !empty($displayorders)) { if (!empty($allOrders)) { $nb_orders = count($allOrders); foreach ($allOrders as $key => $order) { - if ((int)$order['id_loyalty_state'] !=2){ + if ((int)$order['id_loyalty_state'] != 2){ continue; } $total_discount += (float)$order['discount_value']; @@ -92,17 +92,18 @@ if (Tools::getValue('transform-points') == 'true' AND $total_discount > 0) /* If merchandise returns are allowed, the voucher musn't be usable before this max return date */ $dateFrom = Db::getInstance()->getValue(' - SELECT UNIX_TIMESTAMP(date_add) n - FROM '._DB_PREFIX_.'loyalty - WHERE id_discount = 0 AND id_customer = '.(int)$cookie->id_customer.' - ORDER BY date_add DESC'); + SELECT UNIX_TIMESTAMP(date_add) n + FROM '._DB_PREFIX_.'loyalty + WHERE id_discount = 0 AND id_customer = '.(int)$cookie->id_customer.' + ORDER BY date_add DESC + '); - if (Configuration::get('PS_ORDER_RETURN')) + if (Configuration::get('PS_ORDER_RETURN')) { $dateFrom += 60 * 60 * 24 * (int)Configuration::get('PS_ORDER_RETURN_NB_DAYS'); + } $voucher->date_from = date('Y-m-d H:i:s', $dateFrom); - $voucher->date_to = date('Y-m-d H:i:s', $dateFrom + 31536000); // + 1 year - + $voucher->date_to = date('Y-m-d H:i:s', $dateFrom + (60 * 60 * 24 * 365)); // + 1 year $voucher->minimal = (float)Configuration::get('PS_LOYALTY_MINIMAL'); $voucher->active = 1; @@ -130,7 +131,8 @@ if (Tools::getValue('transform-points') == 'true' AND $total_discount > 0) $voucher->add(); /* Register order(s) which contributed to create this voucher */ - $orderToConvert = LoyaltyModule::getAllByIdCustomerCustom((int)($cookie->id_customer), (int)($cookie->id_lang), true, false, $nb = 10, $page = 1); + $orderToConvert = LoyaltyModule::getAllByIdCustomerCustom( + (int)($cookie->id_customer), (int)($cookie->id_lang), true, false, $nb = 10, $page = 1); LoyaltyModule::registerDiscountCustom($voucher, $orderToConvert); Tools::redirect('modules/loyalty/loyalty-program.php');