From 59da87cc7b9db21b01c8c2c0831619aff73d0f84 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 28 Apr 2025 17:54:27 +0800
Subject: [PATCH] fix(mall): 修复活动订单删除功能

---
 src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java |  102 ++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 93 insertions(+), 9 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 399aee3..b2d0db8 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
@@ -14,10 +14,7 @@
 import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cc.mrbird.febs.mall.vo.*;
 import cc.mrbird.febs.mall.dto.ApiOperateDoDto;
-import cc.mrbird.febs.mall.vo.activity.ApiActivityOrderInfoVo;
-import cc.mrbird.febs.mall.vo.activity.ApiActivityOrderListVo;
-import cc.mrbird.febs.mall.vo.activity.ApiCheckOrderVo;
-import cc.mrbird.febs.mall.vo.activity.ApiVoteActivityHotVo;
+import cc.mrbird.febs.mall.vo.activity.*;
 import cc.mrbird.febs.pay.model.BrandWCPayRequestData;
 import cc.mrbird.febs.pay.service.IXcxPayService;
 import cc.mrbird.febs.rabbit.producter.AgentProducer;
@@ -54,6 +51,7 @@
     private final HappyActivityOptionMapper happyActivityOptionMapper;
     private final HappyActivityConnectMapper happyActivityConnectMapper;
     private final HappyActivityOrderMapper happyActivityOrderMapper;
+    private final HappyActivityCommentMapper happyActivityCommentMapper;
     private final HappyActivityOrderItemMapper happyActivityOrderItemMapper;
     private final IXcxPayService iXcxPayService;
     private final IApiMallMemberWalletService iApiMallMemberWalletService;
@@ -114,6 +112,14 @@
         );
         if(happyActivity != null){
             BeanUtil.copyProperties(happyActivity,apiActivityVo);
+
+            Integer commentCount = happyActivityCommentMapper.selectCount(
+                    new LambdaQueryWrapper<HappyActivityComment>()
+                            .eq(HappyActivityComment::getActivityId, happyActivity.getId())
+                            .eq(HappyActivityComment::getShowState, StateUpDownEnum.UP.getCode())
+            );
+            apiActivityVo.setCommentCount(commentCount);
+
             List<HappyFollow> happyFollows = happyFollowMapper.selectList(
                     new LambdaQueryWrapper<HappyFollow>()
                             .select(HappyFollow::getId, HappyFollow::getType)
@@ -409,6 +415,7 @@
                 new LambdaQueryWrapper<HappyActivityConnect>()
                         .eq(HappyActivityConnect::getMemberId, memberId)
                         .eq(HappyActivityConnect::getName, dto.getName())
+                        .eq(HappyActivityConnect::getPhone, dto.getPhone())
         );
         if(CollUtil.isNotEmpty(happyActivityConnects)){
             throw new FebsException("已经添加过该联系人");
@@ -465,6 +472,26 @@
     }
 
     @Override
+    public FebsResponse expireOrder(ApiExpireOrderDto dto) {
+        if(CollUtil.isEmpty(dto.getIds())){
+            throw new FebsException("请选择订单");
+        }
+
+        dto.getIds().forEach(id -> {
+            HappyActivityOrder happyActivityOrder = happyActivityOrderMapper.selectById(id);
+            if(ObjectUtil.isNotEmpty(happyActivityOrder)){
+                Long activityId = happyActivityOrder.getActivityId();
+                Integer numCnt = happyActivityOrder.getNumCnt();
+                this.baseMapper.updateHappyActivitySurplusCnt(activityId,numCnt);
+
+                happyActivityOrder.setState(StateUpDownEnum.ORDER_STATE_OVERTIME.getCode());
+                happyActivityOrderMapper.updateById(happyActivityOrder);
+            }
+        });
+        return new FebsResponse().success();
+    }
+
+    @Override
     public FebsResponse createOrder(ApiCreateOrderDto dto) {
         Long memberId = LoginUserUtil.getLoginUser().getId();
         if(CollUtil.isEmpty(dto.getConnectIds())){
@@ -478,6 +505,24 @@
         }
 
         Long activityId = dto.getActivityId();
+
+        List<HappyActivityOrderItem> happyActivityOrderItems = happyActivityOrderItemMapper.selectList(
+                new LambdaQueryWrapper<HappyActivityOrderItem>()
+                        .eq(HappyActivityOrderItem::getActivityId, activityId)
+                        .in(HappyActivityOrderItem::getConnectId, connectIds)
+        );
+        if(CollUtil.isNotEmpty(happyActivityOrderItems)){
+            //stream流操作happyActivityOrderItems,返回一个orderId的Set集合
+            Set<Long> orderIdSet = happyActivityOrderItems.stream().map(HappyActivityOrderItem::getOrderId).collect(Collectors.toSet());
+            List<HappyActivityOrder> happyActivityOrders = happyActivityOrderMapper.selectList(
+                    new LambdaQueryWrapper<HappyActivityOrder>()
+                            .in(HappyActivityOrder::getId, orderIdSet)
+                            .in(HappyActivityOrder::getState, Arrays.asList(StateUpDownEnum.ORDER_STATE_WAIT_PAY.getCode(),StateUpDownEnum.ORDER_STATE_WAIT_USE.getCode()))
+            );
+            if(CollUtil.isNotEmpty(happyActivityOrders)){
+                throw new FebsException("有报名人重复报名了活动,请重新选择");
+            }
+        }
         HappyActivity happyActivity = this.baseMapper.selectById(activityId);
         if (ObjectUtil.isEmpty(happyActivity)) {
             throw new FebsException("活动不存在");
@@ -498,6 +543,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);
@@ -506,6 +552,9 @@
         happyActivityOrder.setNumCnt(dto.getNumCnt());
         happyActivityOrder.setAmount(amount);
         happyActivityOrder.setPayState(StateUpDownEnum.PAY_STATE_NOT_PAY.getCode());
+        happyActivityOrder.setPayType(StateUpDownEnum.PAY_METHOD_WECHAT.getCode());
+        happyActivityOrder.setFailTime(failTime);
+        log.info("创建订单,订单号="+JSONUtil.parse(happyActivityOrder));
         happyActivityOrderMapper.insert(happyActivityOrder);
 
         for(Long connectId : connectIds){
@@ -529,6 +578,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);
     }
@@ -592,8 +642,6 @@
             log.error("支付失败,订单ID:{},支付类型:{}", orderId, payType, e);
             throw new FebsException("支付失败:" + e.getMessage());
         }
-
-        // todo 支付失败要把对应的人数加回来
 
         // 构造返回结果,包含支付相关信息
         Map<String, Object> map = new HashMap<>();
@@ -683,7 +731,7 @@
 
         LambdaQueryWrapper<HappyActivityOrder> happyActivityOrderLambdaQueryWrapper = new LambdaQueryWrapper<>();
         happyActivityOrderLambdaQueryWrapper.eq(HappyActivityOrder::getMemberId, memberId);
-        if(ObjectUtil.isNotEmpty(dto.getState())){
+        if(ObjectUtil.isNotEmpty(dto.getState()) && dto.getState() != 0){
             happyActivityOrderLambdaQueryWrapper.eq(HappyActivityOrder::getState, dto.getState());
         }
         happyActivityOrderLambdaQueryWrapper.eq(HappyActivityOrder::getDeleteFlag, StateUpDownEnum.DOWN.getCode());
@@ -697,6 +745,7 @@
             List<HappyActivity> happyActivities = this.baseMapper.selectList(
                     new LambdaQueryWrapper<HappyActivity>()
                             .select(
+                                    HappyActivity::getId,
                                     HappyActivity::getCategoryId,
                                     HappyActivity::getName,
                                     HappyActivity::getStartTime,
@@ -912,7 +961,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 -> {
@@ -921,13 +970,48 @@
                 Integer numCnt = happyActivityOrder.getNumCnt();
                 this.baseMapper.updateHappyActivitySurplusCnt(activityId,numCnt);
 
-                happyActivityOrder.setDeleteFlag(StateUpDownEnum.UP.getCode());
+                happyActivityOrder.setState(StateUpDownEnum.ORDER_STATE_OVERTIME.getCode());
                 happyActivityOrderMapper.updateById(happyActivityOrder);
             });
         }
     }
 
     @Override
+    public FebsResponse addComment(ApiPayOrderAddCommentDto dto) {
+        // 获取当前登录用户的ID
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        Long orderId = dto.getOrderId();
+
+        HappyActivityOrder happyActivityOrder = happyActivityOrderMapper.selectById(orderId);
+        if(StateUpDownEnum.ORDER_STATE_USED.getCode() != happyActivityOrder.getState()){
+            throw new FebsException("该订单状态不是已使用状态!");
+        }
+
+        happyActivityOrder.setState(StateUpDownEnum.ORDER_STATE_COMMENT.getCode());
+        happyActivityOrderMapper.updateById(happyActivityOrder);
+
+        HappyActivity happyActivity = this.baseMapper.selectById(happyActivityOrder.getActivityId());
+
+        HappyActivityComment happyActivityComment = new HappyActivityComment();
+        happyActivityComment.setActivityId(happyActivity.getId());
+        happyActivityComment.setActivityName(happyActivity.getName());
+        happyActivityComment.setMemberId(memberId);
+        happyActivityComment.setOrderId(orderId);
+        happyActivityComment.setStar(dto.getStar());
+        happyActivityComment.setComment(dto.getComment());
+        happyActivityComment.setImages(dto.getImages());
+        happyActivityCommentMapper.insert(happyActivityComment);
+
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public List<ApiActivityCommentVo> commentByActivityId(ApiActivityCommentDto dto) {
+        Page<ApiActivityCommentVo> page = new Page<>(dto.getPageNow(), dto.getPageSize());
+        return this.baseMapper.selectActivityCommentPage(page,dto);
+    }
+
+    @Override
     public FebsResponse voteActivityHot(Long id) {
 
         ApiVoteActivityHotVo apiVoteActivityHotVo = new ApiVoteActivityHotVo();

--
Gitblit v1.9.1