From 886265d9085ce5324f98e52c1826cfee99637045 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 16 Jul 2021 14:14:58 +0800
Subject: [PATCH] 202107016

---
 gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java |  339 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 329 insertions(+), 10 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 e06dd0d..b46eba3 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
@@ -1,46 +1,103 @@
 package com.xzx.gc.user.service;
 
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.convert.Convert;
 import cn.hutool.core.date.DateUnit;
 import cn.hutool.core.date.DateUtil;
+import com.github.pagehelper.PageHelper;
+import com.github.pagehelper.PageInfo;
 import com.xzx.gc.common.exception.RestException;
-import com.xzx.gc.entity.AccountInfo;
-import com.xzx.gc.entity.SysMessage;
-import com.xzx.gc.entity.UserHeadRelate;
-import com.xzx.gc.entity.UserShareInfo;
+import com.xzx.gc.common.utils.StringUtils;
+import com.xzx.gc.entity.*;
+import com.xzx.gc.user.dto.*;
+import com.xzx.gc.user.mapper.*;
+import com.xzx.gc.user.vo.HeadInfoVo;
+import com.xzx.gc.user.vo.HeadProfitListVo;
+import com.xzx.gc.user.vo.HeadTeamVo;
 import com.xzx.gc.user.mapper.AccountMapper;
 import com.xzx.gc.user.mapper.SysMessageMapper;
 import com.xzx.gc.user.mapper.UserHeadRelateMapper;
 import com.xzx.gc.user.mapper.UserShareInfoMapper;
-import com.xzx.gc.user.vo.ViewSettingVo;
+import com.xzx.gc.user.vo.*;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
+import com.xzx.gc.model.JsonResult;
+import com.xzx.gc.user.mapper.RedPaperRuleMapper;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.util.HashMap;
+import java.util.List;
+
 import java.math.BigDecimal;
 import java.util.Date;
+import java.util.List;
+import java.util.Map;
 
+@Slf4j
 @Service
 @Transactional
 public class DistribService {
 
+    @Resource
+    private RedPaperRuleMapper redPaperRuleMapper;
     @Autowired
     private UserHeadRelateMapper userHeadRelateMapper;
-
+    @Autowired
+    private UserHeadDetailsMapper userHeadDetailsMapper;
     @Autowired
     private AccountMapper accountMapper;
-
     @Autowired
     private UserShareInfoMapper userShareInfoMapper;
     @Autowired
     private SysMessageMapper sysMessageMapper;
 
-    public ViewSettingVo viewSetting(Long id) {
+    public ViewSettingVo viewSetting(String ruleStr) {
         ViewSettingVo viewSettingVo = new ViewSettingVo();
+        RedPaperRule redPaperRule = redPaperRuleMapper.selectByRuleName(ruleStr);
+        if(ObjectUtil.isEmpty(redPaperRule)){
+            viewSettingVo.setFristReward(BigDecimal.ZERO);
+            viewSettingVo.setOrderNumFrist(0);
+            viewSettingVo.setRegularPoint(0);
+            viewSettingVo.setRegularMoneyPercent(BigDecimal.ZERO);
+//            viewSettingVo.setFinishOrderNum(0);
+            viewSettingVo.setPointReward(0);
+            viewSettingVo.setStatus((short) 0);
+        }else{
+            String shareRatio = redPaperRule.getShareRatio();
+            if(StrUtil.isNotEmpty(shareRatio)){
+                List<String> shareRatios = StrUtil.split(shareRatio,',',false,false);
+                if(ObjectUtil.isNotEmpty(shareRatios)){
+                    viewSettingVo.setId(redPaperRule.getId());
+                    viewSettingVo.setFristReward(StrUtil.isEmpty(shareRatios.get(0))?BigDecimal.ZERO:new BigDecimal(shareRatios.get(0)));
+                    viewSettingVo.setOrderNumFrist(StrUtil.isEmpty(shareRatios.get(1))?0:Integer.parseInt(shareRatios.get(1)));
+                    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(4))?0:Integer.parseInt(shareRatios.get(4)));
+                    viewSettingVo.setStatus(redPaperRule.getStatus());
+                }
+            }else{
+                viewSettingVo.setId(redPaperRule.getId());
+                viewSettingVo.setFristReward(BigDecimal.ZERO);
+                viewSettingVo.setOrderNumFrist(0);
+                viewSettingVo.setRegularPoint(0);
+                viewSettingVo.setRegularMoneyPercent(BigDecimal.ZERO);
+//                viewSettingVo.setFinishOrderNum(0);
+                viewSettingVo.setPointReward(0);
+                viewSettingVo.setStatus((short) 0);
+            }
+        }
         return viewSettingVo;
     }
 
 
     public void join(String headId, String userId) {
+        log.info("#加入团队:{}, {}#", headId, userId);
         AccountInfo headInfo = accountMapper.selectOneByUserId(headId);
         if (AccountInfo.IS_HEAD_N.equals(headInfo.getIsHead())) {
             throw new RestException(-3, "不是团长");
@@ -56,6 +113,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, "您已与推广员绑定, 无法加入");
@@ -65,16 +126,274 @@
         userHeadRelate.setHeadUserId(headId);
         userHeadRelate.setUserId(userId);
         userHeadRelate.setScore(BigDecimal.ZERO);
+        userHeadRelate.setCreatedTime(new Date());
         userHeadRelate.setAmount(BigDecimal.ZERO);
         userHeadRelateMapper.insert(userHeadRelate);
 
         SysMessage sysMessage = new SysMessage();
         sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
-        sysMessage.setCreateUserId(userId);
+        sysMessage.setCreateUserId(headId);
+        sysMessage.setUserId(headId);
         sysMessage.setMobilePhone(accountInfo.getAccountName());
         sysMessage.setMessageType("4");
-        sysMessage.setMessage("手机号:" + accountInfo.getAccountName() + "的用户, 成功加入您的团队");
+        sysMessage.setMessageSubTypeName("团队消息");
+        sysMessage.setMessage("手机号:" + accountInfo.getAccountName().replaceAll("(\\w{3})\\w*(\\w{4})", "$1****$2") + "的用户, 成功加入您的团队");
         sysMessage.setFlag("2");
         sysMessageMapper.insert(sysMessage);
     }
+
+    public HeadInfoVo findHeadInfo(String userId) {
+        AccountInfo accountInfo = accountMapper.selectOneByUserId(userId);
+
+        HeadInfoVo headInfoVo = userHeadRelateMapper.selectHeadStatisticsData(userId);
+        if (headInfoVo == null) {
+            headInfoVo = new HeadInfoVo();
+        }
+
+        headInfoVo.setIsHead(accountInfo.getIsHead());
+        return headInfoVo;
+    }
+
+    public List<HeadProfitListVo> findHeadProfitListInPage(HeadProfitLitDto profitLitDto) {
+        PageHelper.startPage(profitLitDto.getPage(), profitLitDto.getLimit());
+        return userHeadDetailsMapper.selectHeadProfitListInPage(profitLitDto.getUserId());
+    }
+
+    public List<HeadTeamVo> findHeadTeamListInPage(HeadTeamDto teamDto) {
+        PageHelper.startPage(teamDto.getPage(), teamDto.getLimit());
+        return userHeadRelateMapper.selectHeadTeamListInPage(teamDto.getUserId());
+    }
+
+    public void addSetting(UpdateSettingDto model) {
+        RedPaperRule redPaperRule = new RedPaperRule();
+        StringBuffer stringBuffer = new StringBuffer();
+        BigDecimal fristReward = ObjectUtil.isEmpty(model.getFristReward()) ? BigDecimal.ZERO : model.getFristReward();
+        stringBuffer.append(fristReward+",");
+        int orderNumFrist = ObjectUtil.isEmpty(model.getOrderNumFrist()) ? 0 : model.getOrderNumFrist();
+        stringBuffer.append(orderNumFrist+",");
+        int regularPoint = ObjectUtil.isEmpty(model.getRegularPoint()) ? 0 : model.getRegularPoint();
+        stringBuffer.append(regularPoint+",");
+        BigDecimal regularMoneyPercent = ObjectUtil.isEmpty(model.getRegularMoneyPercent()) ? BigDecimal.ZERO : model.getRegularMoneyPercent();
+        stringBuffer.append(regularMoneyPercent+",");
+//        int finishOrderNum = ObjectUtil.isEmpty(model.getFinishOrderNum()) ? 0 : model.getFinishOrderNum();
+//        stringBuffer.append(finishOrderNum+",");
+        int pointReward = ObjectUtil.isEmpty(model.getPointReward()) ? 0 : model.getPointReward();
+        stringBuffer.append(pointReward);
+        redPaperRule.setStatus((short) 0);
+        redPaperRule.setRuleName("分销规则");
+        redPaperRule.setSharingProfitType("frist_reward,order_num_frist,regular_point,regular_money_percent,point_reward");
+        redPaperRule.setShareRatio(stringBuffer.toString());
+        redPaperRuleMapper.insert(redPaperRule);
+    }
+
+    public void updateSetting(UpdateSettingDto model) {
+        RedPaperRule redPaperRule = redPaperRuleMapper.selectByPrimaryKey(model.getId());
+        if(ObjectUtil.isNotEmpty(redPaperRule)){
+            StringBuffer stringBuffer = new StringBuffer();
+            BigDecimal fristReward = ObjectUtil.isEmpty(model.getFristReward()) ? BigDecimal.ZERO : model.getFristReward();
+            stringBuffer.append(fristReward+",");
+            int orderNumFrist = ObjectUtil.isEmpty(model.getOrderNumFrist()) ? 0 : model.getOrderNumFrist();
+            stringBuffer.append(orderNumFrist+",");
+            int regularPoint = ObjectUtil.isEmpty(model.getRegularPoint()) ? 0 : model.getRegularPoint();
+            stringBuffer.append(regularPoint+",");
+            BigDecimal regularMoneyPercent = ObjectUtil.isEmpty(model.getRegularMoneyPercent()) ? BigDecimal.ZERO : model.getRegularMoneyPercent();
+            stringBuffer.append(regularMoneyPercent+",");
+//            int finishOrderNum = ObjectUtil.isEmpty(model.getFinishOrderNum()) ? 0 : model.getFinishOrderNum();
+//            stringBuffer.append(finishOrderNum+",");
+            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,point_reward");
+            redPaperRule.setShareRatio(stringBuffer.toString());
+            redPaperRuleMapper.updateByPrimaryKey(redPaperRule);
+        }
+    }
+
+    public Map<String, Object> distribList(DistribListDto distribListDto) {
+        PageHelper.startPage(distribListDto.getPage(), distribListDto.getLimit());
+        if(StrUtil.isNotEmpty(distribListDto.getQueryCol())){
+            String decode = StringUtils.encode(distribListDto.getQueryCol());
+            distribListDto.setName(decode);
+            distribListDto.setPhone(distribListDto.getQueryCol());
+        }
+        List<DistribListVo> distribListVos = accountMapper.selectDsitribListByQueryCol(distribListDto);
+        if(CollUtil.isNotEmpty(distribListVos)){
+            for(DistribListVo distribListVo : distribListVos){
+                String nickname = distribListVo.getNickname();
+                String decode = StringUtils.decode(nickname);
+                distribListVo.setNickname(decode);
+            }
+        }
+        PageInfo<DistribListVo> pageInfo = new PageInfo<>(distribListVos);
+        Map<String, Object> data = new HashMap<>();
+        int count = Convert.toInt(pageInfo.getTotal());
+        data.put("data", distribListVos);
+        data.put("count", count);
+        data.put("code", 0);
+        return data;
+    }
+
+    public void adddistrib(AdddistribDto model) {
+        String id = model.getId();
+        AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id);
+        accountInfo.setIsHead(1);
+        accountMapper.updateByPrimaryKey(accountInfo);
+    }
+
+    public Map<String, Object> distribInfoList(DistribInfoListDto distribInfoListDto) {
+        PageHelper.startPage(distribInfoListDto.getPage(), distribInfoListDto.getLimit());
+        if(StrUtil.isNotEmpty(distribInfoListDto.getName())){
+            String decode = StringUtils.encode(distribInfoListDto.getName());
+            distribInfoListDto.setName(decode);
+        }
+        List<DistribInfoListVo> distribInfoListVos = accountMapper.selectDsitribInfoListByQueryCol(distribInfoListDto);
+        if(CollUtil.isNotEmpty(distribInfoListVos)){
+            for(DistribInfoListVo distribInfoListVo : distribInfoListVos){
+                String nickname = distribInfoListVo.getNickname();
+                String decode = StringUtils.decode(nickname);
+                distribInfoListVo.setNickname(decode);
+            }
+        }
+        PageInfo<DistribInfoListVo> pageInfo = new PageInfo<>(distribInfoListVos);
+        Map<String, Object> data = new HashMap<>();
+        int count = Convert.toInt(pageInfo.getTotal());
+        data.put("data", distribInfoListVos);
+        data.put("count", count);
+        data.put("code", 0);
+        return data;
+
+    }
+
+    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);
+    }
+
+    public Map<String, Object> userHeadInfoList(UserHeadInfoListDto userHeadInfoListDto) {
+        String id = userHeadInfoListDto.getId();
+        AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id);
+        String userId = accountInfo.getUserId();
+        PageHelper.startPage(userHeadInfoListDto.getPage(), userHeadInfoListDto.getLimit());
+        List<UserHeadInfoVo> userHeadInfoVos = accountMapper.selectUserHeadInfoByAccountId(userId);
+        if(CollUtil.isNotEmpty(userHeadInfoVos)){
+            for(UserHeadInfoVo userHeadInfoVo : userHeadInfoVos){
+                String nickname = userHeadInfoVo.getNickname();
+                String decode = StringUtils.decode(nickname);
+                userHeadInfoVo.setNickname(decode);
+            }
+        }
+        PageInfo<UserHeadInfoVo> pageInfo = new PageInfo<>(userHeadInfoVos);
+        Map<String, Object> data = new HashMap<>();
+        int count = Convert.toInt(pageInfo.getTotal());
+        data.put("data", userHeadInfoVos);
+        data.put("count", count);
+        data.put("code", 0);
+        return data;
+    }
+
+    public Map<String, Object> orderItemsList(UserHeadInfoListDto userHeadInfoListDto) {
+        String id = userHeadInfoListDto.getId();
+        AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id);
+        String userId = accountInfo.getUserId();
+        PageHelper.startPage(userHeadInfoListDto.getPage(), userHeadInfoListDto.getLimit());
+        List<OrderItemsVo> orderItemsVos = accountMapper.selectOrderItemsByUserId(userId);
+        if(CollUtil.isNotEmpty(orderItemsVos)){
+            for(OrderItemsVo orderItemsVo : orderItemsVos){
+                if(ObjectUtil.isNotEmpty(orderItemsVo)){
+                    Long orderId = orderItemsVo.getOrderId();
+                    List<JhyOrderItems> jhyOrderItems = accountMapper.selectOrderById(orderId);
+                    if(CollUtil.isNotEmpty(jhyOrderItems)){
+                        orderItemsVo.setOrderItems(jhyOrderItems);
+                    }
+                }
+            }
+        }
+        PageInfo<OrderItemsVo> pageInfo = new PageInfo<>(orderItemsVos);
+        Map<String, Object> data = new HashMap<>();
+        int count = Convert.toInt(pageInfo.getTotal());
+        data.put("data", orderItemsVos);
+        data.put("count", count);
+        data.put("code", 0);
+        return data;
+    }
+
+    public void prohibitDistrib(ProhibitDistribDto model) {
+        Integer status = model.getStatus();
+        String id = model.getId();
+        AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id);
+        accountInfo.setIsProhibit(status.toString());
+        accountMapper.updateByPrimaryKey(accountInfo);
+    }
+
+
+    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);
+                    distribDataListVo.setKg(kg);
+                    String jdsl = accountMapper.selectJDSLByHeadUserId(id);
+                    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 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.selectOrderByHeadUserId(id);
+                    distribDataListVo.setKg(kg);
+                    String jdsl = accountMapper.selectJDSLByHeadUserId(id);
+                    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;
+    }
+
 }

--
Gitblit v1.9.1