feat: 修改订单逻辑增加订单总价和订单支付金额字段

This commit is contained in:
mkm 2024-06-11 13:43:57 +08:00
parent 0b8c373c79
commit 25ad3924a1

View File

@ -38,7 +38,8 @@ use Yansongda\Pay\Event\PayEnd;
*/
class OrderLogic extends BaseLogic
{
public static $total;
public static $total_price;
public static $pay_price;
public static $cost;
public static $profit;
public static $activity_price;
@ -58,7 +59,8 @@ class OrderLogic extends BaseLogic
return false;
}
try {
self::$total = 0;
self::$total_price = 0;
self::$pay_price = 0;
self::$cost = 0; //成本
self::$profit = 0; //利润
self::$activity_price = 0; //活动减少
@ -73,18 +75,18 @@ class OrderLogic extends BaseLogic
unset($cart_select[$k]['id']);
$cart_select[$k]['price'] = $find['price'];
$cart_select[$k]['total_price'] = bcmul($v['cart_num'], $find['price'], 2); //订单总价
if (isset($check) && $check['status'] == 1) {
//零售价*折扣率
$activity_price = bcmul($find['price'], 0.9, 2);
self::$activity_price = bcadd(self::$activity_price, bcsub($find['price'], $activity_price, 2), 2);
self::$activity_price = bcadd(self::$activity_price, bcmul(bcsub($find['price'], $activity_price, 2),$v['cart_num'], 2), 2);
$find['price'] = $activity_price;
}
//利润
$onePrice = bcsub($find['price'], $find['cost'], 2);
$cart_select[$k]['profit'] = bcmul($v['cart_num'], $onePrice, 2); //利润
$cart_select[$k]['cost'] = bcmul($v['cart_num'], $find['cost'], 2) ?? 0;
$cart_select[$k]['total'] = bcmul($v['cart_num'], $find['price'], 2); //钱
$cart_select[$k]['total_price'] = bcmul($v['cart_num'], $find['price'], 2); //钱
$cart_select[$k]['cost'] = bcmul($v['cart_num'], $find['cost'], 2) ?? 0; //成本
$cart_select[$k]['pay_price'] = bcmul($v['cart_num'], $find['price'], 2); //订单支付金额
$cart_select[$k]['product_id'] = $find['product_id'];
$cart_select[$k]['old_cart_id'] = $v['id'];
$cart_select[$k]['cart_num'] = $v['cart_num'];
@ -102,14 +104,15 @@ class OrderLogic extends BaseLogic
//理论上每笔都是拆分了
$cart_select[$k]['name'] = $find['store_name'];
$cart_select[$k]['imgs'] = $find['image'];
$cart_select[$k]['store_id'] = $params['store_id']??0;
$cart_select[$k]['store_id'] = $params['store_id'] ?? 0;
$cart_select[$k]['unit_name'] = StoreProductUnit::where(['id' => $find['unit']])->value('name');
self::$total = bcadd(self::$total, $cart_select[$k]['total'], 2);
self::$total_price = bcadd(self::$total_price, $cart_select[$k]['total_price'], 2);
self::$pay_price = bcadd(self::$pay_price, $cart_select[$k]['pay_price'], 2);
self::$cost = bcadd(self::$cost, $cart_select[$k]['cost'], 2);
self::$profit = bcadd(self::$profit, $cart_select[$k]['profit'], 2);
}
//TODO 收单打9.9折 会员按照比例打折 等级按照充值去升级
$pay_price = self::$total;
$pay_price = self::$pay_price;
// $check = StoreOrder::where('uid',\request()->userId)->count();//首单逻辑
$vipPrice = 0;
// if (isset($check) && $check['status'] == 1) {
@ -153,7 +156,7 @@ class OrderLogic extends BaseLogic
$order = [
'create_time' => time(),
'order_id' => getNewOrderId('PF'),
'total_price' => self::$total, //总价
'total_price' => self::$total_price, //总价
'cost' => self::$cost, //成本价
'profit' => self::$profit, //利润
'pay_price' => $pay_price, //后期可能有降价抵扣
@ -167,6 +170,8 @@ class OrderLogic extends BaseLogic
'activity' => '减免',
'activity_price' => self::$activity_price,
'activities' => $check['status'],
'deduction_price' => self::$activity_price
];
$order['default_delivery'] = 0;
if ($params['store_id']) {
@ -192,7 +197,6 @@ class OrderLogic extends BaseLogic
return false;
}
$_order = $orderInfo['order'];
$_order['deduction_price'] = 0;
$_order['uid'] = request()->userId;
$user = User::where('id', \request()->userId)->find();
$_order['real_name'] = $user['real_name'];
@ -212,7 +216,7 @@ class OrderLogic extends BaseLogic
$_order['user_address'] = $address['detail'];
}
}
if($params['shipping_type'] == 2){
if ($params['shipping_type'] == 2) {
$_order['status'] = 1;
}
@ -338,7 +342,7 @@ class OrderLogic extends BaseLogic
if ($find) {
$find['goods_list'] = StoreOrderCartInfo::where('oid', $find['id'])
->field('product_id,cart_num nums,store_id')->select()->each(function ($item) use($find) {
->field('product_id,cart_num nums,store_id')->select()->each(function ($item) use ($find) {
$find = StoreBranchProduct::where('product_id', $item['product_id'])->where('store_id', $find['store_id'])->find();
$item['store_name'] = $find['store_name'];
$item['image'] = $find['image'];