From 32169b0b5af53ae87ccde57c31c1d6ad6e44a055 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 14 Jul 2021 16:51:32 +0800
Subject: [PATCH] Merge branch 'score-shop' of http://120.27.238.55:7000/r/xzx into score-shop

---
 gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java |  160 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 159 insertions(+), 1 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 ee9cedf..766ea84 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,18 +1,50 @@
 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.common.utils.StringUtils;
+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.user.dto.HeadProfitLitDto;
+import com.xzx.gc.user.dto.HeadTeamDto;
+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.dto.AdddistribDto;
+import com.xzx.gc.user.dto.DistribInfoListDto;
+import com.xzx.gc.user.dto.DistribListDto;
+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.*;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import com.xzx.gc.entity.RedPaperRule;
 import com.xzx.gc.model.JsonResult;
 import com.xzx.gc.user.dto.UpdateSettingDto;
 import com.xzx.gc.user.mapper.RedPaperRuleMapper;
-import com.xzx.gc.user.vo.ViewSettingVo;
+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;
 
 @Service
 @Transactional
@@ -20,6 +52,16 @@
 
     @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(String ruleStr) {
         ViewSettingVo viewSettingVo = new ViewSettingVo();
@@ -58,6 +100,67 @@
             }
         }
         return viewSettingVo;
+    }
+
+
+    public void join(String headId, String userId) {
+        AccountInfo headInfo = accountMapper.selectOneByUserId(headId);
+        if (AccountInfo.IS_HEAD_N.equals(headInfo.getIsHead())) {
+            throw new RestException(-3, "不是团长");
+        }
+
+        if (AccountInfo.IS_PROHIBIT_Y.equals(headInfo.getIsProhibit())) {
+            throw new RestException(-3, "该用户被冻结");
+        }
+
+        UserHeadRelate existHeadRelate = userHeadRelateMapper.selectMemberByUserId(userId);
+        if (existHeadRelate != null) {
+            throw new RestException(-3, "已加入其他团队");
+        }
+
+        AccountInfo accountInfo = accountMapper.selectOneByUserId(userId);
+        UserShareInfo userShareInfo = userShareInfoMapper.selectByRegistPhone(accountInfo.getAccountName());
+        if (userShareInfo != null) {
+            throw new RestException(-3, "您已与推广员绑定, 无法加入");
+        }
+
+        UserHeadRelate userHeadRelate = new UserHeadRelate();
+        userHeadRelate.setHeadUserId(headId);
+        userHeadRelate.setUserId(userId);
+        userHeadRelate.setScore(BigDecimal.ZERO);
+        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.setMobilePhone(accountInfo.getAccountName());
+        sysMessage.setMessageType("4");
+        sysMessage.setMessage("手机号:" + accountInfo.getAccountName() + "的用户, 成功加入您的团队");
+        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) {
@@ -104,4 +207,59 @@
             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;
+
+    }
 }

--
Gitblit v1.9.1