From bf9a238e4b6db75c28ee9efae265f36f33301d83 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 15 Jul 2021 16:15:04 +0800
Subject: [PATCH] 202107015
---
gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java | 286 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 277 insertions(+), 9 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..a2078b6 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,41 +1,95 @@
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 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
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(5))?0:Integer.parseInt(shareRatios.get(5)));
+ 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;
}
@@ -65,16 +119,230 @@
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.setMessageSubTypeName("团队消息");
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) {
+ 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,finish_order_num,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,finish_order_num,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) {
+ //获取团长基本信息
+ 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) {
+ 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 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();
+ }
}
--
Gitblit v1.9.1