From 436c0695fea9a8d11c2a2f1da7abfafd834b40fb Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 20 Jul 2023 17:37:19 +0800
Subject: [PATCH] 购买民宿卷商品,支付完,订单就已经完成

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |   96 ++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 84 insertions(+), 12 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
index ab34249..59f271a 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
@@ -1,18 +1,14 @@
 package cc.mrbird.febs.mall.service.impl;
 
 import cc.mrbird.febs.common.entity.FebsResponse;
-import cc.mrbird.febs.common.enumerates.AgentLevelEnum;
-import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
+import cc.mrbird.febs.common.enumerates.*;
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.utils.AppContants;
 import cc.mrbird.febs.common.utils.HttpCurlUtil;
 import cc.mrbird.febs.common.utils.ShareCodeUtil;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
-import cc.mrbird.febs.mall.service.IAgentService;
-import cc.mrbird.febs.mall.service.IApiMallMemberService;
-import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
-import cc.mrbird.febs.mall.service.IMallAchieveService;
+import cc.mrbird.febs.mall.service.*;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
@@ -50,6 +46,12 @@
     private final MallMemberMapper memberMapper;
     private final MallMemberWalletMapper mallMemberWalletMapper;
     private final RestTemplate restTemplate;
+    private final MallOrderInfoMapper mallOrderInfoMapper;
+    private final MallOrderItemMapper mallOrderItemMapper;
+    private final MallGoodsMapper mallGoodsMapper;
+    private final IApiMallMemberWalletService memberWalletService;
+    private final MallRollPerkMapper mallRollPerkMapper;
+    private final IMallMoneyFlowService mallMoneyFlowService;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -297,11 +299,9 @@
         String accessToken = split[0];
         String openId = split[1];
         MallMember mallMember = memberMapper.selectMemberByOpenId(openId);
-        if (ObjectUtil.isNotEmpty(mallMember)) {
+        if (ObjectUtil.isEmpty(mallMember)) {
             return;
         }
-        log.info("收到accessToken:{}", accessToken);
-        log.info("收到openId:{}", openId);
         String requrl = "https://api.weixin.qq.com/sns/userinfo?access_token="+accessToken+"&openid="+openId+"&lang=zh_CN";
 
         // 创建一个StringHttpMessageConverter,并设置字符集为UTF-8
@@ -324,15 +324,87 @@
         }
         String nickname = json.getString("nickname");
         String headImgUrl = json.getString("headimgurl");
-        log.info("收到nickname:{}", nickname);
-        log.info("收到headImgUrl:{}", headImgUrl);
-
         mallMember.setName(nickname);
         mallMember.setAvatar(headImgUrl);
         memberMapper.updateById(mallMember);
         return;
     }
 
+
+    @Override
+    public void orderGetMsg(String str) {
+        /**
+         * String str : orderId@amount
+         */
+        String[] split = StrUtil.split(str, "@");
+        String orderId = split[0];
+        String amount = split[1];
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
+        if(ObjectUtil.isEmpty(mallOrderInfo)){
+            return;
+        }
+        Long memberId = mallOrderInfo.getMemberId();
+        MallMember mallMember = memberMapper.selectById(memberId);
+
+
+        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(mallOrderInfo.getId());
+        if(CollUtil.isEmpty(mallOrderItemList)){
+            return;
+        }
+
+        /**
+         * 支付后同意验证
+         *  1:是否送券
+         *  2:是否送积分
+         *  3:是否返利
+         */
+        //是否返利
+        BigDecimal amountBigDecimal = new BigDecimal(StrUtil.isEmpty(amount) ? "0" : amount);
+        if(BigDecimal.ZERO.compareTo(amountBigDecimal) < 0){
+            if(ObjectUtil.isNotEmpty(mallMember.getReferrerId())){
+                String referrerId = mallMember.getReferrerId();
+                MallMember mallMemberParent = memberMapper.selectInfoByInviteId(referrerId);
+                Long id = mallMemberParent.getId();
+                DataDictionaryCustom returnPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                        DataDictionaryEnum.MEMBER_RETURN_PERCENT.getType(),
+                        DataDictionaryEnum.MEMBER_RETURN_PERCENT.getCode()
+                );
+                String returnPercentStr = StrUtil.isNotEmpty(returnPercentDic.getValue()) ? "1" : returnPercentDic.getValue();
+                BigDecimal returnPercent = new BigDecimal(returnPercentStr).divide(new BigDecimal(100), 2, BigDecimal.ROUND_DOWN);
+                BigDecimal amountActual = amountBigDecimal.multiply(returnPercent).setScale(2, BigDecimal.ROUND_DOWN);
+                memberWalletService.add(amountActual, id, "balance");
+                mallMoneyFlowService.addMoneyFlow(id, amountActual, MoneyFlowTypeEnum.DYNAMIC_ACHIEVE.getValue(),
+                        mallOrderInfo.getOrderNo(),  FlowTypeEnum.BALANCE.getValue());
+            }
+        }
+        for(MallOrderItem mallOrderItem : mallOrderItemList){
+            Long goodsId = mallOrderItem.getGoodsId();
+            MallGoods mallGoods = mallGoodsMapper.selectById(goodsId);
+            if(ObjectUtil.isEmpty(mallGoods)){
+                break;
+            }
+            //是否送券 1:是 2:否
+            BigDecimal levelTwoPrice = mallGoods.getLevelTwoPrice();
+            if(BigDecimal.ONE.compareTo(levelTwoPrice) == 0){
+                MallRollPerk mallRollPerk = new MallRollPerk();
+                mallRollPerk.setMemberId(memberId);
+                mallRollPerk.setState(1);
+                mallRollPerk.setRollId(mallGoods.getLevelThreePrice().longValue());
+                mallRollPerkMapper.insert(mallRollPerk);
+                mallOrderInfo.setStatus(OrderStatusEnum.FINISH.getValue());
+                mallOrderInfoMapper.updateById(mallOrderInfo);
+            }
+            //赠送积分
+            BigDecimal levelOnePrice = mallGoods.getLevelOnePrice();
+            if(BigDecimal.ZERO.compareTo(levelOnePrice) <= 0){
+                memberWalletService.add(levelOnePrice, memberId, "score");
+
+                mallMoneyFlowService.addMoneyFlow(memberId, levelOnePrice, MoneyFlowTypeEnum.STATIC_BONUS.getValue(),
+                        mallOrderInfo.getOrderNo(),  FlowTypeEnum.SCORE.getValue());
+            }
+        }
+    }
+
     public static void main(String[] args) {
 
         RestTemplate restTemplate = new RestTemplate();

--
Gitblit v1.9.1