From c8553669f87a7bc4df3b2279ad4473b6b212a127 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 15 Mar 2023 14:46:42 +0800
Subject: [PATCH] 后台修改

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |   76 +++++++++----------------------------
 1 files changed, 19 insertions(+), 57 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
index e253eae..11214b8 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
@@ -59,18 +59,20 @@
         List<String> ids = StrUtil.split(member.getReferrerIds(), ',');
         List<MallMember> parentMembers = memberMapper.selectByInviteIds(ids);
         for (MallMember parent : parentMembers) {
-            // 未激活用户无法升级
+            // 没有购买套餐无法升级合伙人等级
             if (AgentLevelEnum.ZERO_LEVEL.name().equals(member.getLevel())) {
                 continue;
             }
-
-            DataDictionaryCustom nextLevel = dataDictionaryCustomMapper.selectNextAgentLevelInfo(parent.getLevel());
-            if (nextLevel == null) {
+            //合伙人的下一个层级
+            String parentLevel = parent.getLevel();
+            String nextLevel = MemberLevelEnum.SECOND_LEVEL.getNextLevel(parentLevel);
+            if (parentLevel.equals(nextLevel)) {
                 log.info("当前层级无下一级:{}", parent.getLevel());
                 continue;
             }
 
-            AgentInfo agentInfo = JSONObject.parseObject(nextLevel.getValue(), AgentInfo.class);
+            DataDictionaryCustom nextLevelDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode("AGENT_LEVEL_REQUIRE", nextLevel);
+            AgentInfo agentInfo = JSONObject.parseObject(nextLevelDic.getValue(), AgentInfo.class);
             if (!directMemberCnt(parent, agentInfo)) {
                 continue;
             }
@@ -83,7 +85,7 @@
                 continue;
             }
 
-            parent.setLevel(nextLevel.getCode());
+            parent.setLevel(nextLevel);
             memberMapper.updateById(parent);
         }
     }
@@ -104,7 +106,7 @@
             return true;
         }
 
-        log.info("用户:{}直推数量未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), childs.size(), agentInfo.getLastAgentCnt());
+        log.info("用户:{}直推数量未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), childs.size(), agentInfo.getDirectCnt());
         return false;
     }
 
@@ -142,20 +144,24 @@
     }
 
     /**
-     * 团队业绩是否达标
+     * 团队贡献点是否达标
      *
      * @param agentInfo
      * @return
      */
     private boolean teamIncome(MallMember member, AgentInfo agentInfo) {
-        BigDecimal totalIncome = memberMapper.selectAchieveByMemberId(member.getInviteId(), 2);
 
-        BigDecimal targetIncome = agentInfo.getTeamIncome().multiply(new BigDecimal("10000"));
-        if (totalIncome.compareTo(targetIncome) >= 0) {
+        List<MallMember> mallMembers = memberMapper.selectAllChildAgentListByInviteId(member.getInviteId());
+        List<Long> ids = mallMembers.stream().map(MallMember::getId).collect(Collectors.toList());
+        List<MallMemberWallet> mallMemberWallets = mallMemberWalletMapper.selectMemberWalletsByIds(ids);
+
+        int starSum = mallMemberWallets.stream().mapToInt(MallMemberWallet::getStar).sum();
+        BigDecimal teamIncome = agentInfo.getTeamIncome();
+        if (teamIncome.compareTo(new BigDecimal(starSum)) <= 0) {
             return true;
         }
 
-        log.info("用户:{}团队业绩未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), totalIncome, targetIncome);
+        log.info("用户:{}团队贡献点未达标, 当前等级:{}, 当前数量:{}, 目标数量:{}", member.getPhone(), member.getLevel(), starSum, teamIncome);
         return false;
     }
 
@@ -425,6 +431,7 @@
      * @param orderNo
      * @param memberId
      */
+    @Override
     public void flowTotalScoreBalance(List<MallMemberWallet> mallMemberWallets,BigDecimal amount,int flowType,String orderNo,Long memberId){
         //给当前等级的每个用户发放星级奖励
         int count = 0;
@@ -488,50 +495,5 @@
         }
     }
 
-    /**
-     * 平级奖励补贴
-     */
-    public void getPeerPerk(){
-        /**
-         * 全体用户
-         *      对象:产生了收益的用户的直属上级
-         *      条件:等级和用户等级一样
-         *      补贴:每日补贴的10%,例如用户当日的补贴总额为100,直属上级拿100*10%=10,
-         *      限制:直推收益除外。
-         */
-        //平级补贴百分比
-        DataDictionaryCustom teamEqualsPerkDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
-                DataDictionaryEnum.TEAM_EQUALS_PERK.getType(),
-                DataDictionaryEnum.TEAM_EQUALS_PERK.getCode());
-        BigDecimal teamEqualsPerkPercent = new BigDecimal(teamEqualsPerkDic.getValue()).abs().multiply(BigDecimal.valueOf(0.01));
 
-        //产生了收益的用户和直属上级
-        List<AdminTeamEqualsPerkVo> adminTeamEqualsPerkVos = mallMoneyFlowMapper.selectTeamEqualsMemberByDate(new Date());
-        if(CollUtil.isNotEmpty(adminTeamEqualsPerkVos)){
-            for(AdminTeamEqualsPerkVo adminTeamEqualsPerkVo : adminTeamEqualsPerkVos){
-                BigDecimal sumAmount = adminTeamEqualsPerkVo.getSumAmount();
-                //平级补贴
-                BigDecimal teamEqualsPerkAmount = teamEqualsPerkPercent.multiply(sumAmount).setScale(2, BigDecimal.ROUND_DOWN);
-
-                MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(adminTeamEqualsPerkVo.getRtMemberId());
-                BigDecimal totalScore = mallMemberWallet.getTotalScore();
-                if(totalScore.compareTo(teamEqualsPerkAmount) < 0){
-                    teamEqualsPerkAmount = totalScore;
-                }
-                if(BigDecimal.ZERO.compareTo(teamEqualsPerkAmount) < 0){
-                //减少补贴额度
-                mallMemberWalletMapper.reduceTotalScoreById(teamEqualsPerkAmount, mallMemberWallet.getId());
-
-                mallMemberWalletMapper.addBalanceById(teamEqualsPerkAmount, mallMemberWallet.getId());
-
-                mallMoneyFlowService.addMoneyFlow(
-                        adminTeamEqualsPerkVo.getRtMemberId(),
-                        teamEqualsPerkAmount,
-                        MoneyFlowTypeEnum.TEAM_EQUALS_PERK.getValue(),
-                        MallUtils.getOrderNum("TEP"),
-                        FlowTypeEnum.BALANCE.getValue());
-                }
-            }
-        }
-    }
 }

--
Gitblit v1.9.1