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 +++++---- src/main/java/cc/mrbird/febs/mall/entity/HappyActivityOrder.java | 3 +++ src/main/java/cc/mrbird/febs/common/enumerates/StateUpDownEnum.java | 9 +++++++-- 3 files changed, 15 insertions(+), 6 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/StateUpDownEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/StateUpDownEnum.java index c4138aa..fcde796 100644 --- a/src/main/java/cc/mrbird/febs/common/enumerates/StateUpDownEnum.java +++ b/src/main/java/cc/mrbird/febs/common/enumerates/StateUpDownEnum.java @@ -4,7 +4,11 @@ @Getter public enum StateUpDownEnum { - + /** + * 活动订单失效时间 + * 分钟 + */ + ORDER_OVERTIME(30), /** * 来源类型 1-活动 2-社区圈子发布 @@ -27,7 +31,7 @@ VOTE_OPTION_STATE_AUDIT_REFUSE(2), /** - * 订单状态 1-待支付 2-待使用 3-已使用 4-售后 5-已评价 6-删除 + * 订单状态 1-待支付 2-待使用 3-已使用 4-售后 5-已评价 6-删除 7-已失效 */ ORDER_STATE_WAIT_PAY(1), ORDER_STATE_WAIT_USE(2), @@ -35,6 +39,7 @@ ORDER_STATE_AFTER_SALE(4), ORDER_STATE_COMMENT(5), ORDER_STATE_DELETE(6), + ORDER_STATE_OVERTIME(7), /** * 支付状态 0-待支付 1-支付成功 2-支付失败 diff --git a/src/main/java/cc/mrbird/febs/mall/entity/HappyActivityOrder.java b/src/main/java/cc/mrbird/febs/mall/entity/HappyActivityOrder.java index bf32bb3..868d696 100644 --- a/src/main/java/cc/mrbird/febs/mall/entity/HappyActivityOrder.java +++ b/src/main/java/cc/mrbird/febs/mall/entity/HappyActivityOrder.java @@ -27,6 +27,7 @@ `pay_order_no` text COMMENT '支付订单号', `wx_order_no` varchar(100) DEFAULT NULL COMMENT '微信订单编号', `state` int(11) DEFAULT '1' COMMENT '订单状态 1-待支付 2-待使用 3-已使用 4-售后', + `fail_time` datetime DEFAULT NULL COMMENT '失效时间', */ @@ -43,6 +44,8 @@ private String payOrderNo; private String wxOrderNo; private Integer state; + @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8") + private Date failTime; @TableField(exist = false) 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