From fdb91cc72f7cbe8c095a1ce6442c9259ff01ff06 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Thu, 05 Aug 2021 16:47:12 +0800
Subject: [PATCH] add invite award

---
 gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java |  241 ++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 234 insertions(+), 7 deletions(-)

diff --git a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java
index 3337ac7..10489b6 100644
--- a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java
+++ b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java
@@ -6,7 +6,9 @@
 import cn.hutool.core.date.DateUtil;
 import com.github.pagehelper.PageHelper;
 import com.github.pagehelper.PageInfo;
+import com.xzx.gc.common.constant.CommonEnum;
 import com.xzx.gc.common.exception.RestException;
+import com.xzx.gc.common.utils.RedisUtil;
 import com.xzx.gc.common.utils.StringUtils;
 import com.xzx.gc.entity.*;
 import com.xzx.gc.user.dto.*;
@@ -30,6 +32,7 @@
 
 import javax.annotation.Resource;
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.util.HashMap;
 import java.util.List;
 
@@ -55,6 +58,10 @@
     private UserShareInfoMapper userShareInfoMapper;
     @Autowired
     private SysMessageMapper sysMessageMapper;
+    @Autowired
+    private RedisUtil redisUtil;
+    @Autowired
+    private ScoreDetailsMapper scoreDetailsMapper;
 
     public ViewSettingVo viewSetting(String ruleStr) {
         ViewSettingVo viewSettingVo = new ViewSettingVo();
@@ -78,7 +85,7 @@
                     viewSettingVo.setRegularPoint(StrUtil.isEmpty(shareRatios.get(2))?0:Integer.parseInt(shareRatios.get(2)));
                     viewSettingVo.setRegularMoneyPercent(StrUtil.isEmpty(shareRatios.get(3))?BigDecimal.ZERO:new BigDecimal(shareRatios.get(3)));
 //                    viewSettingVo.setFinishOrderNum(StrUtil.isEmpty(shareRatios.get(4))?0:Integer.parseInt(shareRatios.get(4)));
-                    viewSettingVo.setPointReward(StrUtil.isEmpty(shareRatios.get(5))?0:Integer.parseInt(shareRatios.get(5)));
+                    viewSettingVo.setPointReward(StrUtil.isEmpty(shareRatios.get(4))?0:Integer.parseInt(shareRatios.get(4)));
                     viewSettingVo.setStatus(redPaperRule.getStatus());
                 }
             }else{
@@ -113,6 +120,10 @@
         }
 
         AccountInfo accountInfo = accountMapper.selectOneByUserId(userId);
+        if (AccountInfo.IS_HEAD_Y.equals(accountInfo.getIsHead())) {
+            throw new RestException(-3, "团长不能加入团队");
+        }
+
         UserShareInfo userShareInfo = userShareInfoMapper.selectByRegistPhone(accountInfo.getAccountName());
         if (userShareInfo != null) {
             throw new RestException(-3, "您已与推广员绑定, 无法加入");
@@ -177,7 +188,7 @@
         stringBuffer.append(pointReward);
         redPaperRule.setStatus((short) 0);
         redPaperRule.setRuleName("分销规则");
-        redPaperRule.setSharingProfitType("frist_reward,order_num_frist,regular_point,regular_money_percent,finish_order_num,point_reward");
+        redPaperRule.setSharingProfitType("frist_reward,order_num_frist,regular_point,regular_money_percent,point_reward");
         redPaperRule.setShareRatio(stringBuffer.toString());
         redPaperRuleMapper.insert(redPaperRule);
     }
@@ -199,7 +210,7 @@
             int pointReward = ObjectUtil.isEmpty(model.getPointReward()) ? 0 : model.getPointReward();
             stringBuffer.append(pointReward);
             redPaperRule.setStatus(model.getStatus());
-            redPaperRule.setSharingProfitType("first_reward,order_num_first,regular_point,regular_money_percent,finish_order_num,point_reward");
+            redPaperRule.setSharingProfitType("first_reward,order_num_first,regular_point,regular_money_percent,point_reward");
             redPaperRule.setShareRatio(stringBuffer.toString());
             redPaperRuleMapper.updateByPrimaryKey(redPaperRule);
         }
@@ -229,8 +240,7 @@
         return data;
     }
 
-    public void adddistrib(AdddistribDto model) {
-        String id = model.getId();
+    public void adddistrib(String id) {
         AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id);
         accountInfo.setIsHead(1);
         accountMapper.updateByPrimaryKey(accountInfo);
@@ -262,6 +272,11 @@
 
     public ViewDistribInfoVo viewDistribInfo(String id) {
         //获取团长基本信息
+        ViewDistribInfoVo viewDistribInfoVo = accountMapper.selectDistribByAccountId(id);
+        if(StrUtil.isNotEmpty(viewDistribInfoVo.getNickname())){
+            String decode = StringUtils.decode(viewDistribInfoVo.getNickname());
+            viewDistribInfoVo.setNickname(decode);
+        }
         return accountMapper.selectDistribByAccountId(id);
     }
 
@@ -296,6 +311,9 @@
         if(CollUtil.isNotEmpty(orderItemsVos)){
             for(OrderItemsVo orderItemsVo : orderItemsVos){
                 if(ObjectUtil.isNotEmpty(orderItemsVo)){
+                    String nickname = orderItemsVo.getNickname();
+                    String decode = StringUtils.decode(nickname);
+                    orderItemsVo.setNickname(decode);
                     Long orderId = orderItemsVo.getOrderId();
                     List<JhyOrderItems> jhyOrderItems = accountMapper.selectOrderById(orderId);
                     if(CollUtil.isNotEmpty(jhyOrderItems)){
@@ -323,15 +341,23 @@
 
 
     public Map<String, Object> distribDataList(DistribDataListDto distribDataListDto) {
+        if(StrUtil.isNotEmpty(distribDataListDto.getQueryCol())){
+            String decode = StringUtils.encode(distribDataListDto.getQueryCol());
+            distribDataListDto.setName(decode);
+            distribDataListDto.setPhone(distribDataListDto.getQueryCol());
+        }
         PageHelper.startPage(distribDataListDto.getPage(), distribDataListDto.getLimit());
         List<DistribDataListVo> distribDataListVos = accountMapper.distribDataList(distribDataListDto);
         if(CollUtil.isNotEmpty(distribDataListVos)){
             for(DistribDataListVo distribDataListVo : distribDataListVos){
                 if(ObjectUtil.isNotEmpty(distribDataListVo)){
+                    String nickname = distribDataListVo.getNickname();
+                    String decode = StringUtils.decode(nickname);
+                    distribDataListVo.setNickname(decode);
                     String id = distribDataListVo.getId();
-                    String kg = accountMapper.selectOrderByHeadUserId(id);
+                    String kg = accountMapper.selectOrderByHeadUserId(id,distribDataListDto);
                     distribDataListVo.setKg(kg);
-                    String jdsl = accountMapper.selectJDSLByHeadUserId(id);
+                    String jdsl = accountMapper.selectJDSLByHeadUserId(id,distribDataListDto);
                     distribDataListVo.setJdsl(jdsl);
                 }
             }
@@ -348,4 +374,205 @@
     public DistribDataInfoVo distribDataInfo(DistribDataInfoDto distribDataInfoDto) {
         return accountMapper.selectDistribDataInfoVo();
     }
+
+    public Map<String, Object> distribDataExport(ExportDistribDataListDto distribDataListDto) {
+        if(StrUtil.isNotEmpty(distribDataListDto.getQueryCol())){
+            String decode = StringUtils.encode(distribDataListDto.getQueryCol());
+            distribDataListDto.setName(decode);
+            distribDataListDto.setPhone(distribDataListDto.getQueryCol());
+        }
+        List<DistribDataListVo> distribDataListVos = accountMapper.distribDataExport(distribDataListDto);
+        if(CollUtil.isNotEmpty(distribDataListVos)){
+            for(DistribDataListVo distribDataListVo : distribDataListVos){
+                if(ObjectUtil.isNotEmpty(distribDataListVo)){
+                    String nickname = distribDataListVo.getNickname();
+                    String decode = StringUtils.decode(nickname);
+                    distribDataListVo.setNickname(decode);
+                    String id = distribDataListVo.getId();
+                    String kg = accountMapper.selectOrderExportByHeadUserId(id,distribDataListDto);
+                    distribDataListVo.setKg(kg);
+                    String jdsl = accountMapper.selectJDSLExportByHeadUserId(id,distribDataListDto);
+                    distribDataListVo.setJdsl(jdsl);
+                }
+            }
+        }
+        PageInfo<DistribDataListVo> pageInfo = new PageInfo<>(distribDataListVos);
+        Map<String, Object> data = new HashMap<>();
+        int count = Convert.toInt(pageInfo.getTotal());
+        data.put("data", distribDataListVos);
+        data.put("count", count);
+        data.put("code", 0);
+        return data;
+    }
+
+    public ViewScoreSettingVo viewScoreSetting(String ruleStr) {
+        ViewScoreSettingVo viewScoreSettingVo = new ViewScoreSettingVo();
+        RedPaperRule redPaperRule = redPaperRuleMapper.selectByRuleName(ruleStr);
+        if(ObjectUtil.isEmpty(redPaperRule)){
+            viewScoreSettingVo.setRegisterScore(0);
+            viewScoreSettingVo.setShareScore(0);
+            viewScoreSettingVo.setShareScoreTime(0);
+            viewScoreSettingVo.setFirstScore(0);
+            viewScoreSettingVo.setStatus((short) 0);
+        }else{
+            String shareRatio = redPaperRule.getShareRatio();
+            if(StrUtil.isNotEmpty(shareRatio)){
+                List<String> shareRatios = StrUtil.split(shareRatio,',',false,false);
+                if(ObjectUtil.isNotEmpty(shareRatios)){
+                    viewScoreSettingVo.setId(redPaperRule.getId());
+                    viewScoreSettingVo.setRegisterScore(StrUtil.isEmpty(shareRatios.get(0))?0:Integer.parseInt(shareRatios.get(0)));
+                    viewScoreSettingVo.setShareScore(StrUtil.isEmpty(shareRatios.get(1))?0:Integer.parseInt(shareRatios.get(1)));
+                    viewScoreSettingVo.setShareScoreTime(StrUtil.isEmpty(shareRatios.get(2))?0:Integer.parseInt(shareRatios.get(2)));
+                    viewScoreSettingVo.setFirstScore(StrUtil.isEmpty(shareRatios.get(3))?0:Integer.parseInt(shareRatios.get(3)));
+                    viewScoreSettingVo.setStatus(redPaperRule.getStatus());
+                }
+            }else{
+                viewScoreSettingVo.setId(redPaperRule.getId());
+                viewScoreSettingVo.setRegisterScore(0);
+                viewScoreSettingVo.setShareScore(0);
+                viewScoreSettingVo.setShareScoreTime(0);
+                viewScoreSettingVo.setFirstScore(0);
+                viewScoreSettingVo.setStatus(redPaperRule.getStatus());
+            }
+        }
+        return viewScoreSettingVo;
+    }
+
+    public void addScoreSetting(UpdateScoreSetting model) {
+        RedPaperRule redPaperRule = new RedPaperRule();
+        StringBuffer stringBuffer = new StringBuffer();
+        int registerScore = ObjectUtil.isEmpty(model.getRegisterScore()) ? 0 : model.getRegisterScore();
+        stringBuffer.append(registerScore+",");
+        int shareScore = ObjectUtil.isEmpty(model.getShareScore()) ? 0 : model.getShareScore();
+        stringBuffer.append(shareScore+",");
+        int shareScoreTime = ObjectUtil.isEmpty(model.getShareScoreTime()) ? 0 : model.getShareScoreTime();
+        stringBuffer.append(shareScoreTime+",");
+        int firstScore = ObjectUtil.isEmpty(model.getFirstScore()) ? 0 : model.getFirstScore();
+        stringBuffer.append(firstScore);
+        redPaperRule.setStatus((short) 0);
+        redPaperRule.setRuleName("积分运行设置");
+        redPaperRule.setRuleType("10");
+        redPaperRule.setSharingProfitType("register_score,share_score,share_score_time,first_score");
+        redPaperRule.setShareRatio(stringBuffer.toString());
+        redPaperRuleMapper.insert(redPaperRule);
+    }
+
+    public void updateScoreSetting(UpdateScoreSetting model) {
+        RedPaperRule redPaperRule = redPaperRuleMapper.selectByPrimaryKey(model.getId());
+        if(ObjectUtil.isNotEmpty(redPaperRule)){
+            StringBuffer stringBuffer = new StringBuffer();
+            int registerScore = ObjectUtil.isEmpty(model.getRegisterScore()) ? 0 : model.getRegisterScore();
+            stringBuffer.append(registerScore+",");
+            int shareScore = ObjectUtil.isEmpty(model.getShareScore()) ? 0 : model.getShareScore();
+            stringBuffer.append(shareScore+",");
+            int shareScoreTime = ObjectUtil.isEmpty(model.getShareScoreTime()) ? 0 : model.getShareScoreTime();
+            stringBuffer.append(shareScoreTime+",");
+            int firstScore = ObjectUtil.isEmpty(model.getFirstScore()) ? 0 : model.getFirstScore();
+            stringBuffer.append(firstScore);
+            redPaperRule.setStatus(model.getStatus());
+            redPaperRule.setSharingProfitType("register_score,share_score,share_score_time,first_score");
+            redPaperRule.setShareRatio(stringBuffer.toString());
+            redPaperRuleMapper.updateByPrimaryKey(redPaperRule);
+        }
+    }
+
+    public void shareToMoments(String userId) {
+        List<RedPaperRule> redPaperRules = redPaperRuleMapper.selectByRuleType("10");
+        if (CollUtil.isEmpty(redPaperRules)) {
+            return;
+        }
+
+        RedPaperRule rule = redPaperRules.get(0);
+        String shareTimes = getRuleValue(rule, CommonEnum.朋友圈分享限次.getValue());
+
+        String shareScore = getRuleValue(rule, CommonEnum.朋友圈分享奖励.getValue());
+        String key = "moments:times:" + userId;
+        Integer times = redisUtil.getAsInt("moments:times:" + userId);
+        times = times == null ? 1 : times + 1;
+
+        if (StrUtil.isNotBlank(shareTimes)) {
+            if (times > Integer.parseInt(shareTimes)) {
+                throw new RestException("达到24小时内最大分享次数");
+            }
+
+            if (StrUtil.isBlank(shareScore)) {
+                return;
+            }
+
+            AccountInfo accountInfo = accountMapper.selectOneByUserId(userId);
+            BigDecimal returnScore = new BigDecimal(shareScore);
+            BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO;
+            accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, RoundingMode.DOWN).toString());
+            accountMapper.updateByPrimaryKey(accountInfo);
+
+            ScoreDetails scoreDetails = new ScoreDetails();
+            scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore()));
+            scoreDetails.setOriginalScore(collectScore);
+            scoreDetails.setChangeScore(returnScore);
+            scoreDetails.setCreatedTime(new Date());
+            scoreDetails.setType(ScoreDetails.SCORE_TYPE_SHARE_MOMENTS);
+            scoreDetails.setUserId(accountInfo.getUserId());
+            scoreDetailsMapper.insert(scoreDetails);
+
+            SysMessage sysMessage = new SysMessage();
+            sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
+            sysMessage.setCreateUserId(accountInfo.getUserId());
+            sysMessage.setUserId(accountInfo.getUserId());
+            sysMessage.setMessageType("4");
+            sysMessage.setMessageSubTypeName("朋友圈分享");
+            sysMessage.setMessage("朋友圈分享, 积分:" + returnScore);
+            sysMessage.setFlag("2");
+            sysMessageMapper.insert(sysMessage);
+
+            redisUtil.setex(key, times.toString(), 84400);
+        }
+    }
+
+    public void inviteAward(String phone) {
+        AccountInfo accountInfo = accountMapper.selectAccountInfoByPhone(phone);
+
+        List<RedPaperRule> redPaperRules = redPaperRuleMapper.selectByRuleType("10");
+        if (CollUtil.isEmpty(redPaperRules)) {
+            return;
+        }
+
+        RedPaperRule rule = redPaperRules.get(0);
+        String invite = getRuleValue(rule, CommonEnum.邀请奖励.getValue());
+
+        if (StrUtil.isBlank(invite)) {
+            return;
+        }
+
+        BigDecimal returnScore = new BigDecimal(invite);
+        BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO;
+        accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, RoundingMode.DOWN).toString());
+        accountMapper.updateByPrimaryKey(accountInfo);
+
+        ScoreDetails scoreDetails = new ScoreDetails();
+        scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore()));
+        scoreDetails.setOriginalScore(collectScore);
+        scoreDetails.setChangeScore(returnScore);
+        scoreDetails.setCreatedTime(new Date());
+        scoreDetails.setType(ScoreDetails.SCORE_TYPE_INVITE);
+        scoreDetails.setUserId(accountInfo.getUserId());
+        scoreDetailsMapper.insert(scoreDetails);
+
+        SysMessage sysMessage = new SysMessage();
+        sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
+        sysMessage.setCreateUserId(accountInfo.getUserId());
+        sysMessage.setUserId(accountInfo.getUserId());
+        sysMessage.setMessageType("4");
+        sysMessage.setMessageSubTypeName("邀请奖励");
+        sysMessage.setMessage("邀请奖励, 积分:" + returnScore);
+        sysMessage.setFlag("2");
+        sysMessageMapper.insert(sysMessage);
+    }
+
+    private String getRuleValue(RedPaperRule redPaperRule, String key) {
+        List<String> rules = StrUtil.split(redPaperRule.getSharingProfitType(), ',');
+        List<String> values = StrUtil.split(redPaperRule.getShareRatio(), ',');
+
+        int i = rules.indexOf(key);
+        return values.get(i);
+    }
 }

--
Gitblit v1.9.1