From 17a07481c3292e6fcbc7fff3dcbeb8ae817c178c Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Fri, 16 Jul 2021 16:16:24 +0800 Subject: [PATCH] Merge branch 'score-shop' of http://120.27.238.55:7000/r/xzx into score-shop --- gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java | 50 ++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 46 insertions(+), 4 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..1c30613 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,14 @@ private RedPaperRuleMapper redPaperRuleMapper; @Autowired private JhyOrderItemsMapper jhyOrderItemsMapper; + @Autowired + private SysMessageMapper sysMessageMapper; + @Autowired + private AccountMapper accountMapper; + @Autowired + private UserMapper userMapper; + @Autowired + private ScoreDetailsMapper scoreDetailsMapper; public void distribRecord(Long orderId, String userId) { UserHeadRelate userHeadRelate = userHeadRelateMapper.selectRelateByUserId(userId); @@ -47,6 +57,12 @@ } Integer count = userHeadDetailsMapper.selectDetailsCount(userId); +// UserInfo userInfo = userMapper.selectByPrimaryKey(userId); + AccountInfo accountInfo = accountMapper.selectAccountInfoByUserId(userHeadRelate.getHeadUserId()); + + if (AccountInfo.IS_PROHIBIT_Y.equals(accountInfo.getIsProhibit())) { + return; + } List<String> remark = new ArrayList<>(); BigDecimal totalReturnScore = BigDecimal.ZERO; @@ -60,7 +76,7 @@ // 首单返利 if (StrUtil.isNotBlank(value) && !"0".equals(value)) { BigDecimal money = new BigDecimal(value); - totalReturnScore = totalReturnScore.add(money); + totalReturnCoin = totalReturnCoin.add(money); remark.add("首单返利:" + money); } } @@ -70,7 +86,7 @@ if (StrUtil.isNotBlank(value) && !"0".equals(value)) { // 首单完成后,在value单内,返利积分或者环保币 - if (count - 1 <= Integer.parseInt(value)) { + if (count - 1 < Integer.parseInt(value)) { String scoreStr = getRuleValue(redPaperRule, CommonEnum.返利固定积分.getValue()); String coinStr = getRuleValue(redPaperRule, CommonEnum.返利环保币比例.getValue()); // 根据积分返利固定积分 @@ -83,7 +99,7 @@ // 根据订单总积分, 1:40比例,换算成环保币,返对应百分比 if (StrUtil.isNotBlank(coinStr) && !"0".equals(coinStr)) { BigDecimal coinRatio = new BigDecimal(coinStr).divide(BigDecimal.valueOf(100), 2, BigDecimal.ROUND_DOWN); - BigDecimal totalCoin = totalScore.multiply(new BigDecimal(40)); + BigDecimal totalCoin = totalScore.divide(new BigDecimal(40), 2, BigDecimal.ROUND_DOWN); BigDecimal returnCoin = totalCoin.multiply(coinRatio).setScale(2, BigDecimal.ROUND_DOWN); totalReturnCoin = totalReturnCoin.add(returnCoin); @@ -113,9 +129,35 @@ userHeadDetailsMapper.insert(userHeadDetails); userHeadRelate.setAmount(userHeadRelate.getAmount().add(totalReturnCoin)); - userHeadRelate.setScore(userHeadDetails.getScore().add(totalReturnScore)); + userHeadRelate.setScore(userHeadRelate.getScore().add(totalReturnScore)); userHeadRelateMapper.updateByPrimaryKey(userHeadRelate); + 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(0, BigDecimal.ROUND_DOWN).toString()); + accountMapper.updateByPrimaryKey(accountInfo); + + if (totalReturnScore.compareTo(BigDecimal.ZERO) > 0) { + ScoreDetails scoreDetails = new ScoreDetails(); + scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore())); + scoreDetails.setOriginalScore(collectScore); + scoreDetails.setChangeScore(totalReturnScore); + scoreDetails.setCreatedTime(new Date()); + scoreDetails.setType(ScoreDetails.SCORE_TYPE_OTHER); + scoreDetails.setUserId(userHeadRelate.getHeadUserId()); + scoreDetails.setOrderNo(order.getOrderNo()); + scoreDetailsMapper.insert(scoreDetails); + } + + 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("收到用户:" + accountInfo.getAccountName().replaceAll("(\\w{3})\\w*(\\w{4})", "$1****$2") + "的订单返利, 积分:" + totalReturnScore +", 环保币:" + totalReturnCoin); + sysMessage.setFlag("2"); + sysMessageMapper.insert(sysMessage); } private String getRuleValue(RedPaperRule redPaperRule, String key) { -- Gitblit v1.9.1