From 237dc82b539966a08fca13bbedbeaafd0822aff2 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Tue, 07 May 2024 15:43:01 +0800 Subject: [PATCH] 我的团队、商品的类别 --- src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java | 106 +++++++++++++++++++++++++++-------------------------- 1 files changed, 54 insertions(+), 52 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 d514a17..728157d 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 @@ -3,10 +3,8 @@ import cc.mrbird.febs.common.enumerates.FlowTypeEnum; import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum; import cc.mrbird.febs.common.enumerates.ScoreFlowTypeEnum; -import cc.mrbird.febs.mall.entity.MallGoods; -import cc.mrbird.febs.mall.entity.MallMember; -import cc.mrbird.febs.mall.entity.MallOrderInfo; -import cc.mrbird.febs.mall.entity.MallOrderItem; +import cc.mrbird.febs.mall.entity.*; +import cc.mrbird.febs.mall.mapper.MallMemberLevelMapper; import cc.mrbird.febs.mall.mapper.MallMemberMapper; import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper; import cc.mrbird.febs.mall.service.IApiMallGoodsService; @@ -21,8 +19,10 @@ import cc.mrbird.febs.vip.service.IVipCommonService; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.date.DateUtil; +import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; @@ -50,6 +50,7 @@ private final MallVipConfigMapper mallVipConfigMapper; private final AgentProducer agentProducer; private final IApiMallGoodsService mallGoodsService; + private final MallMemberLevelMapper mallMemberLevelMapper; @Override @Transactional(rollbackFor = Exception.class) @@ -58,60 +59,61 @@ if (mallOrderInfo == null) { return; } + BigDecimal amount = mallOrderInfo.getAmount(); Long memberId = mallOrderInfo.getMemberId(); - MallVipBenefits mallVipBenefits = mallVipConfigService.hasVipBenefits(memberId); - MallMember member = mallMemberMapper.selectById(memberId); - BigDecimal multiple = BigDecimal.ONE; - String name = ""; - if (mallVipBenefits != null) { - multiple = mallVipBenefits.getScoreMultiple(); - name = mallVipBenefits.getName(); + /** + * 一级返佣 + */ + String referrerId = member.getReferrerId(); + if(StrUtil.isEmpty(referrerId)){ + return; + } + MallMember mallMemberRef = mallMemberMapper.selectInfoByInviteId(referrerId); + QueryWrapper<MallMemberLevel> mallMemberLevelQueryWrapper = new QueryWrapper<>(); + mallMemberLevelQueryWrapper.eq("member_id",mallMemberRef.getId()); + MallMemberLevel mallMemberLevelRef = mallMemberLevelMapper.selectOne(mallMemberLevelQueryWrapper); + if(ObjectUtil.isNotEmpty(mallMemberLevelRef)){ + BigDecimal levelPercent = mallMemberLevelRef.getLevelPercent(); + + BigDecimal refAmount = amount.multiply(levelPercent.multiply(new BigDecimal(0.01))).setScale(2, BigDecimal.ROUND_DOWN); + mallMemberWalletService.addBalance(refAmount,mallMemberRef.getId()); + mallMoneyFlowService.addMoneyFlow( + mallMemberRef.getId(), + refAmount, + ScoreFlowTypeEnum.LEVEL_PERK.getValue(), + mallOrderInfo.getOrderNo(), + FlowTypeEnum.BALANCE.getValue(), + StrUtil.format(ScoreFlowTypeEnum.LEVEL_PERK.getDesc(),mallOrderInfo.getOrderNo()), + 2); } - List<String> skuNames = mallOrderInfo.getItems().stream().map(MallOrderItem::getSkuName).collect(Collectors.toList()); - double sum = mallOrderInfo.getItems().stream().map(MallOrderItem::getAmount).mapToDouble(BigDecimal::doubleValue).sum(); + /** + * 两级返佣 + */ + String referrerIdRef = mallMemberRef.getReferrerId(); + if(StrUtil.isEmpty(referrerIdRef)){ + return; + } + MallMember mallMemberRefTwo = mallMemberMapper.selectInfoByInviteId(referrerIdRef); + QueryWrapper<MallMemberLevel> mallMemberLevelQueryWrapperTwo = new QueryWrapper<>(); + mallMemberLevelQueryWrapperTwo.eq("member_id",mallMemberRefTwo.getId()); + MallMemberLevel mallMemberLevelRefTwo = mallMemberLevelMapper.selectOne(mallMemberLevelQueryWrapperTwo); + if(ObjectUtil.isNotEmpty(mallMemberLevelRefTwo)){ + BigDecimal levelPercentTwo = mallMemberLevelRefTwo.getLevelPercent(); - int score = multiple.multiply(BigDecimal.valueOf(sum)).intValue(); - - 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"); - - List<Long> itemGoodsIds = mallOrderInfo.getItems().stream().map(MallOrderItem::getGoodsId).distinct().collect(Collectors.toList()); - List<MallGoods> goodsList = mallGoodsService.listByIds(itemGoodsIds); - Map<Long, MallGoods> goodsMap = goodsList.stream().collect(Collectors.toMap(MallGoods::getId, MallGoods -> MallGoods)); - - Map<Long, BigDecimal> recommendScoreMap = new HashMap<>(); - mallOrderInfo.getItems().forEach(item -> { - if (StrUtil.isNotBlank(item.getMemberInviteId()) && !member.getInviteId().equals(item.getMemberInviteId())) { - MallGoods mallGoods = goodsMap.get(item.getGoodsId()); - if (mallGoods.getStaticMulti() == null) { - return; - } - - BigDecimal multi = mallGoods.getStaticMulti().divide(BigDecimal.valueOf(100), 2, RoundingMode.HALF_UP); - MallMember mallMember = mallMemberMapper.selectInfoByInviteId(item.getMemberInviteId()); - if (mallMember == null) { - return; - } - - BigDecimal recommendScore = recommendScoreMap.get(mallMember.getId()); - recommendScore = recommendScore == null ? BigDecimal.ZERO : recommendScore; - recommendScore = recommendScore.add(item.getAmount().multiply(multi)); - - recommendScoreMap.put(mallMember.getId(), recommendScore); - } - }); - - recommendScoreMap.forEach((key, value) -> { - if (value != null) { - mallMoneyFlowService.addMoneyFlow(key, value, ScoreFlowTypeEnum.RECOMMEND.getValue(), mallOrderInfo.getOrderNo(), FlowTypeEnum.PRIZE_SCORE.getValue(), CollUtil.join(skuNames, ","), 2); - mallMemberWalletService.add(value, key, "prizeScore"); - } - }); - - agentProducer.sendVipLevelUp(orderId); + BigDecimal refAmountTwo = amount.multiply(levelPercentTwo.multiply(new BigDecimal(0.01))).setScale(2, BigDecimal.ROUND_DOWN); + mallMemberWalletService.addBalance(refAmountTwo,mallMemberRefTwo.getId()); + mallMoneyFlowService.addMoneyFlow( + mallMemberRefTwo.getId(), + refAmountTwo, + ScoreFlowTypeEnum.LEVEL_PERK.getValue(), + mallOrderInfo.getOrderNo(), + FlowTypeEnum.BALANCE.getValue(), + StrUtil.format(ScoreFlowTypeEnum.LEVEL_PERK.getDesc(),mallOrderInfo.getOrderNo()), + 2); + } } @Override -- Gitblit v1.9.1