From 73b874c72ad55eb9eef21c36160ac0de58f0189e Mon Sep 17 00:00:00 2001
From: quanwei <419654421@qq.com>
Date: Thu, 05 Feb 2026 10:30:43 +0800
Subject: [PATCH] 优化名片

---
 admin/app/api/service/order/settled/OrderSettledService.php |   37 ++++++++++++++++++++++++++++---------
 1 files changed, 28 insertions(+), 9 deletions(-)

diff --git a/admin/app/api/service/order/settled/OrderSettledService.php b/admin/app/api/service/order/settled/OrderSettledService.php
index d91d7ef..40cdde3 100644
--- a/admin/app/api/service/order/settled/OrderSettledService.php
+++ b/admin/app/api/service/order/settled/OrderSettledService.php
@@ -12,6 +12,7 @@
 use app\common\enum\order\OrderPayTypeEnum;
 use app\common\enum\order\OrderSourceEnum;
 use app\common\enum\order\OrderTypeEnum;
+use app\common\enum\supplier\SupplierType;
 use app\common\model\settings\Setting as SettingModel;
 use app\api\service\coupon\ProductDeductService;
 use app\common\model\store\Store as StoreModel;
@@ -146,7 +147,7 @@
                 $this->setOrderCouponMoney($couponList, $this->orderData['coupon_id'], $supplier['productList']);
             }
             // 计算可用积分抵扣
-            $this->setOrderPoints($supplier['productList']);
+            $this->setOrderPoints($supplier['productList'],$supplier['supplier']);
             $totalPointsMoney += $this->orderData['points_money'];
             $totalPoints += $this->orderData['points_num'];
             // 计算可用消费券抵扣
@@ -624,14 +625,14 @@
         // 积分兑换扣除用户积分
         if ($commomOrder['force_points']) {
             $describe = "用户积分兑换消费:{$this->model['order_no']}";
-            $this->user->setIncPoints(-$commomOrder['points_num'], $describe);
+            $this->user->setIncPoints(-$commomOrder['points_num'], $describe,0,true,($supplier['supplier']['supplier_type'] == SupplierType::GROUPBUYING?1:0));
         } else {
             // 积分抵扣情况下扣除用户积分
             if ($commomOrder['is_allow_points'] && $commomOrder['is_real_use_points'] && $commomOrder['points_num'] > 0) {
                 $describe = "用户消费:{$this->model['order_no']}";
-                $this->user->setIncPoints(-$commomOrder['points_num'], $describe);
+                $this->user->setIncPoints(-$commomOrder['points_num'], $describe,0,true,($supplier['supplier']['supplier_type'] == SupplierType::GROUPBUYING?1:0));
             }
-            // 积分抵扣情况下扣除用户积分
+            // 消费券抵扣情况下扣除用户消费券
             if ($commomOrder['is_allow_consumption'] && $commomOrder['is_real_use_consumption'] && $commomOrder['consumption_num'] > 0) {
                 $describe = "用户消费:{$this->model['order_no']}";
                 $this->user->setIncConsumption(-$commomOrder['consumption_num'], $describe);
@@ -763,6 +764,12 @@
         // 订单商品列表
         $productList = [];
         foreach ($supplier['productList'] as $product) {
+            $product_type = 0;
+            if ($product['is_brand'] == 1) {
+                $product_type = 10;
+            }else if ($supplier['supplier']['supplier_type'] == SupplierType::GROUPBUYING) {
+                $product_type = 20;
+            }
             $item = [
                 'order_id' => $status,
                 'user_id' => $this->user['user_id'],
@@ -821,6 +828,12 @@
                 'is_viewpoint_money' => $product['is_viewpoint_money'],
                 'viewpoint_money' => $product['viewpoint_money'],
                 'deduction_price' => empty($product['deduction_price']) ? 0 : $product['deduction_price'],//券商品的抵扣金额 by yj 2024.1.10
+                'product_type' => $product_type,
+                'is_activation_code' => $product['is_activation_code'],
+                'activation_code_num' => $product['product_sku']['activation_code_num'],
+                'activation_code_exchange' => $product['activation_code_exchange'],
+                'is_gift_pack' => $product['is_gift_pack'],
+                'vip_order_num' => $product['vip_order_num'],
             ];
             // 记录订单商品来源id
             $item['product_source_id'] = isset($product['product_source_id']) ? $product['product_source_id'] : 0;
@@ -840,13 +853,16 @@
     /**
      * 计算订单可用积分抵扣
      */
-    private function setOrderPoints($productList)
+    private function setOrderPoints($productList,$supplier)
     {
         $this->orderData['points_money'] = 0;
         // 积分抵扣总数量
         $this->orderData['points_num'] = 0;
         // 允许积分抵扣
         $this->orderData['is_allow_points'] = false;
+
+        // 只有团购类商品允许使用品牌积分
+        $points=$supplier['supplier_type']==SupplierType::GROUPBUYING?$this->user['points']:$this->user['points']-$this->user['brand_points'];
         // 积分商城兑换
         if (isset($this->settledRule['force_points']) && $this->settledRule['force_points']) {
             // 积分抵扣金额,商品价格-兑换金额
@@ -855,7 +871,7 @@
             $this->orderData['points_num'] = $productList[0]['points_num'];
             // 允许积分抵扣
             $this->orderData['is_allow_points'] = true;
-            if ($this->user['points'] < $productList[0]['points_num']) {
+            if ($points < $productList[0]['points_num']) {
                 $this->error = '积分不足,去多赚点积分吧!';
                 return false;
             }
@@ -876,7 +892,7 @@
         // 订单最多可抵扣的积分总数量
         $maxPointsNumCount = helper::getArrayColumnSum($productList, 'max_points_num');
         // 实际可抵扣的积分数量
-        $actualPointsNum = min($maxPointsNumCount, $this->user['points']);
+        $actualPointsNum = min($maxPointsNumCount, $points);
         if ($actualPointsNum < 1) {
             $this->orderData['points_money'] = 0;
             // 积分抵扣总数量
@@ -1156,8 +1172,11 @@
         $service = new FullDeductService;
         $completed = $service->setProductFullreduceMoney($productListTemp, $reduce['reduced_price']);
         // 分配订单商品优惠券抵扣金额
-        foreach ($productList as $key => &$product) {
-            $product['fullreduce_money'] = $completed[$key]['fullreduce_money'] / 100;
+        if ($completed){
+            // 分配订单商品优惠券抵扣金额
+            foreach ($productList as $key => &$product) {
+                $product['fullreduce_money'] = $completed[$key]['fullreduce_money'] / 100;
+            }
         }
         return true;
     }

--
Gitblit v1.9.2