From f727a93931f801bbcd3b5eb0275169cf55a87d5e Mon Sep 17 00:00:00 2001
From: 陶杰 <1378534974@qq.com>
Date: 星期日, 22 九月 2024 22:40:56 +0800
Subject: [PATCH] 1.优惠券-使用条件-根据满减还是无门槛控制 2.商品限购-根据payment_time来控制

---
 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 681a6fd..770572e 100644
--- a/src/main/java/com/mzl/flower/service/payment/OrderService.java
+++ b/src/main/java/com/mzl/flower/service/payment/OrderService.java
@@ -65,6 +65,7 @@
 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;
@@ -868,9 +869,11 @@
         List<OrderListDTO> ls = getOrderListBase(page, dto);
         if (ls != null && ls.size() > 0) {
             List<String> orderIds = new ArrayList<>();
+            Map<String, OrderListDTO> orderMap = new HashMap<>();
             for (OrderListDTO o : ls) {
                 o.setCouldRefund(couldRefund(o.getStatusBackend(), o.getPaymentTime()));
                 orderIds.add(o.getId());
+                orderMap.put(o.getId(), o);
             }
 
             List<OrderItemListDTO> itemList = orderItemMapper.getOrderItems(orderIds);
@@ -880,6 +883,14 @@
                 List<OrderItemListDTO> ll = map.computeIfAbsent(orderId, k -> new ArrayList<>());
                 OrderItemListDTO d = new OrderItemListDTO();
                 BeanUtils.copyProperties(oi, d);
+
+                OrderListDTO o = orderMap.get(orderId);
+                if(dto.isCustomerQuery() && o != null && StringUtils.isEmpty(o.getTransferId())){
+                    d.setReduceNum(0);
+                    d.setLackNum(0);
+                    d.setReplaceNum(0);
+                }
+
                 ll.add(d);
             }
 
@@ -1058,6 +1069,7 @@
 
     public Page<OrderListDTO> selectCustomerOrderList(Page page, OrderQueryDTO dto) {
         dto.setCreateBy(SecurityUtils.getUserId());
+        dto.setCustomerQuery(true);
 
         return selectOrderList(page, dto);
     }
@@ -1564,7 +1576,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