From ff55c5334fc35594d2f0c680c29afd309cf367a2 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 22 May 2025 10:51:36 +0800
Subject: [PATCH] feat(mall): 添加商品佣金设置并调整相关功能

---
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java |  151 ++++++++++++++++++++++++++++++--------------------
 1 files changed, 90 insertions(+), 61 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 65b4263..31a2347 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
@@ -1,10 +1,8 @@
 package cc.mrbird.febs.vip.service.impl;
 
-import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
-import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
-import cc.mrbird.febs.common.enumerates.OrderStatusEnum;
-import cc.mrbird.febs.common.enumerates.ScoreFlowTypeEnum;
+import cc.mrbird.febs.common.enumerates.*;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.mall.dto.ScoreSettingDto;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IApiMallGoodsService;
@@ -22,6 +20,7 @@
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.json.JSONUtil;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
@@ -43,6 +42,7 @@
 public class VipCommonServiceImpl implements IVipCommonService {
 
     private final MallOrderInfoMapper mallOrderInfoMapper;
+    private final MallOrderItemMapper mallOrderItemMapper;
     private final IMallVipConfigService mallVipConfigService;
     private final IMallMoneyFlowService mallMoneyFlowService;
     private final IApiMallMemberWalletService mallMemberWalletService;
@@ -54,6 +54,7 @@
     private final HappyMemberLevelMapper happyMemberLevelMapper;
     private final HappySaleLevelMapper happySaleLevelMapper;
     private final MallAchieveRecordMapper mallAchieveRecordMapper;
+    private final DataDictionaryCustomMapper  dataDictionaryCustomMapper;
     /**
      * 根据订单ID获取分数
      * 此方法处理订单得分逻辑,包括直接购买得分、会员等级得分和推荐人得分
@@ -86,19 +87,17 @@
         Long memberId = mallOrderInfo.getMemberId();
         // 根据会员ID查询会员信息
         MallMember member = mallMemberMapper.selectById(memberId);
-
-        // 记录会员购买获得的经验
-        mallMoneyFlowService.addMoneyFlow(
-                memberId,
-                amount,
-                ScoreFlowTypeEnum.BUY.getValue(),
-                mallOrderInfo.getOrderNo(),
-                FlowTypeEnum.SCORE.getValue(),
-                StrUtil.format(ScoreFlowTypeEnum.BUY.getDesc(),amount),
-                2
-        );
-        // 更新会员钱包中的分数
-        mallMemberWalletService.add(amount, memberId, "score");
+        BigDecimal scorePercent = BigDecimal.ONE;
+        DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.SCORE_SIGN_SETTING.getType(),
+                DataDictionaryEnum.SCORE_SIGN_SETTING.getCode());
+        if (dic != null) {
+            ScoreSettingDto scoreSettingDto = JSONObject.parseObject(dic.getValue(), ScoreSettingDto.class);
+            BigDecimal bigDecimal = ObjectUtil.isEmpty(scoreSettingDto.getScorePercent()) ? BigDecimal.ONE : new BigDecimal(scoreSettingDto.getScorePercent());
+            if (bigDecimal.compareTo(BigDecimal.ZERO) > 0) {
+                scorePercent = bigDecimal;
+            }
+        }
 
         // 下单自己获得积分,推荐人获得积分
         //<memberId,积分数量>的map
@@ -115,42 +114,73 @@
         if(ObjectUtil.isNotEmpty(happyMemberLevel)){
             // 计算自己获得的积分
             BigDecimal minePercent = happyMemberLevel.getMinePercent();
-            BigDecimal mineScore = amount.multiply(minePercent).setScale(0, RoundingMode.HALF_DOWN);
+            BigDecimal mineScore = amount.multiply(minePercent).multiply(scorePercent).setScale(0, RoundingMode.HALF_DOWN);
             log.info("下单获得积分:{}", mineScore);
             if(mineScore.compareTo(BigDecimal.ZERO) > 0){
-                recommendScoreMap.put(memberId, mineScore);
-                recommendTypeScoreMap.put(memberId, ScoreFlowTypeEnum.MINE_RECOMMEND.getValue());
+                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");
+
+                // 记录会员购买获得的经验
+                BigDecimal multiply = amount.multiply(minePercent).setScale(2, RoundingMode.HALF_DOWN);
+                mallMoneyFlowService.addMoneyFlow(
+                        memberId,
+                        multiply,
+                        ScoreFlowTypeEnum.BUY.getValue(),
+                        mallOrderInfo.getOrderNo(),
+                        FlowTypeEnum.SCORE.getValue(),
+                        StrUtil.format(ScoreFlowTypeEnum.BUY.getDesc(),multiply),
+                        2
+                );
+                // 更新会员钱包中的分数
+                mallMemberWalletService.add(multiply, memberId, "score");
+                // 发送会员等级升级消息
+                agentProducer.sendVipLevelUp(memberId);
             }
             // 计算推荐人获得的积分
             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);
+                BigDecimal otherScore = amount.multiply(otherPercent).multiply(scorePercent).setScale(0, RoundingMode.HALF_DOWN);
                 log.info("推荐人获得积分:{}", otherScore);
                 if(otherScore.compareTo(BigDecimal.ZERO) > 0){
-                    recommendScoreMap.put(refMember.getId(), otherScore);
-                    recommendTypeScoreMap.put(memberId, ScoreFlowTypeEnum.OTHER_RECOMMEND.getValue());
+                    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");
+
+                    // 记录会员购买获得的经验
+                    BigDecimal multiply = amount.multiply(otherPercent).setScale(2, RoundingMode.HALF_DOWN);
+                    mallMoneyFlowService.addMoneyFlow(
+                            refMember.getId(),
+                            multiply,
+                            ScoreFlowTypeEnum.BUY.getValue(),
+                            mallOrderInfo.getOrderNo(),
+                            FlowTypeEnum.SCORE.getValue(),
+                            StrUtil.format(ScoreFlowTypeEnum.BUY.getDesc(),multiply),
+                            2
+                    );
+                    // 更新会员钱包中的分数
+                    mallMemberWalletService.add(multiply, refMember.getId(), "score");
+                    // 发送会员等级升级消息
+                    agentProducer.sendVipLevelUp(refMember.getId());
                 }
             }
         }
 
-        // 为推荐人和自己添加积分流动记录和更新钱包
-        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);
     }
 
 
@@ -161,21 +191,10 @@
      * @param orderId 订单ID
      */
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public void levelUp(Long orderId) {
-        // 根据订单ID获取订单详细信息
-        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
-        // 如果订单信息为空,则直接返回
-        if (mallOrderInfo == null) {
-            return;
-        }
-        // 如果订单状态不是完成状态,则直接返回
-        if (mallOrderInfo.getStatus() != OrderStatusEnum.FINISH.getValue()) {
-            // 订单不是完成状态
-            return;
-        }
-
         // 根据订单中的会员ID获取会员信息
-        MallMember member = mallMemberMapper.selectById(mallOrderInfo.getMemberId());
+        MallMember member = mallMemberMapper.selectById(orderId);
         // 如果会员信息为空,则记录日志并返回
         if (member == null) {
             log.info("会员不存在");
@@ -210,14 +229,14 @@
         if(member.getDirector() == code){
             return;
         }
+        if(member.getDirector() > code){
+            return;
+        }
 
         // 更新会员的导演等级为当前会员等级代码
         member.setDirector(code);
         // 更新会员信息
         mallMemberMapper.updateById(member);
-
-        // 发送分销等级升级消息
-        agentProducer.sendSaleLevelUp(orderId);
     }
 
     /**
@@ -226,6 +245,7 @@
      * @param orderId 订单ID,用于识别和处理特定的订单
      */
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public void saleLevelUp(Long orderId) {
         // 根据订单ID获取订单详细信息
         MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
@@ -260,7 +280,7 @@
                         .eq(MallMember::getAccountStatus, MallMember.ACCOUNT_STATUS_ENABLE)
                         .eq(MallMember::getAccountType, MallMember.ACCOUNT_TYPE_NORMAL)
                         .ne(MallMember::getStoreMaster, 0)
-                .orderByAsc(MallMember::getStoreMaster)
+                .orderByDesc(MallMember::getId)
                 .last("limit 1")
         );
         // 如果没有找到符合条件的团长,则记录日志并返回
@@ -279,15 +299,24 @@
             return;
         }
         // 计算返佣金额
+        List<MallOrderItem> mallOrderItems = mallOrderItemMapper.selectList(
+                new LambdaQueryWrapper<MallOrderItem>()
+                        .eq(MallOrderItem::getOrderId, orderId)
+                        .eq(MallOrderItem::getState, 1)
+        );
+        if(CollUtil.isEmpty(mallOrderItems)){
+            return;
+        }
+        BigDecimal amount = mallOrderItems.stream().map(MallOrderItem::getLevelOnePrice).reduce(BigDecimal.ZERO, BigDecimal::add);
         BigDecimal returnPercent = happySaleLevel.getReturnPercent();
-        BigDecimal multiply = mallOrderInfo.getAmount().multiply(returnPercent).setScale(2, RoundingMode.HALF_DOWN);
+        BigDecimal multiply = amount.multiply(returnPercent).setScale(2, RoundingMode.HALF_DOWN);
         log.info("团长获得返佣:{}",multiply);
         // 如果返佣金额小于等于0,则直接返回
         if(BigDecimal.ZERO.compareTo(multiply) >=0){
             return;
         }
         // 如果返佣金额大于等于订单金额,则直接返回
-        if(multiply.compareTo(mallOrderInfo.getAmount()) >= 0){
+        if(multiply.compareTo(amount) > 0){
             return;
         }
         // 记录团长获得返佣
@@ -302,10 +331,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