From 417842b77970a8647945cff4ada68f3707f555e5 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 10 Mar 2023 16:15:21 +0800
Subject: [PATCH] 下单,余额支付,转账,分享奖,星级奖励,商品贡献值,补贴三倍回购

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |   43 ++++++++++++++++++++++++++++++-------------
 1 files changed, 30 insertions(+), 13 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index 1a86fd2..7004685 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -14,10 +14,7 @@
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.*;
-import cc.mrbird.febs.mall.vo.ApiShopApplyVo;
-import cc.mrbird.febs.mall.vo.OrderDetailVo;
-import cc.mrbird.febs.mall.vo.OrderListVo;
-import cc.mrbird.febs.mall.vo.OrderRefundVo;
+import cc.mrbird.febs.mall.vo.*;
 import cc.mrbird.febs.pay.model.AgreementPayDto;
 import cc.mrbird.febs.pay.model.AgreementSignDto;
 import cc.mrbird.febs.pay.model.UnipayDto;
@@ -42,6 +39,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.math.BigInteger;
 import java.text.DecimalFormat;
 import java.util.*;
 
@@ -79,6 +77,7 @@
     private final MallShopApplyMapper mallShopApplyMapper;
     private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
     private final MallAchieveRecordMapper mallAchieveRecordMapper;
+    private final MallMemberWalletMapper mallMemberWalletMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -349,9 +348,9 @@
                 orderInfo.setPayTime(new Date());
                 orderInfo.setPayResult("1");
 
-                changeWallet(orderInfo.getId(), member.getId());
-
-                agentProducer.sendAutoLevelUpMsg(member.getId());
+                changeWallet(orderInfo.getId());
+                //发送补贴消息
+                agentProducer.sendPerkMoneyMsg(orderInfo.getId());
 //                agentProducer.sendOrderReturn(orderInfo.getId());
                 break;
             case "4":
@@ -431,10 +430,10 @@
      *      增加贡献值,增加流水
      *      产生一条业绩记录
      * @param orderId
-     * @param memberId
      */
-    public void changeWallet(Long orderId,Long memberId){
+    public void changeWallet(Long orderId){
         MallOrderInfo orderInfo = this.baseMapper.selectById(orderId);
+        Long memberId = orderInfo.getMemberId();
         boolean hasTc = false;
         //总贡献值
         BigDecimal starSum = BigDecimal.ZERO;
@@ -453,7 +452,7 @@
                  */
                 if (mallGoods.getIsNormal() == 2) {
                     hasTc = true;
-                    BigDecimal star = mallGoods.getStar();
+                    BigDecimal star = mallGoods.getStar()==null ? BigDecimal.ZERO : mallGoods.getStar();
                     starSum = starSum.add(star);
                     scoreSum = scoreSum.add(
                             new BigDecimal(mallGoods.getPresentPrice())
@@ -466,7 +465,7 @@
              * 增加贡献值,增加流水
              */
             if (starSum.compareTo(BigDecimal.ZERO) > 0) {
-                memberWalletService.add(starSum, memberId, "star");
+                mallMemberWalletMapper.addStarByMemberId(starSum.intValue(), memberId);
                 mallMoneyFlowService.addMoneyFlow(
                         memberId,
                         starSum,
@@ -834,7 +833,7 @@
         BigDecimal score = ObjectUtil.isEmpty(addOrderDto.getScore()) ? BigDecimal.ZERO : addOrderDto.getScore();
         if(ObjectUtil.isNotEmpty(scorePercentDic)){
             //商品的现金折扣比例
-            BigDecimal scorePercent = new BigDecimal(scorePercentDic.getValue()).divide(new BigDecimal(100), BigDecimal.ROUND_DOWN);
+            BigDecimal scorePercent = new BigDecimal(scorePercentDic.getValue()).multiply(BigDecimal.valueOf(0.01));
             //最大折扣金额对应需要的总积分数目
             BigDecimal scorePercentMaxAmount = total.multiply(scorePercent);
             BigDecimal scoreChange = BigDecimal.ONE;
@@ -843,7 +842,9 @@
             }
             scorePercentMaxAmount = scorePercentMaxAmount.multiply(scoreChange);
             if(scorePercentMaxAmount.compareTo(score) < 0){
-                return false;
+                flag = false;
+            }else{
+                flag = true;
             }
         }else{
             flag = true;
@@ -851,4 +852,20 @@
         return flag;
     }
 
+    @Override
+    public ApiScoreSetVo myScoreSet() {
+        ApiScoreSetVo apiScoreSetVo = new ApiScoreSetVo();
+        DataDictionaryCustom scorePercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.SCORE_PERCENT.getType(),
+                DataDictionaryEnum.SCORE_PERCENT.getCode()
+        );
+        DataDictionaryCustom scoreChangeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.SCORE_CHANGE.getType(),
+                DataDictionaryEnum.SCORE_CHANGE.getCode()
+        );
+        apiScoreSetVo.setScorePercent(new BigDecimal(scorePercentDic.getValue()).multiply(BigDecimal.valueOf(0.01)).setScale(2,BigDecimal.ROUND_DOWN));
+        apiScoreSetVo.setScoreChange(new BigDecimal(scoreChangeDic.getValue()).setScale(2,BigDecimal.ROUND_DOWN));
+        return apiScoreSetVo;
+    }
+
 }

--
Gitblit v1.9.1