From 575411c3f1abc10184ee2c1b416241246f943226 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 03 Jan 2025 10:35:58 +0800
Subject: [PATCH] refactor(mall): 修改购买 VIP 接口名称

---
 src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java |   25 ++++++++++++++++++-------
 1 files changed, 18 insertions(+), 7 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
index 8e464dd..0324149 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
@@ -857,24 +857,28 @@
         }
         //获取节点设置
         List<RunNodeSet> runNodeSets = runNodeSetMapper.selectList(null);
-        BigDecimal balanceToCoin = new BigDecimal(
-                dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
-                        RunVipDataDictionaryEnum.RUN_VIP_BALANCE_TO_COIN.getType(),
-                        RunVipDataDictionaryEnum.RUN_VIP_BALANCE_TO_COIN.getCode()).getValue()
-        ).setScale(2, BigDecimal.ROUND_DOWN);
+
+        //获取节点设置runNodeSets中orderNumber最小的节点
+        RunNodeSet minRunNodeSet = runNodeSets.stream().min(Comparator.comparingInt(RunNodeSet::getOrderNumber)).orElse(null);
+        if(null == minRunNodeSet){
+            return;
+        }
 
         DateTime endTime = DateUtil.date();
         for (MallMember item : mallMembers) {
             //获取总业绩
             BigDecimal achieve = getDirectAchieve(item.getInviteId(),item.getDirectorTime(),endTime);
-            if(BigDecimal.ZERO.compareTo(achieve) >= 0){
+            //判断总业绩是否小于最小业绩
+            if(minRunNodeSet.getMinAchieve().compareTo(achieve) > 0){
+                item.setDirector(YesOrNoEnum.NO.getValue());
+                mallMemberMapper.updateById(item);
                 continue;
             }
             BigDecimal nodePercent = getNodePercent(runNodeSets, achieve);
             if(BigDecimal.ZERO.compareTo(nodePercent) >= 0){
                 continue;
             }
-            asyncService.releaseNodeCoin(achieve,nodePercent,balanceToCoin,item.getId());
+            asyncService.releaseNodeCoin(achieve,nodePercent,item.getId());
             item.setDirectorTime(endTime);
             mallMemberMapper.updateById(item);
         }
@@ -920,6 +924,9 @@
                 new LambdaQueryWrapper<MallMember>()
                         .eq(MallMember::getReferrerId, inviteId)
         );
+        if(CollUtil.isEmpty(directMembers)){
+            return memberIds;
+        }
         memberIds.addAll(directMembers.stream().map(MallMember::getId).collect(Collectors.toSet()));
 
         // 获取团队成员
@@ -927,6 +934,10 @@
                 new LambdaQueryWrapper<MallMember>()
                         .in(MallMember::getReferrerId, directMembers.stream().map(MallMember::getInviteId).collect(Collectors.toSet()))
         );
+
+        if(CollUtil.isEmpty(teamMembers)){
+            return memberIds;
+        }
         memberIds.addAll(teamMembers.stream().map(MallMember::getId).collect(Collectors.toSet()));
 
         return memberIds;

--
Gitblit v1.9.1