From ae1471f378f399f76518539ec8992e64a3673436 Mon Sep 17 00:00:00 2001
From: 陶杰 <1378534974@qq.com>
Date: 星期三, 08 一月 2025 15:26:06 +0800
Subject: [PATCH] 1.订单提交:订单最小金额配置

---
 src/main/java/com/mzl/flower/service/menber/impl/MemberServiceImpl.java |   46 +++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 39 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/mzl/flower/service/menber/impl/MemberServiceImpl.java b/src/main/java/com/mzl/flower/service/menber/impl/MemberServiceImpl.java
index 16fcf32..269e418 100644
--- a/src/main/java/com/mzl/flower/service/menber/impl/MemberServiceImpl.java
+++ b/src/main/java/com/mzl/flower/service/menber/impl/MemberServiceImpl.java
@@ -9,13 +9,16 @@
 import com.mzl.flower.dto.request.menber.MemberQueryDTO;
 import com.mzl.flower.dto.response.member.MemberVO;
 import com.mzl.flower.entity.menber.Member;
+import com.mzl.flower.entity.system.User;
 import com.mzl.flower.mapper.customer.CustomerMapper;
 import com.mzl.flower.mapper.member.MemberMapper;
 import com.mzl.flower.service.menber.MemberService;
+import com.mzl.flower.service.system.UserService;
 import lombok.RequiredArgsConstructor;
 import org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.CollectionUtils;
 import org.springframework.util.ObjectUtils;
 import org.springframework.util.StringUtils;
 
@@ -38,16 +41,18 @@
 
     private final CustomerMapper customerMapper;
 
+    private final UserService  userService;
+
     @Override
     public void saveMember(MemberDTO memberDTO) {
         //是否已经存在endpoint已经有最大值了,有的话需要删除或者修改
         if (memberDTO.getEndPoint() == null) {
-            Member pointByIntegerMaxValue = memberMapper.getEndPointByIntegerMaxValue(Integer.MAX_VALUE);
-            if (!ObjectUtils.isEmpty(pointByIntegerMaxValue)) {
-                throw new ValidationException("系统中已经有一条最大值或者空值记录,请删除或者修改再保存");
-            } else {
+//            Member pointByIntegerMaxValue = memberMapper.getEndPointByIntegerMaxValue(Integer.MAX_VALUE);
+//            if (!ObjectUtils.isEmpty(pointByIntegerMaxValue)) {
+//                throw new ValidationException("系统中已经有一条最大值或者空值记录,请删除或者修改再保存");
+//            } else {
                 memberDTO.setEndPoint(Integer.MAX_VALUE);
-            }
+//            }
         }
         if (StringUtils.isEmpty(memberDTO.getName())) {
             throw new ValidationException("会员等级名称不能为空");
@@ -76,6 +81,14 @@
                 throw new ValidationException("会员折扣百分比不能大于100");
             }
         }
+        //区间交集判断
+        //查询所有等级
+        List<Member> allMember = memberMapper.getAllMember();
+        allMember.forEach(a -> {
+            if (a.getStartPoint() < memberDTO.getEndPoint() && a.getEndPoint() > memberDTO.getStartPoint()) {
+                throw new ValidationException("存在交集,不允许保存");
+            }
+        });
         if (!StringUtils.isEmpty(memberDTO.getDiscountAmount())) {
             int discountAmount = memberDTO.getDiscountAmount().compareTo(BigDecimal.ZERO);
             if (discountAmount == -1) {
@@ -93,7 +106,7 @@
         member.create(SecurityUtils.getUserId());
         memberMapper.insert(member);
         //更新会员等级
-        customerMapper.updateMemberLevelByPoint(member.getId(), member.getStartPoint(), member.getEndPoint());
+        customerMapper.updateMemberLevelByPoint(member.getId(), memberDTO.getStartPoint(), memberDTO.getEndPoint());
 
     }
 
@@ -163,9 +176,18 @@
         if (memberDTO.getStartPoint() > memberDTO.getEndPoint()) {
             throw new ValidationException("成长点开始不能大于结束");
         }
+        //区间交集判断
+        //查询所有等级
+        List<Member> allMember = memberMapper.getOtherAllMember(memberDTO.getId());
+        allMember.forEach(a -> {
+            if (a.getStartPoint() < memberDTO.getEndPoint() && a.getEndPoint() > memberDTO.getStartPoint()) {
+                throw new ValidationException("存在交集,不允许修改");
+            }
+        });
+
         //更新会员等级
         if (memberInfo.getStartPoint() != memberDTO.getStartPoint() || memberInfo.getEndPoint() != memberDTO.getEndPoint()) {
-            customerMapper.updateMemberLevelByPoint(memberInfo.getId(), memberInfo.getStartPoint(), memberInfo.getEndPoint());
+            customerMapper.updateMemberLevelByPoint(memberInfo.getId(), memberDTO.getStartPoint(), memberDTO.getEndPoint());
         }
 
         BeanUtils.copyProperties(memberDTO,memberInfo);
@@ -193,6 +215,16 @@
     @Override
     public Page<MemberVO> queryPage(MemberQueryDTO memberQueryDTO, Page page) {
         List<MemberVO> list = memberMapper.queryPage(memberQueryDTO, page);
+        if(!CollectionUtils.isEmpty(list)){
+            list.forEach(l->{
+                if (!StringUtils.isEmpty(l.getUpdateBy())) {
+                    User userById = userService.getUserById(l.getUpdateBy());
+                    if(!ObjectUtils.isEmpty(userById)){
+                        l.setCreateName(userById.getNickName());
+                    }
+                }
+            });
+        }
         page.setRecords(list);
         return page;
     }

--
Gitblit v1.9.3