From fcf92d335a32ec572337247431b4bd17752cb64d Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期一, 23 九月 2024 14:34:13 +0800
Subject: [PATCH] add:订单详情页面增加优惠券类型、使用条件

---
 src/main/java/com/mzl/flower/service/payment/OrderService.java |   38 +++++++++++++++++++++++++++++++++++++-
 1 files changed, 37 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/mzl/flower/service/payment/OrderService.java b/src/main/java/com/mzl/flower/service/payment/OrderService.java
index 68f2395..34d6b5b 100644
--- a/src/main/java/com/mzl/flower/service/payment/OrderService.java
+++ b/src/main/java/com/mzl/flower/service/payment/OrderService.java
@@ -14,6 +14,7 @@
 import com.mzl.flower.dto.PriceDTO;
 import com.mzl.flower.dto.request.menber.MemberGrowthRecordDTO;
 import com.mzl.flower.dto.request.payment.*;
+import com.mzl.flower.dto.response.coupon.CouponRecordVO;
 import com.mzl.flower.dto.response.flower.FlowerCartListDTO;
 import com.mzl.flower.dto.response.flower.FlowerCartListWrapDTO;
 import com.mzl.flower.dto.response.flower.FlowerDTO;
@@ -60,11 +61,13 @@
 import org.springframework.context.annotation.Lazy;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.ObjectUtils;
 
 import java.math.BigDecimal;
 import java.math.RoundingMode;
 import java.time.LocalDate;
 import java.time.LocalDateTime;
+import java.time.LocalTime;
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
@@ -1098,6 +1101,15 @@
         List<OrderPointGoodsListDTO> pointGoodsList = orderMapper.getPointGoodsList(id);
         dto.setPointGoodsList(pointGoodsList);
 
+        //判断优惠券ID是否为空 用户优惠券id
+        if(StringUtils.isNotBlank(o.getMemberCouponId())){
+            CouponRecordVO couponRecordVO = couponRecordService.getCouponRecordById(o.getMemberCouponId());
+            if(!ObjectUtils.isEmpty(couponRecordVO)){
+                dto.setCouponDiscountType(couponRecordVO.getCouponDiscountType());
+                dto.setMinOrderAmount("满"+couponRecordVO.getMinOrderAmount());
+            }
+        }
+
         return dto;
     }
 
@@ -1575,7 +1587,31 @@
     }
 
     public Integer getFlowerCompleteNumToday(String userId,Long flowerId){
-        Integer completeNum= orderMapper.getFlowerCompleteNumToday(userId,flowerId);
+
+        int completeNum = 0;
+        // 获取当前时间
+        LocalDateTime now = LocalDateTime.now();
+        // 构造今天的17:00
+        LocalDateTime todayAtFivePM = LocalDateTime.of(LocalDate.now(), LocalTime.of(17, 0));
+        // 定义时间区间的开始和结束时间
+        LocalDateTime startTime;
+        LocalDateTime endTime;
+
+        if (now.isAfter(todayAtFivePM)) {
+            // 当前时间大于今天的17:00,取今天17:00到明天17:00的区间
+            startTime = todayAtFivePM;
+            endTime = todayAtFivePM.plusDays(1);  // 明天的17:00
+        } else {
+            // 当前时间小于今天的17:00,取昨天17:00到今天17:00的区间
+            startTime = todayAtFivePM.minusDays(1);  // 昨天的17:00
+            endTime = todayAtFivePM;  // 今天的17:00
+        }
+
+        // 调用Mapper方法,传递开始时间和结束时间
+        completeNum = orderMapper.getFlowerCompleteNumWithinTimeRange(userId, flowerId, startTime, endTime);
+
         return completeNum;
+
+
     }
 }

--
Gitblit v1.9.3