mirror of
https://gitee.com/ShopeX/OMS
synced 2026-03-23 02:45:33 +08:00
583 lines
26 KiB
PHP
583 lines
26 KiB
PHP
<?php
|
||
/**
|
||
* Copyright © ShopeX (http://www.shopex.cn). All rights reserved.
|
||
* See LICENSE file for license details.
|
||
*/
|
||
|
||
|
||
class ome_order_edit_pkg{
|
||
|
||
protected $config = array(
|
||
'app' => 'ome',
|
||
'html' => 'admin/order/edit/pkg_edit.html',
|
||
'js_count' => 'total_pkg()',
|
||
'is_add' => true,
|
||
'add_title' => '添加促销类销售物料',
|
||
'add_id' => 'add_pkg_product',
|
||
);
|
||
|
||
/**
|
||
* 获取捆绑商品类型页面配置
|
||
* @return Araay conf
|
||
*/
|
||
public function get_config(){
|
||
return $this->config;
|
||
}
|
||
|
||
/**
|
||
* 处理订单编辑时提交的数据
|
||
* @access public
|
||
* @param array $data 订单编辑的数据 //POST
|
||
*/
|
||
public function process($data){
|
||
if (!$data['pkg']) return false;
|
||
|
||
$obj = $data['pkg']['obj'];
|
||
$onum = $data['pkg']['num'];
|
||
$oprice = $data['pkg']['price'];
|
||
$obj_pmt_price = $data['pkg']['obj_pmt_price'];
|
||
$item_pmt_price = $data['pkg']['item_pmt_price'];
|
||
$num = $data['pkg']['inum'];
|
||
$price = $data['pkg']['iprice'];
|
||
$order_id = $data['order_id'];
|
||
$newPkgONum = $data['pkg']['pkgonum'];//新增PKG
|
||
$newPkgOPr = $data['pkg']['pkgopr'];
|
||
$new_obj_pmt_price = $data['pkg']['new_obj_pmt_price'];
|
||
$new_item_pmt_price = $data['pkg']['new_item_pmt_price'];
|
||
$newPkgINum = $data['pkg']['pkgnum'];
|
||
$newPkgIPr = $data['pkg']['pkgpr'];
|
||
$shop_id = $data['shop_id'];
|
||
|
||
$oOrderItm = app::get('ome')->model("order_items");
|
||
$oOrderObj = app::get('ome')->model("order_objects");
|
||
|
||
$salesMLib = kernel::single('material_sales_material');
|
||
$basicMStockFreezeLib = kernel::single('material_basic_material_stock_freeze');
|
||
|
||
$tmp_obj = array();
|
||
$new_obj = array();
|
||
|
||
$is_order_change = false;
|
||
$is_goods_modify = false;
|
||
$total = $total_pmt_goods = 0;
|
||
$branchBatchList = [];
|
||
//捆绑商品信息
|
||
if ($obj && is_array($obj))
|
||
foreach ($obj as $k =>$v){
|
||
$tmp_obj[$k] = array('obj_id'=>$k,'pmt_price'=>$obj_pmt_price[$k]);
|
||
$obj_ = $oOrderObj->dump($k);
|
||
|
||
if (!$obj_) continue;
|
||
|
||
if ($obj_['quantity'] != $onum[$k] || $obj_['price'] != $oprice[$k] || $obj_['pmt_price'] != $obj_pmt_price[$k]){
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
}
|
||
|
||
if (isset($onum[$k])){
|
||
$tmp_amount = intval($onum[$k])*$oprice[$k];
|
||
$total += $tmp_amount;
|
||
$total_pmt_goods += $obj_pmt_price[$k];
|
||
|
||
$oldbasicMInfos = $salesMLib->getBasicMBySalesMId($obj_['goods_id']);
|
||
|
||
$oldpmt_price_rate = $salesMLib->calpmtpriceByRate($obj_pmt_price[$k], $oldbasicMInfos);
|
||
|
||
if ($obj_['amount'] != $tmp_amount){
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
}
|
||
$tmp_obj[$k]['obj_id'] = $k;
|
||
$tmp_obj[$k]['goods_id'] = $obj_['goods_id'];
|
||
$tmp_obj[$k]['amount'] = $tmp_amount;
|
||
$tmp_obj[$k]['quantity'] = intval($onum[$k]);
|
||
$tmp_obj[$k]['price'] = $oprice[$k];
|
||
$tmp_obj[$k]['amount'] = $tmp_obj[$k]['quantity'] * $tmp_obj[$k]['price'];
|
||
$tmp_obj[$k]['delete'] = 'false';
|
||
$obj_num_change = intval($onum[$k])-$obj_['quantity'];
|
||
|
||
$tmp_item_sale_price = $tmp_item_pmt_price = $tmp_item_amount = 0;
|
||
foreach ($v as $n){
|
||
$quantity = 0;
|
||
$oi = $oOrderItm->dump($n);
|
||
$pmt_price = $oldpmt_price_rate[$oi['bn']] ? $oldpmt_price_rate[$oi['bn']]['rate_price'] : '0';
|
||
|
||
$tmp_item_pmt_price += $pmt_price;
|
||
//$total_pmt_goods += $pmt_price;
|
||
$quantity = intval($oi['quantity'] / $obj_['quantity'])*intval($onum[$k]);
|
||
$item_price = $price[$n]==0 ? $oi['price'] : $price[$n];
|
||
$sale_price = $quantity * $item_price - $pmt_price;
|
||
$tmp_item_sale_price += $sale_price;
|
||
$tmp_item_amount += $quantity * $item_price;
|
||
|
||
if ($oi['quantity'] != $quantity || $oi['price'] != $item_price || $oi['pmt_price'] != $pmt_price){
|
||
$t_n = $quantity - $oi['quantity'];
|
||
if ($oi['delete'] == 'true'){
|
||
|
||
$freezeData = [];
|
||
$freezeData['bm_id'] = $oi['product_id'];
|
||
$freezeData['sm_id'] = $obj_['goods_id'];
|
||
$freezeData['obj_type'] = material_basic_material_stock_freeze::__ORDER;
|
||
$freezeData['bill_type'] = 0;
|
||
$freezeData['obj_id'] = $order_id;
|
||
$freezeData['shop_id'] = $shop_id;
|
||
$freezeData['branch_id'] = 0;
|
||
$freezeData['bmsq_id'] = material_basic_material_stock_freeze::__SHARE_STORE;
|
||
$freezeData['num'] = $quantity;
|
||
$freezeData['obj_bn'] = $data['order_bn'];
|
||
|
||
$branchBatchList['+'][] = $freezeData;
|
||
}else {
|
||
if ($t_n < 0){
|
||
|
||
$branchBatchList['-'][] = [
|
||
'bm_id' => $oi['product_id'],
|
||
'sm_id' => $obj_['goods_id'],
|
||
'obj_type' => material_basic_material_stock_freeze::__ORDER,
|
||
'bill_type' => 0,
|
||
'obj_id' => $order_id,
|
||
'branch_id' => '',
|
||
'bmsq_id' => material_basic_material_stock_freeze::__SHARE_STORE,
|
||
'num' => abs($t_n),
|
||
];
|
||
}elseif ($t_n > 0){
|
||
|
||
$freezeData = [];
|
||
$freezeData['bm_id'] = $oi['product_id'];
|
||
$freezeData['sm_id'] = $obj_['goods_id'];
|
||
$freezeData['obj_type'] = material_basic_material_stock_freeze::__ORDER;
|
||
$freezeData['bill_type'] = 0;
|
||
$freezeData['obj_id'] = $order_id;
|
||
$freezeData['shop_id'] = $shop_id;
|
||
$freezeData['branch_id'] = 0;
|
||
$freezeData['bmsq_id'] = material_basic_material_stock_freeze::__SHARE_STORE;
|
||
$freezeData['num'] = abs($t_n);
|
||
$freezeData['obj_bn'] = $data['order_bn'];
|
||
|
||
$branchBatchList['+'][] = $freezeData;
|
||
}
|
||
}
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
}elseif ($oi['delete'] == 'true'){
|
||
|
||
$freezeData = [];
|
||
$freezeData['bm_id'] = $oi['product_id'];
|
||
$freezeData['sm_id'] = $obj_['goods_id'];
|
||
$freezeData['obj_type'] = material_basic_material_stock_freeze::__ORDER;
|
||
$freezeData['bill_type'] = 0;
|
||
$freezeData['obj_id'] = $order_id;
|
||
$freezeData['shop_id'] = $shop_id;
|
||
$freezeData['branch_id'] = 0;
|
||
$freezeData['bmsq_id'] = material_basic_material_stock_freeze::__SHARE_STORE;
|
||
$freezeData['num'] = $quantity;
|
||
$freezeData['obj_bn'] = $data['order_bn'];
|
||
$branchBatchList['+'][] = $freezeData;
|
||
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
}
|
||
|
||
$tmp_obj[$k]['items'][$n]['item_id'] = $n;
|
||
$tmp_obj[$k]['items'][$n]['product_id'] = $oi['product_id'];
|
||
$tmp_obj[$k]['items'][$n]['quantity'] = $quantity;
|
||
$tmp_obj[$k]['items'][$n]['price'] = $price[$n]==0?$oi['price']:$price[$n];
|
||
$tmp_obj[$k]['items'][$n]['delete'] = 'false';
|
||
$tmp_obj[$k]['items'][$n]['pmt_price'] = $pmt_price;
|
||
$tmp_obj[$k]['items'][$n]['sale_price'] = $sale_price;
|
||
|
||
}
|
||
|
||
//$tmp_obj[$k]['sale_price'] = $tmp_obj[$k]['amount'] - $obj_pmt_price[$k] - $tmp_item_pmt_price;
|
||
$tmp_obj[$k]['sale_price'] = $tmp_obj[$k]['amount'] - $obj_pmt_price[$k];
|
||
if ($obj_['sale_price'] != $tmp_obj[$k]['sale_price']){
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
}
|
||
}else {
|
||
foreach ($v as $n){
|
||
$oi = $oOrderItm->dump($n);
|
||
if ($oi['delete'] == 'false'){
|
||
|
||
$branchBatchList['-'][] = [
|
||
'bm_id' => $oi['product_id'],
|
||
'sm_id' => $obj_['goods_id'],
|
||
'obj_type' => material_basic_material_stock_freeze::__ORDER,
|
||
'bill_type' => 0,
|
||
'obj_id' => $order_id,
|
||
'branch_id' => '',
|
||
'bmsq_id' => material_basic_material_stock_freeze::__SHARE_STORE,
|
||
'num' => $oi['quantity'],
|
||
];
|
||
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
}
|
||
$tmp_obj[$k]['items'][$n]['item_id'] = $n;
|
||
$tmp_obj[$k]['items'][$n]['delete'] = 'true';
|
||
}
|
||
|
||
$tmp_obj[$k]['delete'] = 'true';
|
||
}
|
||
}
|
||
|
||
$basicMStockFreezeLib->freezeBatch($branchBatchList['+'], __CLASS__.'::'.__FUNCTION__, $err);
|
||
$basicMStockFreezeLib->unfreezeBatch($branchBatchList['-'], __CLASS__.'::'.__FUNCTION__, $err);
|
||
|
||
//新增捆绑商品
|
||
if ($newPkgONum){
|
||
$branchBatchList = [];
|
||
$is_order_change = true;
|
||
$is_goods_modify = true;
|
||
foreach ($newPkgONum as $key => $n){
|
||
if ($data['do_action'] != 2){
|
||
if ($n < 1 || $n > 499999){
|
||
trigger_error('数量必须大于1且小于499999', E_USER_ERROR);
|
||
}
|
||
}
|
||
|
||
$tmp_price = $newPkgOPr[$key];
|
||
$pmt_price = $new_obj_pmt_price[$key];
|
||
$amount = $n * $tmp_price;
|
||
$obj_number = $n;
|
||
|
||
$salesMInfo = $salesMLib->getSalesMById($shop_id,$key);
|
||
if($salesMInfo){
|
||
$basicMInfos = $salesMLib->getBasicMBySalesMId($salesMInfo['sm_id']);
|
||
if($basicMInfos){
|
||
if($salesMInfo['sales_material_type'] == 2){
|
||
$obj_sale_price = $amount - $pmt_price;
|
||
//item层关联基础物料平摊销售价
|
||
$salesMLib->calProSaleMPriceByRate($obj_sale_price, $basicMInfos);
|
||
|
||
$pmt_price_rate = $salesMLib->calpmtpriceByRate($pmt_price, $basicMInfos);
|
||
$tmp = array();
|
||
$weight = 0;
|
||
foreach($basicMInfos as $kk => $basicMInfo){
|
||
$tmp['items'][] = array(
|
||
'order_id' => $order_id,
|
||
'product_id' => $basicMInfo['bm_id'],
|
||
'bn' => $basicMInfo['material_bn'],
|
||
'name' => $basicMInfo['material_name'],
|
||
'price' => $basicMInfo['rate_price'] ? bcdiv($basicMInfo['rate_price'], $basicMInfo['number']*$obj_number, 2) : 0.00,
|
||
'amount' => $basicMInfo['rate_price'] ? $basicMInfo['rate_price'] : 0.00,
|
||
'sale_price'=> $basicMInfo['rate_price'] ? $basicMInfo['rate_price'] : 0.00,
|
||
'pmt_price'=>$pmt_price_rate[$basicMInfo['material_bn']] ? $pmt_price_rate[$basicMInfo['material_bn']]['rate_price'] : 0.00,
|
||
'quantity' => $basicMInfo['number']*$obj_number,
|
||
'sendnum' => 0,
|
||
'item_type' => 'pkg'
|
||
);
|
||
|
||
$weight += $basicMInfo['weight']*$basicMInfo['number']*$obj_number;
|
||
|
||
$freezeData = [];
|
||
$freezeData['bm_id'] = $basicMInfo['bm_id'];
|
||
$freezeData['sm_id'] = $salesMInfo['sm_id'];
|
||
$freezeData['obj_type'] = material_basic_material_stock_freeze::__ORDER;
|
||
$freezeData['bill_type'] = 0;
|
||
$freezeData['obj_id'] = $order_id;
|
||
$freezeData['shop_id'] = $shop_id;
|
||
$freezeData['branch_id'] = 0;
|
||
$freezeData['bmsq_id'] = material_basic_material_stock_freeze::__SHARE_STORE;
|
||
$freezeData['num'] = $basicMInfo['number']*$obj_number;
|
||
$freezeData['obj_bn'] = $data['order_bn'];
|
||
$branchBatchList[] = $freezeData;
|
||
}
|
||
|
||
$tmp['order_id'] = $order_id;
|
||
$tmp['obj_type'] = 'pkg';
|
||
$tmp['obj_alias'] = '促销类';
|
||
$tmp['goods_id'] = $salesMInfo['sm_id'];
|
||
$tmp['bn'] = $salesMInfo['sales_material_bn'];
|
||
$tmp['name'] = $salesMInfo['sales_material_name'];
|
||
$tmp['price'] = $tmp_price;
|
||
$tmp['quantity'] = $obj_number;
|
||
$tmp['amount'] = $amount;
|
||
$tmp['weight'] = $weight;
|
||
$tmp['pmt_price'] = $pmt_price;
|
||
$tmp['sale_price'] = $obj_sale_price;
|
||
|
||
$new_obj[] = $tmp;
|
||
$total += $tmp['amount'];
|
||
$total_pmt_goods += $pmt_price;
|
||
}
|
||
}else{
|
||
continue;
|
||
}
|
||
}else{
|
||
continue;
|
||
}
|
||
}
|
||
$basicMStockFreezeLib->freezeBatch($branchBatchList, __CLASS__.'::'.__FUNCTION__, $err);
|
||
}
|
||
|
||
$rs = array(
|
||
'oobj' => $tmp_obj,
|
||
'nobj' => $new_obj,
|
||
'total' => $total,
|
||
'is_order_change' => $is_order_change,
|
||
'is_goods_modify' => $is_goods_modify,
|
||
'total_pmt_goods' => $total_pmt_goods,
|
||
);
|
||
return $rs;
|
||
}
|
||
|
||
/**
|
||
* 判断这次提交的数据在处理完成后,是否还存在有正常的数据。
|
||
* @param array $data 订单编辑的数据 //POST
|
||
*/
|
||
public function is_null($data){
|
||
if (!$data['pkg']) return true;
|
||
$obj = $data['pkg']['obj'];
|
||
$onum = $data['pkg']['num'];
|
||
$oprice = $data['pkg']['price'];
|
||
$num = $data['pkg']['inum'];
|
||
$price = $data['pkg']['iprice'];
|
||
$newPkgONum = $data['pkg']['pkgonum'];//新增PKG
|
||
$newPkgOPr = $data['pkg']['pkgopr'];
|
||
$newPkgINum = $data['pkg']['pkgnum'];
|
||
$newPkgIPr = $data['pkg']['pkgpr'];
|
||
if ((empty($onum) && empty($newPkgONum)) || (empty($oprice) && empty($newPkgOPr))) return true;
|
||
return false;
|
||
}
|
||
|
||
/**
|
||
* 校验订单编辑时提交的数据
|
||
* @param array $data 订单编辑的数据 //POST
|
||
*/
|
||
public function valid($data){
|
||
if (!$data['pkg']) return true;
|
||
|
||
$obj = $data['pkg']['obj'];
|
||
$onum = $data['pkg']['num'];
|
||
$oprice = $data['pkg']['price'];
|
||
$obj_pmt_price = $data['pkg']['obj_pmt_price'];
|
||
$item_pmt_price = $data['pkg']['item_pmt_price'];
|
||
$new_obj_pmt_price = $data['pkg']['new_obj_pmt_price'];
|
||
$new_item_pmt_price = $data['pkg']['new_item_pmt_price'];
|
||
$num = $data['pkg']['inum'];
|
||
$price = $data['pkg']['iprice'];
|
||
$newPkgONum = $data['pkg']['pkgonum'];//新增PKG
|
||
$newPkgOPr = $data['pkg']['pkgopr'];
|
||
$newPkgINum = $data['pkg']['pkgnum'];
|
||
$newPkgIPr = $data['pkg']['pkgpr'];
|
||
|
||
//捆绑商品信息
|
||
if ($obj && is_array($obj))
|
||
foreach ($obj as $k =>$v)
|
||
{
|
||
//过滤已经删除的商品
|
||
if (!isset($onum[$k])){
|
||
continue;
|
||
}
|
||
|
||
if ($onum[$k] < 1 || $onum[$k] > 99999){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => "捆绑商品:数量必须大于1且小于99999;",
|
||
);
|
||
return $rs;
|
||
}
|
||
|
||
foreach ($v as $item_id)
|
||
{
|
||
if ($item_pmt_price[$item_id] < 0){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => '捆绑商品:优惠价格必须大于等于0,并且不能大于销售金额;',
|
||
'error_info' => array('name'=>'pkg[item_pmt_price]['.$item_id.']'),
|
||
);
|
||
return $rs;
|
||
}
|
||
}
|
||
|
||
if ($obj_pmt_price[$k] < 0){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => "捆绑商品:优惠金额必须大于等于0",
|
||
'error_info' => array('name'=>'pkg[obj_pmt_price]['.$k.']'),
|
||
);
|
||
return $rs;
|
||
}
|
||
|
||
$amount = $onum[$k] * $oprice[$k];
|
||
if ($obj_pmt_price[$k] > $amount){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => '捆绑商品:优惠价格必须大于等于0,并且不能大于销售金额;',
|
||
'error_info' => array('name'=>'goods[obj_pmt_price]['.$k.']'),
|
||
);
|
||
return $rs;
|
||
}
|
||
}
|
||
|
||
//新增捆绑商品
|
||
if ($newPkgONum){
|
||
foreach ($newPkgONum as $key => $n)
|
||
{
|
||
if ($n < 1 || $n > 99999){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => "捆绑商品:数量必须大于1且小于99999!",
|
||
);
|
||
return $rs;
|
||
}
|
||
foreach ($newPkgINum[$key] as $k => $v){
|
||
if ($v < 1 || $v > 99999){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => "捆绑商品:数量必须大于1且小于99999。",
|
||
);
|
||
return $rs;
|
||
}
|
||
}
|
||
|
||
//检查输入价格
|
||
$tempPrice = bcmul($newPkgOPr[$key], 1, 2);
|
||
if($tempPrice != $newPkgOPr[$key]){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => '捆绑商品:单价最多只能输入2位小数;',
|
||
);
|
||
return $rs;
|
||
}
|
||
|
||
$tempPrice = bcmul($new_obj_pmt_price[$key], 1, 2);
|
||
if($tempPrice != $new_obj_pmt_price[$key]){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => '捆绑商品:优惠价格最多只能输入2位小数!',
|
||
);
|
||
return $rs;
|
||
}
|
||
|
||
//检查金额
|
||
$amount = $n * $newPkgOPr[$key];
|
||
if ($new_obj_pmt_price[$key] < 0 || $new_obj_pmt_price[$key] > $amount){
|
||
$rs = array(
|
||
'flag' => false,
|
||
'msg' => '捆绑商品:优惠价格必须大于等于0,并且不能大于销售金额!',
|
||
);
|
||
return $rs;
|
||
}
|
||
}
|
||
}
|
||
|
||
return true;
|
||
}
|
||
|
||
/**
|
||
* 判断订单上商品明细是否被修改
|
||
*
|
||
* @param array $data 订单编辑的数据POST
|
||
* @return bool
|
||
*/
|
||
public function is_edit_product($data){
|
||
if (!$data['pkg']) return false;
|
||
|
||
$oOrderItm = app::get('ome')->model("order_items");
|
||
$oOrderObj = app::get('ome')->model("order_objects");
|
||
$salesMLib = kernel::single('material_sales_material');
|
||
$obj = $data['pkg']['obj'];
|
||
$onum = $data['pkg']['num'];
|
||
$oprice = $data['pkg']['price'];
|
||
$obj_pmt_price = $data['pkg']['obj_pmt_price'];
|
||
$item_pmt_price = $data['pkg']['item_pmt_price'];
|
||
|
||
$num = $data['pkg']['inum'];
|
||
$price = $data['pkg']['iprice'];
|
||
$newPkgONum = $data['pkg']['pkgonum'];//新增PKG
|
||
$order_id = $data['order_id'];
|
||
|
||
$tmp_obj = array();
|
||
$total = $total_pmt_goods = 0;
|
||
|
||
//捆绑商品信息
|
||
if ($obj && is_array($obj)){
|
||
foreach ($obj as $k =>$v){
|
||
|
||
$tmp_obj[$k] = array('obj_id'=>$k,'pmt_price'=>$obj_pmt_price[$k]);
|
||
|
||
|
||
|
||
//如果obj_id不存在,跳过
|
||
$obj_ = $oOrderObj->dump($k);
|
||
if (!$obj_) continue;
|
||
|
||
$oldbasicMInfos = $salesMLib->getBasicMBySalesMId($obj_['goods_id']);
|
||
|
||
$oldpmt_price_rate = $salesMLib->calpmtpriceByRate($obj_pmt_price[$k], $oldbasicMInfos);
|
||
|
||
|
||
//捆绑商品数量或金额有变化
|
||
if ($obj_['quantity'] != $onum[$k] || $obj_['price'] != $oprice[$k] || $obj_['pmt_price'] != $obj_pmt_price[$k]){
|
||
return true;
|
||
}
|
||
|
||
if (isset($onum[$k])){
|
||
$tmp_amount = intval($onum[$k])*$oprice[$k];
|
||
|
||
//优惠金额变化,直接返回true
|
||
if ($obj_['amount'] != $tmp_amount){
|
||
return true;
|
||
}
|
||
|
||
$tmp_obj[$k]['obj_id'] = $k;
|
||
$tmp_obj[$k]['amount'] = $tmp_amount;
|
||
$tmp_obj[$k]['quantity'] = intval($onum[$k]);
|
||
$tmp_obj[$k]['price'] = $oprice[$k];
|
||
$tmp_obj[$k]['amount'] = $tmp_obj[$k]['quantity'] * $tmp_obj[$k]['price'];
|
||
|
||
$tmp_item_sale_price = $tmp_item_pmt_price = $tmp_item_amount = 0;
|
||
foreach ($v as $n){
|
||
$quantity = 0;
|
||
$oi = $oOrderItm->dump($n);
|
||
$pmt_price = $oldpmt_price_rate[$oi['bn']] ? $oldpmt_price_rate[$oi['bn']]['rate_price'] : '0';
|
||
|
||
//$tmp_item_pmt_price += $pmt_price;
|
||
//$total_pmt_goods += $pmt_price;
|
||
|
||
$quantity = intval($oi['quantity'] / $obj_['quantity'])*intval($onum[$k]);
|
||
$item_price = $price[$n]==0 ? $oi['price'] : $price[$n];
|
||
$sale_price = $quantity * $item_price - $pmt_price;
|
||
$tmp_item_sale_price += $sale_price;
|
||
$tmp_item_amount += $quantity * $item_price;
|
||
|
||
if ($oi['quantity'] != $quantity || $oi['price'] != $item_price || $oi['pmt_price'] != $pmt_price){
|
||
return true;//数量有变化
|
||
}elseif ($oi['delete'] == 'true'){
|
||
return true;//恢复删除的商品
|
||
}
|
||
|
||
$tmp_obj[$k]['items'][$n]['item_id'] = $n;
|
||
$tmp_obj[$k]['items'][$n]['quantity'] = $quantity;
|
||
$tmp_obj[$k]['items'][$n]['price'] = $price[$n]==0?$oi['price']:$price[$n];
|
||
$tmp_obj[$k]['items'][$n]['delete'] = 'false';
|
||
$tmp_obj[$k]['items'][$n]['pmt_price'] = $pmt_price;
|
||
$tmp_obj[$k]['items'][$n]['sale_price'] = $sale_price;
|
||
}
|
||
|
||
//$tmp_obj[$k]['sale_price'] = $tmp_obj[$k]['amount'] - $obj_pmt_price[$k] - $tmp_item_pmt_price;
|
||
$tmp_obj[$k]['sale_price'] = $tmp_obj[$k]['amount'] - $obj_pmt_price[$k];
|
||
if ($obj_['sale_price'] != $tmp_obj[$k]['sale_price']){
|
||
return true;//金额有变化
|
||
}
|
||
}else {
|
||
foreach ($v as $n){
|
||
$oi = $oOrderItm->dump($n);
|
||
if ($oi['delete'] == 'false'){
|
||
return true;//删除了商品
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
//新增捆绑商品
|
||
if ($newPkgONum){
|
||
return true;
|
||
}
|
||
|
||
return false;
|
||
}
|
||
} |