From 0bb46a371b4767c817653bb3af2da0bcd7349471 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 23 Feb 2024 14:41:42 +0800
Subject: [PATCH] 抽奖

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |   70 ++++++++++++++++++++++++++++------
 1 files changed, 57 insertions(+), 13 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 7bdf4dd..bfe07d6 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
@@ -891,8 +891,24 @@
                     /**
                      * 用户的账户增加对应的收益
                      */
+
+                    BigDecimal totalPerk = mallProductBuy.getTotalPerk();
+                    if(BigDecimal.ZERO.compareTo(totalPerk) >= 0){
+                        mallProductBuy.setTotalPerk(BigDecimal.ZERO);
+                        mallProductBuyMapper.updateById(mallProductBuy);
+                        continue;
+                    }
                     BigDecimal nftTotal = mallProductBuy.getNftTotal();
                     BigDecimal profit = nftTotal.multiply(profitPercent.multiply(new BigDecimal(0.01)));
+
+                    if(totalPerk.compareTo(profit) <= 0){
+                        profit = totalPerk;
+                        mallProductBuy.setTotalPerk(BigDecimal.ZERO);
+                        mallProductBuyMapper.updateById(mallProductBuy);
+                    }else{
+                        mallProductBuy.setTotalPerk(totalPerk.subtract(profit).setScale(2,BigDecimal.ROUND_DOWN));
+                        mallProductBuyMapper.updateById(mallProductBuy);
+                    }
 //                    insertSell(mallProductBuy.getMemberId(),profit,profit,BigDecimal.ZERO,BigDecimal.ZERO);
                     String orderNoSY = MallUtils.getOrderNum("SYNFT");
                     mallMoneyFlowService.addMoneyFlow(
@@ -908,6 +924,7 @@
                     MallMemberAmount mallMemberAmountMine = mallMemberAmountMapper.selectByMemberId(mallProductBuy.getMemberId());
                     mallMemberAmountMine.setTrendsNft(mallMemberAmountMine.getTrendsNft().add(profit));
                     mallMemberAmountMapper.updateTrendsNftById(mallMemberAmountMine);
+
 
                     BigDecimal remainderDirect = bigDecimal.divide(new BigDecimal(String.valueOf(cycle)),0,BigDecimal.ROUND_DOWN);//取余
                     if(remainderDirect.compareTo(BigDecimal.ONE) == 0){
@@ -1402,8 +1419,13 @@
             //上级
             String referrerId = mallMember.getReferrerId();
             MallMember mallMemberRef = memberMapper.selectInfoByInviteId(referrerId);
+            if(ObjectUtil.isEmpty(mallMemberRef)){
+                continue;
+            }
             List<MallMember> mallMembersAll = memberMapper.selectAllChildAgentListByInviteId(referrerId);
-
+            if(ObjectUtil.isEmpty(mallMembersAll)){
+                continue;
+            }
             List<MallMember> mallMembers = memberMapper.selectByRefererId(referrerId);
             Set<Long> mallMembersSet = mallMembers.stream().map(MallMember::getId).collect(Collectors.toSet());
             mallMembersSet.retainAll(collect);
@@ -1428,20 +1450,42 @@
                 TeamPerkDto teamPerkDto = JSONObject.parseObject(levelDic.getValue(), TeamPerkDto.class);
                 Integer directCntLevel = teamPerkDto.getDirectCnt();
                 Integer teamCnt = teamPerkDto.getTeamCnt();
-                if(directCntLevel >= intersection.size() &&
-                        teamCnt >= mallMembersAll.size()){
-                    mallMemberRef.setLevel(level);
-                    memberMapper.updateById(mallMemberRef);
+                if(directCntLevel <= intersection.size()){
+                    if(teamCnt <= mallMembersAll.size()){
+                        mallMemberRef.setLevel(level);
+                        memberMapper.updateById(mallMemberRef);
+
+                        String nextLevel = MemberLevelNewEnum.ZERO_LEVEL.getNextLevel(level);
+                        level = nextLevel;
+                        if(level.equals(MemberLevelNewEnum.WU_LEVEL.getType()) &&
+                                nextLevel.equals(MemberLevelNewEnum.WU_LEVEL.getType()) ){
+                            mallMemberRef.setLevel(level);
+                            memberMapper.updateById(mallMemberRef);
+                            flag = true;
+                        }
+                    }else{
+                        flag = true;
+                    }
+                }else{
                     flag = true;
                 }
-                String nextLevel = MemberLevelNewEnum.ZERO_LEVEL.getNextLevel(level);
-                level = nextLevel;
-                if(level.equals(MemberLevelNewEnum.WU_LEVEL.getType()) &&
-                        nextLevel.equals(MemberLevelNewEnum.WU_LEVEL.getType()) ){
-                    mallMemberRef.setLevel(level);
-                    memberMapper.updateById(mallMemberRef);
-                    flag = true;
-                }
+            }
+        }
+    }
+
+    @Override
+    public void memberLevelDown() {
+        List<MallProductBuy> mallProductBuys = mallProductBuyMapper.selectTotalPerk();
+        if(CollUtil.isEmpty(mallProductBuys)){
+            return;
+        }
+        for(MallProductBuy mallProductBuy : mallProductBuys){
+            BigDecimal totalPerk = mallProductBuy.getTotalPerk();
+            if(BigDecimal.ZERO.compareTo(totalPerk) >= 0 ){
+                Long memberId = mallProductBuy.getMemberId();
+                MallMember mallMember = memberMapper.selectById(memberId);
+                mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.getCode());
+                memberMapper.updateById(mallMember);
             }
         }
     }

--
Gitblit v1.9.1