From 966ccdfcdf7aff42801d93667dd7712136ce8b89 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 28 Apr 2025 14:23:48 +0800
Subject: [PATCH] feat(mall): 添加活动订单失效时间和状态处理

---
 src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java |    9 +++++----
 1 files changed, 5 insertions(+), 4 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java
index 6f755cb..2f7f7a2 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java
@@ -504,6 +504,7 @@
         if(amount.compareTo(BigDecimal.ZERO) < 0){
             throw new FebsException("支付金额错误");
         }
+        DateTime failTime = DateUtil.offsetMinute(new Date(), StateUpDownEnum.ORDER_OVERTIME.getCode());
         HappyActivityOrder happyActivityOrder = new HappyActivityOrder();
         happyActivityOrder.setOrderNo(MallUtils.getOrderNum());
         happyActivityOrder.setMemberId(memberId);
@@ -512,6 +513,7 @@
         happyActivityOrder.setNumCnt(dto.getNumCnt());
         happyActivityOrder.setAmount(amount);
         happyActivityOrder.setPayState(StateUpDownEnum.PAY_STATE_NOT_PAY.getCode());
+        happyActivityOrder.setFailTime(failTime);
         happyActivityOrderMapper.insert(happyActivityOrder);
 
         for(Long connectId : connectIds){
@@ -535,6 +537,7 @@
         HashMap<String, Object> stringObjectHashMap = new HashMap<>();
         stringObjectHashMap.put("orderId",happyActivityOrder.getId());
         stringObjectHashMap.put("amount",amount);
+        stringObjectHashMap.put("failTime",failTime);
 
         return new FebsResponse().success().data(stringObjectHashMap);
     }
@@ -598,8 +601,6 @@
             log.error("支付失败,订单ID:{},支付类型:{}", orderId, payType, e);
             throw new FebsException("支付失败:" + e.getMessage());
         }
-
-        // todo 支付失败要把对应的人数加回来
 
         // 构造返回结果,包含支付相关信息
         Map<String, Object> map = new HashMap<>();
@@ -918,7 +919,7 @@
         List<HappyActivityOrder> happyActivityOrders = happyActivityOrderMapper.selectList(
                 new LambdaQueryWrapper<HappyActivityOrder>()
                         .eq(HappyActivityOrder::getState, StateUpDownEnum.ORDER_STATE_WAIT_PAY.getCode())
-                        .lt(HappyActivityOrder::getCreatedTime, DateUtil.offsetMinute(new Date(), -10))
+                        .lt(HappyActivityOrder::getFailTime, new Date())
         );
         if(CollUtil.isNotEmpty(happyActivityOrders)){
             happyActivityOrders.forEach(happyActivityOrder -> {
@@ -927,7 +928,7 @@
                 Integer numCnt = happyActivityOrder.getNumCnt();
                 this.baseMapper.updateHappyActivitySurplusCnt(activityId,numCnt);
 
-                happyActivityOrder.setDeleteFlag(StateUpDownEnum.UP.getCode());
+                happyActivityOrder.setState(StateUpDownEnum.ORDER_STATE_OVERTIME.getCode());
                 happyActivityOrderMapper.updateById(happyActivityOrder);
             });
         }

--
Gitblit v1.9.1