From 61b9b64a416b9171af5d7fd45c6684ce8ccda731 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Mon, 19 May 2025 17:09:19 +0800 Subject: [PATCH] refactor(vip): 重构会员积分计算和流动逻辑 --- src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java | 37 ++++++++++++++++++------------------- 1 files changed, 18 insertions(+), 19 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..75c1f27 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 @@ -118,8 +118,15 @@ BigDecimal mineScore = amount.multiply(minePercent).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"); } // 计算推荐人获得的积分 if(StrUtil.isNotEmpty(member.getReferrerId())){ @@ -128,26 +135,18 @@ BigDecimal otherScore = amount.multiply(otherPercent).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"); } } } - - // 为推荐人和自己添加积分流动记录和更新钱包 - 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); -- Gitblit v1.9.1