From d3e9f57c91ffc08e090bf8d4b8fcbf60f0d3a86f Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 19 May 2025 17:45:15 +0800
Subject: [PATCH] feat(mall): 添加会员等级当前进度相关数据

---
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java |   57 +++++++++++++++++++++++++++++++--------------------------
 1 files changed, 31 insertions(+), 26 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
index 2c20a88..1740893 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
@@ -21,6 +21,7 @@
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
+import cn.hutool.json.JSONUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
@@ -110,43 +111,47 @@
         happyMemberLevelLambdaQueryWrapper.eq(HappyMemberLevel::getCode, director);
         happyMemberLevelLambdaQueryWrapper.last("limit 1");
         HappyMemberLevel happyMemberLevel = happyMemberLevelMapper.selectOne(happyMemberLevelLambdaQueryWrapper);
+        log.info("会员等级信息:{}", JSONUtil.toJsonStr(happyMemberLevel));
         if(ObjectUtil.isNotEmpty(happyMemberLevel)){
             // 计算自己获得的积分
             BigDecimal minePercent = happyMemberLevel.getMinePercent();
             BigDecimal mineScore = amount.multiply(minePercent).setScale(0, RoundingMode.HALF_DOWN);
-            if(BigDecimal.ZERO.compareTo(mineScore) < 0){
-                recommendScoreMap.put(memberId, mineScore);
-                recommendTypeScoreMap.put(memberId, ScoreFlowTypeEnum.MINE_RECOMMEND.getValue());
+            log.info("下单获得积分:{}", mineScore);
+            if(mineScore.compareTo(BigDecimal.ZERO) > 0){
+                mallMoneyFlowService.addMoneyFlow(
+                        memberId,
+                        mineScore,
+                        ScoreFlowTypeEnum.MINE_RECOMMEND.getValue(),
+                        mallOrderInfo.getOrderNo(),
+                        FlowTypeEnum.PRIZE_SCORE.getValue(),
+                        StrUtil.format( ScoreFlowTypeEnum.MINE_RECOMMEND.getDesc(),mineScore),
+                        2);
+                mallMemberWalletService.add(mineScore,memberId , "prizeScore");
             }
             // 计算推荐人获得的积分
             if(StrUtil.isNotEmpty(member.getReferrerId())){
                 MallMember refMember = mallMemberMapper.selectInfoByInviteId(member.getReferrerId());
                 BigDecimal otherPercent = happyMemberLevel.getOtherPercent();
                 BigDecimal otherScore = amount.multiply(otherPercent).setScale(0, RoundingMode.HALF_DOWN);
-                if(BigDecimal.ZERO.compareTo(otherScore) < 0){
-                    recommendScoreMap.put(refMember.getId(), otherScore);
-                    recommendTypeScoreMap.put(memberId, ScoreFlowTypeEnum.OTHER_RECOMMEND.getValue());
+                log.info("推荐人获得积分:{}", otherScore);
+                if(otherScore.compareTo(BigDecimal.ZERO) > 0){
+                    mallMoneyFlowService.addMoneyFlow(
+                            refMember.getId(),
+                            otherScore,
+                            ScoreFlowTypeEnum.OTHER_RECOMMEND.getValue(),
+                            mallOrderInfo.getOrderNo(),
+                            FlowTypeEnum.PRIZE_SCORE.getValue(),
+                            StrUtil.format( ScoreFlowTypeEnum.OTHER_RECOMMEND.getDesc(),otherScore),
+                            2);
+                    mallMemberWalletService.add(otherScore,refMember.getId() , "prizeScore");
                 }
             }
         }
 
-        // 为推荐人和自己添加积分流动记录和更新钱包
-        recommendScoreMap.forEach((key, value) -> {
-            if (value != null) {
-                mallMoneyFlowService.addMoneyFlow(
-                        key,
-                        value,
-                        recommendTypeScoreMap.get(key),
-                        mallOrderInfo.getOrderNo(),
-                        FlowTypeEnum.PRIZE_SCORE.getValue(),
-                        StrUtil.format(ScoreFlowTypeEnum.getDescByValue(recommendTypeScoreMap.get(key)),value),
-                        2);
-                mallMemberWalletService.add(value, key, "prizeScore");
-            }
-        });
-
         // 发送会员等级升级消息
         agentProducer.sendVipLevelUp(orderId);
+        // 发送分销等级升级消息
+        agentProducer.sendSaleLevelUp(orderId);
     }
 
 
@@ -157,6 +162,7 @@
      * @param orderId 订单ID
      */
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public void levelUp(Long orderId) {
         // 根据订单ID获取订单详细信息
         MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
@@ -211,9 +217,6 @@
         member.setDirector(code);
         // 更新会员信息
         mallMemberMapper.updateById(member);
-
-        // 发送分销等级升级消息
-        agentProducer.sendSaleLevelUp(orderId);
     }
 
     /**
@@ -222,6 +225,7 @@
      * @param orderId 订单ID,用于识别和处理特定的订单
      */
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public void saleLevelUp(Long orderId) {
         // 根据订单ID获取订单详细信息
         MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
@@ -277,6 +281,7 @@
         // 计算返佣金额
         BigDecimal returnPercent = happySaleLevel.getReturnPercent();
         BigDecimal multiply = mallOrderInfo.getAmount().multiply(returnPercent).setScale(2, RoundingMode.HALF_DOWN);
+        log.info("团长获得返佣:{}",multiply);
         // 如果返佣金额小于等于0,则直接返回
         if(BigDecimal.ZERO.compareTo(multiply) >=0){
             return;
@@ -297,10 +302,10 @@
         );
         // 更新会员钱包中的余额
         mallMemberWalletService.add(multiply, storeMasterMember.getId(), "commission");
-        mallMemberWalletService.add(multiply, storeMasterMember.getId(), "total_score");
+        mallMemberWalletService.add(multiply, storeMasterMember.getId(), "totalScore");
 
         MallAchieveRecord mallAchieveRecord = new MallAchieveRecord();
-        mallAchieveRecord.setMemberId(mallOrderInfo.getMemberId());
+        mallAchieveRecord.setMemberId(storeMasterMember.getId());
         mallAchieveRecord.setAchieveTime(new Date());
         mallAchieveRecord.setAmount(mallOrderInfo.getAmount());
         mallAchieveRecord.setCostAmount(multiply);

--
Gitblit v1.9.1