From 61a8a1b57718b83b6f8ac09e817fabf09e96fdc0 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 19 May 2025 18:01:56 +0800
Subject: [PATCH] fix(member): 修正会员累计订单统计
---
src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java | 57 +++++++++++++++++++++++++++++++--------------------------
1 files changed, 31 insertions(+), 26 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 2c20a88..1740893 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
@@ -21,6 +21,7 @@
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
+import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
@@ -110,43 +111,47 @@
happyMemberLevelLambdaQueryWrapper.eq(HappyMemberLevel::getCode, director);
happyMemberLevelLambdaQueryWrapper.last("limit 1");
HappyMemberLevel happyMemberLevel = happyMemberLevelMapper.selectOne(happyMemberLevelLambdaQueryWrapper);
+ log.info("会员等级信息:{}", JSONUtil.toJsonStr(happyMemberLevel));
if(ObjectUtil.isNotEmpty(happyMemberLevel)){
// 计算自己获得的积分
BigDecimal minePercent = happyMemberLevel.getMinePercent();
BigDecimal mineScore = amount.multiply(minePercent).setScale(0, RoundingMode.HALF_DOWN);
- if(BigDecimal.ZERO.compareTo(mineScore) < 0){
- recommendScoreMap.put(memberId, mineScore);
- recommendTypeScoreMap.put(memberId, ScoreFlowTypeEnum.MINE_RECOMMEND.getValue());
+ log.info("下单获得积分:{}", mineScore);
+ if(mineScore.compareTo(BigDecimal.ZERO) > 0){
+ 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())){
MallMember refMember = mallMemberMapper.selectInfoByInviteId(member.getReferrerId());
BigDecimal otherPercent = happyMemberLevel.getOtherPercent();
BigDecimal otherScore = amount.multiply(otherPercent).setScale(0, RoundingMode.HALF_DOWN);
- if(BigDecimal.ZERO.compareTo(otherScore) < 0){
- recommendScoreMap.put(refMember.getId(), otherScore);
- recommendTypeScoreMap.put(memberId, ScoreFlowTypeEnum.OTHER_RECOMMEND.getValue());
+ log.info("推荐人获得积分:{}", otherScore);
+ if(otherScore.compareTo(BigDecimal.ZERO) > 0){
+ 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);
+ // 发送分销等级升级消息
+ agentProducer.sendSaleLevelUp(orderId);
}
@@ -157,6 +162,7 @@
* @param orderId 订单ID
*/
@Override
+ @Transactional(rollbackFor = Exception.class)
public void levelUp(Long orderId) {
// 根据订单ID获取订单详细信息
MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
@@ -211,9 +217,6 @@
member.setDirector(code);
// 更新会员信息
mallMemberMapper.updateById(member);
-
- // 发送分销等级升级消息
- agentProducer.sendSaleLevelUp(orderId);
}
/**
@@ -222,6 +225,7 @@
* @param orderId 订单ID,用于识别和处理特定的订单
*/
@Override
+ @Transactional(rollbackFor = Exception.class)
public void saleLevelUp(Long orderId) {
// 根据订单ID获取订单详细信息
MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderDetailsById(orderId);
@@ -277,6 +281,7 @@
// 计算返佣金额
BigDecimal returnPercent = happySaleLevel.getReturnPercent();
BigDecimal multiply = mallOrderInfo.getAmount().multiply(returnPercent).setScale(2, RoundingMode.HALF_DOWN);
+ log.info("团长获得返佣:{}",multiply);
// 如果返佣金额小于等于0,则直接返回
if(BigDecimal.ZERO.compareTo(multiply) >=0){
return;
@@ -297,10 +302,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