From ba02a14fb6b9144bd28dbb1acc8525c058312a8e Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Mon, 08 Apr 2024 16:45:55 +0800
Subject: [PATCH] 文件上传

---
 src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java |   59 +++++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 49 insertions(+), 10 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 ed529c1..60447a8 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
@@ -37,9 +37,8 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
-import java.util.Date;
-import java.util.List;
-import java.util.Objects;
+import java.util.*;
+import java.util.stream.Collectors;
 
 @Slf4j
 @Service
@@ -76,15 +75,17 @@
             return;
         }
 
-        if (CollUtil.isEmpty(mallVipBenefits.getDetails())) {
-            throw new FebsException("权益明细不能为空");
-        }
+//        if (CollUtil.isEmpty(mallVipBenefits.getDetails())) {
+//            throw new FebsException("权益明细不能为空");
+//        }
 
         this.baseMapper.insert(mallVipBenefits);
 
-        mallVipBenefits.getDetails().forEach(item -> {
-            item.setBenefitsId(mallVipBenefits.getId());
-        });
+        if (CollUtil.isNotEmpty(mallVipBenefits.getDetails())) {
+            mallVipBenefits.getDetails().forEach(item -> {
+                item.setBenefitsId(mallVipBenefits.getId());
+            });
+        }
         this.mallVipBenefitsDetailsService.saveBatch(mallVipBenefits.getDetails());
     }
 
@@ -170,7 +171,7 @@
         recordQuery.ge(MallVipBenefitsRecord::getReceiveTime, DateUtil.beginOfDay(new Date()))
                 .le(MallVipBenefitsRecord::getReceiveTime, DateUtil.endOfDay(new Date()))
                 .eq(MallVipBenefitsRecord::getMemberId, member.getId())
-                .eq(MallVipBenefitsRecord::getBenefitsType, vipBenefits.getType())
+                .eq(MallVipBenefitsRecord::getBenefitsType, vipBenefits.getGainType())
                 .eq(MallVipBenefitsRecord::getReceiveId, Long.parseLong(benefits.getContent()));
         List<MallVipBenefitsRecord> mallVipBenefitsRecords = mallVipBenefitsRecordMapper.selectList(recordQuery);
         if (CollUtil.isNotEmpty(mallVipBenefitsRecords)) {
@@ -269,6 +270,7 @@
             memberCoupon.setInviteId(member.getInviteId());
             memberCoupon.setCouponUuid(IdUtil.simpleUUID());
             memberCoupon.setState(1);
+            memberCoupon.setFromType(2);
             memberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(), coupon.getExpireDay()));
             memberCoupon.setMemberId(member.getId());
             mallMemberCouponMapper.insert(memberCoupon);
@@ -279,4 +281,41 @@
         mallVipBenefitsRecordMapper.insert(record);
     }
 
+    @Override
+    public void switchBenefitsShow(Long id) {
+        MallVipBenefits vipBenefits = this.baseMapper.selectById(id);
+
+        MallVipBenefits update = new MallVipBenefits();
+        if (vipBenefits.getIsShow() == 1) {
+            update.setIsShow(2);
+        } else {
+            update.setIsShow(1);
+        }
+
+        update.setId(vipBenefits.getId());
+        this.baseMapper.updateById(update);
+    }
+
+    @Override
+    public Map<String, Object> birthdayEvent() {
+        MallMember loginUser = LoginUserUtil.getLoginUser();
+        MallMember member = this.mallMemberMapper.selectById(loginUser.getId());
+
+        String today = DateUtil.format(new Date(), DatePattern.NORM_DATE_PATTERN);
+        boolean isBirthday = member.getBirthday().compareTo(DateUtil.parseDate(today)) == 0;
+        if (!isBirthday) {
+            return new HashMap<>();
+        }
+
+        MallVipConfig configList = mallVipConfigMapper.selectVipConfigByCode(member.getLevel());
+
+        List<MallVipBenefits> benefits = configList.getBenefits().stream().filter(item -> item.getGainType() == 2 && item.getType() != 1).collect(Collectors.toList());
+        if (CollUtil.isEmpty(benefits)) {
+            return new HashMap<>();
+        }
+
+        Map<String, Object> map = new HashMap<>();
+        map.put("benefit", benefits.get(0));
+        return map;
+    }
 }

--
Gitblit v1.9.1