From 60f2bee16b7431d6badf492df9047fb1cde520fc Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Mon, 19 Feb 2024 15:45:03 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java |   34 +++++++++++++++++++++++++---------
 1 files changed, 25 insertions(+), 9 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 b2ba6e9..be9569d 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
@@ -28,7 +28,10 @@
 
 import java.math.BigDecimal;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
+import java.util.logging.Handler;
 import java.util.stream.Collectors;
 
 @Slf4j
@@ -70,16 +73,29 @@
         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");
 
-        agentProducer.sendVipLevelUp(orderId);
-        if (StrUtil.isNotBlank(mallOrderInfo.getTakeCode())) {
-            MallMember mallMember = mallMemberMapper.selectInfoByInviteId(mallOrderInfo.getTakeCode());
-            if (mallMember == null) {
-                return;
-            }
+        Map<Long, BigDecimal> recommendScoreMap = new HashMap<>();
+        mallOrderInfo.getItems().forEach(item -> {
+            if (StrUtil.isNotBlank(item.getMemberInviteId())) {
+                MallMember mallMember = mallMemberMapper.selectInfoByInviteId(item.getMemberInviteId());
+                if (mallMember == null) {
+                    return;
+                }
 
-            mallMoneyFlowService.addMoneyFlow(mallMember.getId(), new BigDecimal(score), ScoreFlowTypeEnum.RECOMMEND.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
-            mallMemberWalletService.add(new BigDecimal(score), mallMember.getId(), "prizeScore");
-        }
+                BigDecimal recommendScore = recommendScoreMap.get(mallMember.getId());
+                if (recommendScore != null) {
+                    recommendScore = recommendScore.add(item.getAmount());
+                }
+
+                recommendScoreMap.put(mallMember.getId(), recommendScore);
+            }
+        });
+
+        recommendScoreMap.forEach((key, value) -> {
+            mallMoneyFlowService.addMoneyFlow(key, value, ScoreFlowTypeEnum.RECOMMEND.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2);
+            mallMemberWalletService.add(new BigDecimal(score), key, "prizeScore");
+        });
+
+        agentProducer.sendVipLevelUp(orderId);
     }
 
     @Override

--
Gitblit v1.9.1