From 03ee7fdc7085d97febb174e4aa8d53dd2fef490d Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Fri, 02 Feb 2024 14:18:01 +0800 Subject: [PATCH] 购物车使用优惠卷 --- src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java | 11 +++++++++-- 1 files changed, 9 insertions(+), 2 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 3f9ddf9..fa1618c 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 @@ -11,6 +11,7 @@ import cc.mrbird.febs.mall.service.IApiMallMemberWalletService; import cc.mrbird.febs.mall.service.IApiMallOrderInfoService; import cc.mrbird.febs.mall.service.IMallMoneyFlowService; +import cc.mrbird.febs.rabbit.producter.AgentProducer; import cc.mrbird.febs.vip.entity.MallVipBenefits; import cc.mrbird.febs.vip.entity.MallVipConfig; import cc.mrbird.febs.vip.mapper.MallVipConfigMapper; @@ -28,6 +29,7 @@ import java.math.BigDecimal; import java.util.Date; import java.util.List; +import java.util.stream.Collectors; @Slf4j @Service @@ -40,6 +42,7 @@ private final IApiMallMemberWalletService mallMemberWalletService; private final MallMemberMapper mallMemberMapper; private final MallVipConfigMapper mallVipConfigMapper; + private final AgentProducer agentProducer; @Override @Transactional(rollbackFor = Exception.class) @@ -59,12 +62,15 @@ name = mallVipBenefits.getName(); } + List<String> skuNames = mallOrderInfo.getItems().stream().map(MallOrderItem::getSkuName).collect(Collectors.toList()); double sum = mallOrderInfo.getItems().stream().map(MallOrderItem::getAmount).mapToDouble(BigDecimal::doubleValue).sum(); int score = multiple.multiply(BigDecimal.valueOf(sum)).intValue(); - mallMoneyFlowService.addMoneyFlow(memberId, new BigDecimal(score), ScoreFlowTypeEnum.BUY.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), name, 2); - mallMemberWalletService.add(new BigDecimal(score), memberId, "prize_score"); + 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); } @Override @@ -141,6 +147,7 @@ MallMember update = new MallMember(); update.setId(member.getId()); update.setLevel(nextLevelCode); + update.setVipLevelTime(new Date()); mallMemberMapper.updateById(update); } } -- Gitblit v1.9.1