From 2c5a0e133b64bb0a46b1419c48e9b62a4779e268 Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期一, 09 十二月 2024 16:13:17 +0800
Subject: [PATCH] add: 供应商子账号

---
 src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java |   84 +++++++++++++++++++++++++++++++++++------
 1 files changed, 71 insertions(+), 13 deletions(-)

diff --git a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java
index b0d20bc..08026a8 100644
--- a/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java
+++ b/src/main/java/com/mzl/flower/web/v2/coupon/CouponTemplateActivyController.java
@@ -11,10 +11,7 @@
 import com.mzl.flower.dto.response.coupon.CouponTemplatePointVO;
 import com.mzl.flower.dto.response.coupon.CouponTemplateVO;
 import com.mzl.flower.entity.coupon.CouponTemplateDO;
-import com.mzl.flower.enums.CouponCategoryEnum;
-import com.mzl.flower.enums.CouponGetUserTypeEnum;
-import com.mzl.flower.enums.CouponTypeEnum;
-import com.mzl.flower.enums.CouponUsageTypeEnum;
+import com.mzl.flower.enums.*;
 import com.mzl.flower.service.coupon.CouponTemplateService2;
 import com.mzl.flower.utils.ConverterUtil;
 import io.swagger.annotations.Api;
@@ -27,6 +24,7 @@
 import org.springframework.web.bind.annotation.*;
 
 import java.math.BigDecimal;
+import java.time.LocalDateTime;
 
 
 /**
@@ -52,7 +50,7 @@
         CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
         BeanUtils.copyProperties(dto, couponTemplateBO);
 
-        // 设置成积分优惠券
+        // 设置成活动优惠券
         couponTemplateBO.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
         couponTemplateBO.setGetUserType(CouponGetUserTypeEnum.ALL.getType());
 
@@ -65,8 +63,10 @@
 
     @PutMapping("/{id}")
     @ApiOperation(value = "修改", notes = "修改")
-    public ResponseEntity<ReturnDataDTO> update(@Validated @RequestBody CreateCouponTemplateActivyDTO dto) {
+    public ResponseEntity<ReturnDataDTO> update(@PathVariable String id,@Validated @RequestBody CreateCouponTemplateActivyDTO dto) {
 
+        // 手动设置id值
+        dto.setId(id);
         // 信息验证
         valid(dto);
 
@@ -76,9 +76,10 @@
         }
 
         CreateCouponTemplateBO couponTemplateBO = new CreateCouponTemplateBO();
+        BeanUtils.copyProperties(couponTemplateDO,couponTemplateBO);
         BeanUtils.copyProperties(dto, couponTemplateBO);
 
-        // 设置成积分优惠券
+        // 设置成活动优惠券
         couponTemplateBO.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
         couponTemplateBO.setGetUserType(CouponGetUserTypeEnum.ALL.getType());
 
@@ -109,7 +110,7 @@
     @GetMapping("/page")
     @ApiOperation(value = "查询-分页", notes = "查询-分页")
     public ResponseEntity<ReturnDataDTO<Page<CouponTemplatePointVO>>> page(Page page, QueryCouponDTO dto) {
-        // 设置只查询积分优惠券的
+        // 设置只查询活动优惠券的
         dto.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
         Page<CouponTemplateVO> resultPage = couponTemplateService.getPage(page, dto);
         return returnData(R.SUCCESS.getCode(), ConverterUtil.transPage(resultPage, CouponTemplateActivyVO.class));
@@ -118,7 +119,7 @@
     @GetMapping("/list")
     @ApiOperation(value = "查询-全部", notes = "查询-全部")
     public ResponseEntity<ReturnDataDTO<Page<CouponTemplateVO>>> list(QueryCouponDTO dto) {
-        // 设置只查询积分优惠券的
+        // 设置只查询活动优惠券的
         dto.setCategory(CouponCategoryEnum.ACTIVITY.getStatus());
         return returnData(R.SUCCESS.getCode(), ConverterUtil.transList(couponTemplateService.getList(dto), CouponTemplateActivyVO.class));
     }
@@ -132,6 +133,27 @@
         if (null == couponTemplateDO) {
             throw new ValidationException("优惠券不存在");
         }
+
+        // 判断当前时间是否在优惠券的领取时间范围内
+        LocalDateTime now = LocalDateTime.now();
+//        if (couponTemplateDO.getGetStartDate() != null && couponTemplateDO.getGetEndDate() != null) {
+//            if (now.isBefore(couponTemplateDO.getGetStartDate()) || now.isAfter(couponTemplateDO.getGetEndDate())) {
+//                throw new ValidationException("当前时间不在优惠券领取时间范围内,不能发布优惠券。");
+//            }
+//        } else {
+//            throw new ValidationException("优惠券的领取时间未设置。");
+//        }
+
+        // 检查结束时间是否存在
+        if (couponTemplateDO.getGetEndDate() != null) {
+            // 如果当前时间小于结束时间,允许发布
+            if (now.isAfter(couponTemplateDO.getGetEndDate())) {
+                throw new ValidationException("当前时间已超过优惠券领取结束时间,不能发布优惠券。");
+            }
+        } else {
+            throw new ValidationException("优惠券的领取结束时间未设置。");
+        }
+
 
         couponTemplateService.activeCouponTemplate(id);
 
@@ -155,11 +177,22 @@
 
     private void valid(CreateCouponTemplateActivyDTO dto){
 
-        if (StringUtils.isNotBlank(dto.getCouponDiscountType())
-                && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
-                && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
-            throw new ValidationException("订单金额不能小于折扣金额");
+//        if (StringUtils.isNotBlank(dto.getCouponDiscountType())
+//                && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
+//                && dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0) {
+//            throw new ValidationException("优惠券使用条件不能小于面值金额");
+//        }
+        if (StringUtils.isNotBlank(dto.getCouponDiscountType()) && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())) {
+
+            if(dto.getMinOrderAmount().compareTo(BigDecimal.ZERO)<=0){
+                throw new ValidationException("优惠券使用条件不能小于0");
+            }
+            if(dto.getMinOrderAmount().compareTo(dto.getCouponDiscountValue()) < 0){
+                throw new ValidationException("优惠券使用条件不能小于面值金额");
+            }
+
         }
+
         if (StringUtils.isNotBlank(dto.getCouponDiscountType())
                 && dto.getCouponDiscountType().equals(CouponTypeEnum.DISCOUNT.getType())
                 && dto.getCouponDiscountValue().compareTo(BigDecimal.ZERO) <= 0) {
@@ -181,6 +214,19 @@
             if(dto.getUsageEndDate()==null){
                 throw new ValidationException("固定时间结束日期不能为空");
             }
+
+            if(dto.getUsageStartDate().isAfter(dto.getUsageEndDate())){
+                throw new ValidationException("固定时间开始时间不能大于结束日期");
+            }
+
+
+            // 固定时间的使用开始时间必须大于领取的结束时间
+
+            if(null!=dto.getGetEndDate() && null!=dto.getUsageStartDate() && dto.getGetEndDate().isAfter(dto.getUsageStartDate())){
+                throw new ValidationException("使用开始时间必须大于领取结束时间!");
+            }
+
+
         }
 
         // 领取后 有效时间
@@ -197,6 +243,18 @@
                 throw new ValidationException("领取后有效时间整数需要大于0");
             }
         }
+
+        // 用户获取的类型是首页领取的话
+        if(StringUtils.isNotBlank(dto.getGetType()) && dto.getGetType().equals(dto.getGetType().equals(CouponGetTypeEnum.HOME.getType()))
+        ){
+            // 优惠券图片校验
+            if(StringUtils.isBlank(dto.getImageUrl())){
+                throw new ValidationException("优惠券图片不能为空");
+            }
+        }
+
+        //
+
     }
 
 }

--
Gitblit v1.9.3