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