From cd657f34271f387edb8d72befbcdad37f7bed77a Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Thu, 15 Jul 2021 15:47:13 +0800
Subject: [PATCH] fix

---
 gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java |   26 +++++++++++++++++++++++++-
 1 files changed, 25 insertions(+), 1 deletions(-)

diff --git a/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java b/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java
index c5d872f..5a613b4 100644
--- a/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java
+++ b/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java
@@ -1,6 +1,8 @@
 package com.xzx.gc.order.service;
 
+import cn.hutool.core.codec.Base64;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.StrUtil;
 import com.xzx.gc.common.constant.CommonEnum;
 import com.xzx.gc.entity.*;
@@ -34,6 +36,12 @@
     private RedPaperRuleMapper redPaperRuleMapper;
     @Autowired
     private JhyOrderItemsMapper jhyOrderItemsMapper;
+    @Autowired
+    private SysMessageMapper sysMessageMapper;
+    @Autowired
+    private AccountMapper accountMapper;
+    @Autowired
+    private UserMapper userMapper;
 
     public void distribRecord(Long orderId, String userId) {
         UserHeadRelate userHeadRelate = userHeadRelateMapper.selectRelateByUserId(userId);
@@ -47,7 +55,8 @@
         }
 
         Integer count = userHeadDetailsMapper.selectDetailsCount(userId);
-
+        UserInfo userInfo = userMapper.selectByPrimaryKey(userId);
+        AccountInfo accountInfo = accountMapper.selectAccountInfoByUserId(userId);
         List<String> remark = new ArrayList<>();
         BigDecimal totalReturnScore = BigDecimal.ZERO;
         BigDecimal totalReturnCoin = BigDecimal.ZERO;
@@ -116,6 +125,21 @@
         userHeadRelate.setScore(userHeadDetails.getScore().add(totalReturnScore));
         userHeadRelateMapper.updateByPrimaryKey(userHeadRelate);
 
+        accountInfo.setAccountId(accountInfo.getAccountId());
+        accountInfo.setMoney(new BigDecimal(accountInfo.getMoney()).add(totalReturnCoin).setScale(2, BigDecimal.ROUND_DOWN).toString());
+        BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO;
+        accountInfo.setCollectScore(collectScore.add(totalReturnScore).setScale(2, BigDecimal.ROUND_DOWN).toString());
+        accountMapper.updateByPrimaryKey(accountInfo);
+
+        SysMessage sysMessage = new SysMessage();
+        sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
+        sysMessage.setCreateUserId(userHeadRelate.getHeadUserId());
+        sysMessage.setUserId(userHeadRelate.getHeadUserId());
+        sysMessage.setMessageType("4");
+        sysMessage.setMessageSubTypeName("返利消息");
+        sysMessage.setMessage("收到用户:" + Base64.decodeStr(userInfo.getNickName()) + "的订单返利, 积分:" + totalReturnScore +", 环保币:" + totalReturnCoin);
+        sysMessage.setFlag("2");
+        sysMessageMapper.insert(sysMessage);
     }
 
     private String getRuleValue(RedPaperRule redPaperRule, String key) {

--
Gitblit v1.9.1