206 lines
7.6 KiB
PHP
206 lines
7.6 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* 2007-2011 PrestaShop
|
||
|
*
|
||
|
* NOTICE OF LICENSE
|
||
|
*
|
||
|
* This source file is subject to the Open Software License (OSL 3.0)
|
||
|
* that is bundled with this package in the file LICENSE.txt.
|
||
|
* It is also available through the world-wide-web at this URL:
|
||
|
* http://opensource.org/licenses/osl-3.0.php
|
||
|
* If you did not receive a copy of the license and are unable to
|
||
|
* obtain it through the world-wide-web, please send an email
|
||
|
* to license@prestashop.com so we can send you a copy immediately.
|
||
|
*
|
||
|
* DISCLAIMER
|
||
|
*
|
||
|
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
||
|
* versions in the future. If you wish to customize PrestaShop for your
|
||
|
* needs please refer to http://www.prestashop.com for more information.
|
||
|
*
|
||
|
* @author PrestaShop SA <contact@prestashop.com>
|
||
|
* @copyright 2007-2011 PrestaShop SA
|
||
|
* @version Release: $Revision: 7540 $
|
||
|
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
|
||
|
* International Registered Trademark & Property of PrestaShop SA
|
||
|
*/
|
||
|
|
||
|
class OrderReturnCore extends ObjectModel
|
||
|
{
|
||
|
/** @var integer */
|
||
|
public $id;
|
||
|
|
||
|
/** @var integer */
|
||
|
public $id_customer;
|
||
|
|
||
|
/** @var integer */
|
||
|
public $id_order;
|
||
|
|
||
|
/** @var integer */
|
||
|
public $state;
|
||
|
|
||
|
/** @var string message content */
|
||
|
public $question;
|
||
|
|
||
|
/** @var string Object creation date */
|
||
|
public $date_add;
|
||
|
|
||
|
/** @var string Object last modification date */
|
||
|
public $date_upd;
|
||
|
|
||
|
protected $tables = array ('order_return');
|
||
|
|
||
|
protected $fieldsRequired = array ('id_customer', 'id_order');
|
||
|
protected $fieldsValidate = array('id_customer' => 'isUnsignedId', 'id_order' => 'isUnsignedId', 'question' => 'isMessage');
|
||
|
|
||
|
protected $table = 'order_return';
|
||
|
protected $identifier = 'id_order_return';
|
||
|
|
||
|
public function getFields()
|
||
|
{
|
||
|
parent::validateFields();
|
||
|
|
||
|
$fields['id_customer'] = pSQL($this->id_customer);
|
||
|
$fields['id_order'] = pSQL($this->id_order);
|
||
|
$fields['state'] = pSQL($this->state);
|
||
|
$fields['date_add'] = pSQL($this->date_add);
|
||
|
$fields['date_upd'] = pSQL($this->date_upd);
|
||
|
$fields['question'] = pSQL(nl2br2($this->question), true);
|
||
|
return $fields;
|
||
|
}
|
||
|
|
||
|
public function addReturnDetail($orderDetailList, $productQtyList, $customizationIds, $customizationQtyInput)
|
||
|
{
|
||
|
/* Classic product return */
|
||
|
if ($orderDetailList)
|
||
|
foreach ($orderDetailList AS $key => $orderDetail)
|
||
|
if ($qty = (int)($productQtyList[$key]))
|
||
|
Db::getInstance()->AutoExecute(_DB_PREFIX_.'order_return_detail', array('id_order_return' => (int)($this->id), 'id_order_detail' => (int)($orderDetail), 'product_quantity' => $qty, 'id_customization' => 0), 'INSERT');
|
||
|
/* Customized product return */
|
||
|
if ($customizationIds)
|
||
|
foreach ($customizationIds AS $orderDetailId => $customizations)
|
||
|
foreach ($customizations AS $customizationId)
|
||
|
if ($quantity = (int)($customizationQtyInput[(int)($customizationId)]))
|
||
|
Db::getInstance()->AutoExecute(_DB_PREFIX_.'order_return_detail', array('id_order_return' => (int)($this->id), 'id_order_detail' => (int)($orderDetailId), 'product_quantity' => $quantity, 'id_customization' => (int)($customizationId)), 'INSERT');
|
||
|
}
|
||
|
|
||
|
public function checkEnoughProduct($orderDetailList, $productQtyList, $customizationIds, $customizationQtyInput)
|
||
|
{
|
||
|
$order = new Order((int)($this->id_order));
|
||
|
if (!Validate::isLoadedObject($order))
|
||
|
die(Tools::displayError());
|
||
|
$products = $order->getProducts();
|
||
|
/* Products already returned */
|
||
|
$order_return = self::getOrdersReturn($order->id_customer, $order->id, true);
|
||
|
foreach ($order_return AS $or)
|
||
|
{
|
||
|
$order_return_products = self::getOrdersReturnProducts($or['id_order_return'], $order);
|
||
|
foreach ($order_return_products AS $key => $orp)
|
||
|
$products[$key]['product_quantity'] -= (int)($orp['product_quantity']);
|
||
|
}
|
||
|
/* Quantity check */
|
||
|
if ($orderDetailList)
|
||
|
foreach (array_keys($orderDetailList) AS $key)
|
||
|
if ($qty = (int)($productQtyList[$key]))
|
||
|
if ($products[$key]['product_quantity'] - $qty < 0)
|
||
|
return false;
|
||
|
/* Customization quantity check */
|
||
|
if ($customizationIds)
|
||
|
{
|
||
|
$orderedCustomizations = Customization::getOrderedCustomizations((int)($order->id_cart));
|
||
|
foreach ($customizationIds AS $customizations)
|
||
|
foreach ($customizations AS $customizationId)
|
||
|
{
|
||
|
$customizationId = (int)($customizationId);
|
||
|
if (!isset($orderedCustomizations[$customizationId]))
|
||
|
return false;
|
||
|
$quantity = (isset($customizationQtyInput[$customizationId]) ? (int)($customizationQtyInput[$customizationId]) : 0);
|
||
|
if ((int)($orderedCustomizations[$customizationId]['quantity']) - $quantity < 0)
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
public function countProduct()
|
||
|
{
|
||
|
if (!$data = Db::getInstance()->getRow('
|
||
|
SELECT COUNT(`id_order_return`) AS total
|
||
|
FROM `'._DB_PREFIX_.'order_return_detail`
|
||
|
WHERE `id_order_return` = '.(int)($this->id)))
|
||
|
return false;
|
||
|
return (int)($data['total']);
|
||
|
}
|
||
|
|
||
|
public static function getOrdersReturn($customer_id, $order_id = false, $no_denied = false)
|
||
|
{
|
||
|
global $cookie;
|
||
|
|
||
|
$data = Db::getInstance()->ExecuteS('
|
||
|
SELECT *
|
||
|
FROM `'._DB_PREFIX_.'order_return`
|
||
|
WHERE `id_customer` = '.(int)($customer_id).
|
||
|
($order_id ? ' AND `id_order` = '.(int)($order_id) : '').
|
||
|
($no_denied ? ' AND `state` != 4' : '').'
|
||
|
ORDER BY `date_add` DESC');
|
||
|
foreach ($data AS $k => $or)
|
||
|
{
|
||
|
$state = new OrderReturnState($or['state']);
|
||
|
$data[$k]['state_name'] = $state->name[$cookie->id_lang];
|
||
|
}
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
public static function getOrdersReturnDetail($id_order_return)
|
||
|
{
|
||
|
return Db::getInstance()->ExecuteS('
|
||
|
SELECT *
|
||
|
FROM `'._DB_PREFIX_.'order_return_detail`
|
||
|
WHERE `id_order_return` = '.(int)($id_order_return));
|
||
|
}
|
||
|
|
||
|
public static function getOrdersReturnProducts($orderReturnId, $order)
|
||
|
{
|
||
|
$productsRet = self::getOrdersReturnDetail($orderReturnId);
|
||
|
$products = $order->getProducts();
|
||
|
$tmp = array();
|
||
|
foreach ($productsRet AS $return_detail)
|
||
|
{
|
||
|
$tmp[$return_detail['id_order_detail']]['quantity'] = isset($tmp[$return_detail['id_order_detail']]['quantity']) ? $tmp[$return_detail['id_order_detail']]['quantity'] + (int)($return_detail['product_quantity']) : (int)($return_detail['product_quantity']);
|
||
|
$tmp[$return_detail['id_order_detail']]['customizations'] = (int)($return_detail['id_customization']);
|
||
|
}
|
||
|
$resTab = array();
|
||
|
foreach ($products AS $key => $product)
|
||
|
if (isset($tmp[$product['id_order_detail']]))
|
||
|
{
|
||
|
$resTab[$key] = $product;
|
||
|
$resTab[$key]['product_quantity'] = $tmp[$product['id_order_detail']]['quantity'];
|
||
|
$resTab[$key]['customizations'] = $tmp[$product['id_order_detail']]['customizations'];
|
||
|
}
|
||
|
return $resTab;
|
||
|
}
|
||
|
|
||
|
public static function getReturnedCustomizedProducts($id_order)
|
||
|
{
|
||
|
$returns = Customization::getReturnedCustomizations($id_order);
|
||
|
$order = new Order((int)($id_order));
|
||
|
if (!Validate::isLoadedObject($order))
|
||
|
die(Tools::displayError());
|
||
|
$products = $order->getProducts();
|
||
|
foreach ($returns AS &$return)
|
||
|
{
|
||
|
$return['product_id'] = (int)($products[(int)($return['id_order_detail'])]['product_id']);
|
||
|
$return['product_attribute_id'] = (int)($products[(int)($return['id_order_detail'])]['product_attribute_id']);
|
||
|
$return['name'] = $products[(int)($return['id_order_detail'])]['product_name'];
|
||
|
$return['reference'] = $products[(int)($return['id_order_detail'])]['product_reference'];
|
||
|
}
|
||
|
return $returns;
|
||
|
}
|
||
|
|
||
|
public static function deleteOrderReturnDetail($id_order_return, $id_order_detail, $id_customization = 0)
|
||
|
{
|
||
|
return Db::getInstance()->Execute('DELETE FROM `'._DB_PREFIX_.'order_return_detail` WHERE `id_order_detail` = '.(int)($id_order_detail).' AND `id_order_return` = '.(int)($id_order_return).' AND `id_customization` = '.(int)($id_customization));
|
||
|
}
|
||
|
}
|
||
|
|