From 237dc82b539966a08fca13bbedbeaafd0822aff2 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 07 May 2024 15:43:01 +0800
Subject: [PATCH] 我的团队、商品的类别

---
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java |  106 +++++++++++++++++++++++++++--------------------------
 1 files changed, 54 insertions(+), 52 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 d514a17..728157d 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
@@ -3,10 +3,8 @@
 import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.ScoreFlowTypeEnum;
-import cc.mrbird.febs.mall.entity.MallGoods;
-import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallOrderInfo;
-import cc.mrbird.febs.mall.entity.MallOrderItem;
+import cc.mrbird.febs.mall.entity.*;
+import cc.mrbird.febs.mall.mapper.MallMemberLevelMapper;
 import cc.mrbird.febs.mall.mapper.MallMemberMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
 import cc.mrbird.febs.mall.service.IApiMallGoodsService;
@@ -21,8 +19,10 @@
 import cc.mrbird.febs.vip.service.IVipCommonService;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
@@ -50,6 +50,7 @@
     private final MallVipConfigMapper mallVipConfigMapper;
     private final AgentProducer agentProducer;
     private final IApiMallGoodsService mallGoodsService;
+    private final MallMemberLevelMapper mallMemberLevelMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -58,60 +59,61 @@
         if (mallOrderInfo == null) {
             return;
         }
+        BigDecimal amount = mallOrderInfo.getAmount();
 
         Long memberId = mallOrderInfo.getMemberId();
-        MallVipBenefits mallVipBenefits = mallVipConfigService.hasVipBenefits(memberId);
-
         MallMember member = mallMemberMapper.selectById(memberId);
-        BigDecimal multiple = BigDecimal.ONE;
-        String name = "";
-        if (mallVipBenefits != null) {
-            multiple = mallVipBenefits.getScoreMultiple();
-            name = mallVipBenefits.getName();
+        /**
+         * 一级返佣
+         */
+        String referrerId = member.getReferrerId();
+        if(StrUtil.isEmpty(referrerId)){
+            return;
+        }
+        MallMember mallMemberRef = mallMemberMapper.selectInfoByInviteId(referrerId);
+        QueryWrapper<MallMemberLevel> mallMemberLevelQueryWrapper = new QueryWrapper<>();
+        mallMemberLevelQueryWrapper.eq("member_id",mallMemberRef.getId());
+        MallMemberLevel mallMemberLevelRef = mallMemberLevelMapper.selectOne(mallMemberLevelQueryWrapper);
+        if(ObjectUtil.isNotEmpty(mallMemberLevelRef)){
+            BigDecimal levelPercent = mallMemberLevelRef.getLevelPercent();
+
+            BigDecimal refAmount = amount.multiply(levelPercent.multiply(new BigDecimal(0.01))).setScale(2, BigDecimal.ROUND_DOWN);
+            mallMemberWalletService.addBalance(refAmount,mallMemberRef.getId());
+            mallMoneyFlowService.addMoneyFlow(
+                    mallMemberRef.getId(),
+                    refAmount,
+                    ScoreFlowTypeEnum.LEVEL_PERK.getValue(),
+                    mallOrderInfo.getOrderNo(),
+                    FlowTypeEnum.BALANCE.getValue(),
+                    StrUtil.format(ScoreFlowTypeEnum.LEVEL_PERK.getDesc(),mallOrderInfo.getOrderNo()),
+                    2);
         }
 
-        List<String> skuNames = mallOrderInfo.getItems().stream().map(MallOrderItem::getSkuName).collect(Collectors.toList());
-        double sum = mallOrderInfo.getItems().stream().map(MallOrderItem::getAmount).mapToDouble(BigDecimal::doubleValue).sum();
+        /**
+         * 两级返佣
+         */
+        String referrerIdRef = mallMemberRef.getReferrerId();
+        if(StrUtil.isEmpty(referrerIdRef)){
+            return;
+        }
+        MallMember mallMemberRefTwo = mallMemberMapper.selectInfoByInviteId(referrerIdRef);
+        QueryWrapper<MallMemberLevel> mallMemberLevelQueryWrapperTwo = new QueryWrapper<>();
+        mallMemberLevelQueryWrapperTwo.eq("member_id",mallMemberRefTwo.getId());
+        MallMemberLevel mallMemberLevelRefTwo = mallMemberLevelMapper.selectOne(mallMemberLevelQueryWrapperTwo);
+        if(ObjectUtil.isNotEmpty(mallMemberLevelRefTwo)){
+            BigDecimal levelPercentTwo = mallMemberLevelRefTwo.getLevelPercent();
 
-        int score = multiple.multiply(BigDecimal.valueOf(sum)).intValue();
-
-        mallMoneyFlowService.addMoneyFlow(memberId, new BigDecimal(score), ScoreFlowTypeEnum.BUY.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
-        mallMemberWalletService.add(new BigDecimal(score), memberId, "prizeScore");
-
-        List<Long> itemGoodsIds = mallOrderInfo.getItems().stream().map(MallOrderItem::getGoodsId).distinct().collect(Collectors.toList());
-        List<MallGoods> goodsList = mallGoodsService.listByIds(itemGoodsIds);
-        Map<Long, MallGoods> goodsMap = goodsList.stream().collect(Collectors.toMap(MallGoods::getId, MallGoods -> MallGoods));
-
-        Map<Long, BigDecimal> recommendScoreMap = new HashMap<>();
-        mallOrderInfo.getItems().forEach(item -> {
-            if (StrUtil.isNotBlank(item.getMemberInviteId()) && !member.getInviteId().equals(item.getMemberInviteId())) {
-                MallGoods mallGoods = goodsMap.get(item.getGoodsId());
-                if (mallGoods.getStaticMulti() == null) {
-                    return;
-                }
-
-                BigDecimal multi = mallGoods.getStaticMulti().divide(BigDecimal.valueOf(100), 2, RoundingMode.HALF_UP);
-                MallMember mallMember = mallMemberMapper.selectInfoByInviteId(item.getMemberInviteId());
-                if (mallMember == null) {
-                    return;
-                }
-
-                BigDecimal recommendScore = recommendScoreMap.get(mallMember.getId());
-                recommendScore = recommendScore == null ? BigDecimal.ZERO : recommendScore;
-                recommendScore = recommendScore.add(item.getAmount().multiply(multi));
-
-                recommendScoreMap.put(mallMember.getId(), recommendScore);
-            }
-        });
-
-        recommendScoreMap.forEach((key, value) -> {
-            if (value != null) {
-                mallMoneyFlowService.addMoneyFlow(key, value, ScoreFlowTypeEnum.RECOMMEND.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
-                mallMemberWalletService.add(value, key, "prizeScore");
-            }
-        });
-
-        agentProducer.sendVipLevelUp(orderId);
+            BigDecimal refAmountTwo = amount.multiply(levelPercentTwo.multiply(new BigDecimal(0.01))).setScale(2, BigDecimal.ROUND_DOWN);
+            mallMemberWalletService.addBalance(refAmountTwo,mallMemberRefTwo.getId());
+            mallMoneyFlowService.addMoneyFlow(
+                    mallMemberRefTwo.getId(),
+                    refAmountTwo,
+                    ScoreFlowTypeEnum.LEVEL_PERK.getValue(),
+                    mallOrderInfo.getOrderNo(),
+                    FlowTypeEnum.BALANCE.getValue(),
+                    StrUtil.format(ScoreFlowTypeEnum.LEVEL_PERK.getDesc(),mallOrderInfo.getOrderNo()),
+                    2);
+        }
     }
 
     @Override

--
Gitblit v1.9.1