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