From df864d1d636751424fd642d3bdd33c53cf63500d Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 07 Jul 2025 17:51:09 +0800
Subject: [PATCH] feat(mall): 为活动订单项添加积分和成长值奖 - 在活动添加和编辑页面增加积分和成长值输入字段 - 更新活动实体类,添加 scoreCnt 和 growthCnt 字段 - 修改活动订单项处理逻辑,增加积分和成长值奖励的计算和发放 - 优化活动订单项状态检查逻辑,移除冗余代码

---
 src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java |   36 +++++++++++++++++++++++++++++++++++-
 1 files changed, 35 insertions(+), 1 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java
index 60447a8..e82887b 100644
--- a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java
@@ -276,6 +276,7 @@
             mallMemberCouponMapper.insert(memberCoupon);
 
             record.setReceiveName(coupon.getName());
+            record.setStatus(1);
         }
 
         mallVipBenefitsRecordMapper.insert(record);
@@ -314,8 +315,41 @@
             return new HashMap<>();
         }
 
+        List<String> ids = new ArrayList<>();
+        benefits.forEach(item -> {
+            ids.addAll(item.getDetails().stream().filter(detail -> detail.getLinkType() == 2 || detail.getLinkType() == 3).map(MallVipBenefitsDetails::getContent).collect(Collectors.toList()));
+        });
+
+        LambdaQueryWrapper<MallVipBenefitsRecord> recordQuery = new LambdaQueryWrapper<>();
+        recordQuery.in(MallVipBenefitsRecord::getReceiveId, ids)
+                .eq(MallVipBenefitsRecord::getMemberId, member.getId())
+                .ge(MallVipBenefitsRecord::getReceiveTime, DateUtil.beginOfDay(new Date()))
+                .le(MallVipBenefitsRecord::getReceiveTime, DateUtil.endOfDay(new Date()));
+        List<MallVipBenefitsRecord> hasRecieveList = mallVipBenefitsRecordMapper.selectList(recordQuery);
+
         Map<String, Object> map = new HashMap<>();
-        map.put("benefit", benefits.get(0));
+        if (CollUtil.isEmpty(hasRecieveList)) {
+            map.put("benefit", benefits.get(0));
+            return map;
+        }
+
+        List<Long> hasIds = hasRecieveList.stream().map(MallVipBenefitsRecord::getReceiveId).collect(Collectors.toList());
+        List<MallVipBenefits> collect1 = benefits.stream().peek(item -> {
+            List<MallVipBenefitsDetails> collect = item.getDetails().stream().filter(detail -> (detail.getLinkType() == 2 || detail.getLinkType() == 3) && !hasIds.contains(Long.parseLong(detail.getContent()))).collect(Collectors.toList());
+            item.setDetails(collect);
+        }).filter(item -> CollUtil.isNotEmpty(item.getDetails())).collect(Collectors.toList());
+
+        if (CollUtil.isEmpty(collect1)) {
+            return map;
+        }
+
+        map.put("benefit", collect1.get(0));
         return map;
     }
+
+    @Override
+    public IPage<MallVipBenefitsRecord> findVipBenefitsInPage(MallVipBenefitsRecord record, QueryRequest request) {
+        Page<MallVipBenefitsRecord> page = new Page<>(request.getPageNum(), request.getPageSize());
+        return mallVipBenefitsRecordMapper.selectMemberBenefitsRecordInPage(record, page);
+    }
 }

--
Gitblit v1.9.1