From b87c5549fe471167882192944db3f2d6b729476c Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 15 Mar 2024 14:13:55 +0800
Subject: [PATCH] 抽奖

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |   22 ++++++++++++++++++++--
 1 files changed, 20 insertions(+), 2 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
index 7f0f76c..afa2e83 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
@@ -51,6 +51,7 @@
     private final IApiMallMemberWalletService memberWalletService;
     private final MallMoneyFlowMapper mallMoneyFlowMapper;
     private final MallMqRecordMapper mallMqRecordMapper;
+    private final MallGoodsMapper mallGoodsMapper;
 
     private final ICommonService commonService;
 
@@ -192,11 +193,28 @@
 //        if(2 != mallOrderInfo.getStatus()){
 //            return;
 //        }
+
+        BigDecimal amount = BigDecimal.ZERO;
+        List<MallOrderItem> orderItems = this.mallOrderInfoMapper.getMallOrderItemByOrderId(orderId);
+        if (CollUtil.isNotEmpty(orderItems)) {
+            for (MallOrderItem orderItem : orderItems) {
+                MallGoods mallGoods = mallGoodsMapper.selectById(orderItem.getGoodsId());
+                if (mallGoods.getIsNormal() == 2) {
+                    amount = amount.add(
+                            new BigDecimal(mallGoods.getPresentPrice())
+                                    .multiply(new BigDecimal(orderItem.getCnt()))
+                                    .abs()
+                                    .setScale(2,BigDecimal.ROUND_DOWN));
+                }
+            }
+        }
+        amount = amount.subtract(mallOrderInfo.getScoreAmount());
+        if(BigDecimal.ZERO.compareTo(amount) >= 0){
+            return;
+        }
         /**
          * 分享补贴 直推消费额10%
          */
-        BigDecimal amount = mallOrderInfo.getAmount().subtract(mallOrderInfo.getScoreAmount());
-
         Long memberId = mallOrderInfo.getMemberId();
         MallMember mallMember = memberMapper.selectById(memberId);
         //补贴对象 直属上级

--
Gitblit v1.9.1