From 90c31b4e2be82bd9a47115e939a9ad103271fbfa Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Fri, 26 Jan 2024 22:12:40 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java |   96 ++++++++++++++++++++++++-----------------------
 1 files changed, 49 insertions(+), 47 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
index c62a9f9..baf88ea 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/impl/VipCommonServiceImpl.java
@@ -85,59 +85,61 @@
             return;
         }
 
-        LambdaQueryWrapper<MallVipConfig> configQuery = new LambdaQueryWrapper<>();
-        configQuery.gt(MallVipConfig::getLevel, config.getLevel())
-                .orderByAsc(MallVipConfig::getLevel)
-                .last("limit 1");
-        MallVipConfig nextLevel = mallVipConfigMapper.selectOne(configQuery);
+//        LambdaQueryWrapper<MallVipConfig> configQuery = new LambdaQueryWrapper<>();
+//        configQuery.gt(MallVipConfig::getLevel, config.getLevel())
+//                .orderByAsc(MallVipConfig::getLevel)
+//                .last("limit 1");
+//        MallVipConfig nextLevel = mallVipConfigMapper.selectOne(configQuery);
 
-        // 指定商品
-        if (nextLevel.getType() == 1) {
-            boolean hasMatch = mallOrderInfo.getItems().stream().anyMatch(item -> {
-                return item.getGoodsId().equals(nextLevel.getTargetId());
-            });
+        List<MallVipConfig> configs = mallVipConfigMapper.selectVipConfigList();
 
-            if (!hasMatch) {
-                log.info("未购买指定商品");
-                return;
+        String nextLevelCode = "";
+        for (MallVipConfig nextLevel : configs) {
+            if (config.getLevel() >= nextLevel.getLevel()) {
+                continue;
             }
 
-            MallMember update = new MallMember();
-            update.setId(member.getId());
-            update.setLevel(nextLevel.getCode());
-            mallMemberMapper.updateById(update);
-            return;
+            // 指定商品
+            if (nextLevel.getType() == 1) {
+                boolean hasMatch = mallOrderInfo.getItems().stream().anyMatch(item -> {
+                    return item.getGoodsId().equals(nextLevel.getTargetId());
+                });
+
+                if (hasMatch) {
+                    nextLevelCode = nextLevel.getCode();
+                    continue;
+                }
+            }
+
+            // 时间区间内金额
+            if (nextLevel.getType() == 2) {
+                Date endTime = DateUtil.endOfDay(new Date());
+                Date startTime = getStartTime(nextLevel.getValidType());
+
+                LambdaQueryWrapper<MallOrderInfo> query = new LambdaQueryWrapper<>();
+                query.ge(MallOrderInfo::getReceivingTime, startTime)
+                        .le(MallOrderInfo::getReceivingTime, endTime)
+                        .eq(MallOrderInfo::getStatus, 4)
+                        .eq(MallOrderInfo::getMemberId, member.getId());
+                List<MallOrderInfo> orderList = mallOrderInfoMapper.selectList(query);
+                if (CollUtil.isEmpty(orderList)) {
+                    continue;
+                }
+
+                double totalAmount = orderList.stream().mapToDouble(item -> {
+                    return item.getAmount().doubleValue();
+                }).sum();
+
+                if (nextLevel.getAmount().compareTo(BigDecimal.valueOf(totalAmount)) <= 0) {
+                    nextLevelCode = nextLevel.getCode();
+                }
+            }
         }
 
-        //
-        if (nextLevel.getType() == 2) {
-            Date endTime = DateUtil.endOfDay(new Date());
-            Date startTime = getStartTime(nextLevel.getValidType());
-
-            LambdaQueryWrapper<MallOrderInfo> query = new LambdaQueryWrapper<>();
-            query.ge(MallOrderInfo::getReceivingTime, startTime)
-                   .le(MallOrderInfo::getReceivingTime, endTime)
-                   .eq(MallOrderInfo::getStatus, 4)
-                    .eq(MallOrderInfo::getMemberId, member.getId());
-            List<MallOrderInfo> orderList = mallOrderInfoMapper.selectList(query);
-            if (CollUtil.isEmpty(orderList)) {
-                return;
-            }
-
-            double totalAmount = orderList.stream().mapToDouble(item -> {
-                return item.getAmount().doubleValue();
-            }).sum();
-
-            if (nextLevel.getAmount().compareTo(BigDecimal.valueOf(totalAmount)) > 0) {
-                log.info("未达到指定金额:{}, {}", nextLevel.getAmount(), totalAmount);
-                return;
-            }
-
-            MallMember update = new MallMember();
-            update.setId(member.getId());
-            update.setLevel(nextLevel.getCode());
-            mallMemberMapper.updateById(update);
-        }
+        MallMember update = new MallMember();
+        update.setId(member.getId());
+        update.setLevel(nextLevelCode);
+        mallMemberMapper.updateById(update);
     }
 
     private Date getStartTime(String type) {

--
Gitblit v1.9.1