From 92c26cea4de00349b346f71da3cf530b26c31eb0 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 10 Jun 2025 09:40:59 +0800
Subject: [PATCH] fix(mall): 修复用户重复加入标签的问题

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |   22 +++++++++++++++++++---
 1 files changed, 19 insertions(+), 3 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index e674534..031f3a6 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -287,8 +287,8 @@
             delivaryAmount = addOrderDto.getDeliveryAmount() == null ? BigDecimal.ZERO : addOrderDto.getDeliveryAmount();
             orderInfo.setCarriage(delivaryAmount);
         }else{
-            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(orderInfo.getTakeUniqueCode());
-            if(mallTeamLeader!=null){
+            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(addOrderDto.getTakeUniqueCode());
+            if(ObjectUtil.isEmpty(mallTeamLeader)){
                 throw new FebsException("自提点信息异常");
             }
             orderInfo.setCarriage(delivaryAmount);
@@ -896,7 +896,13 @@
     @Transactional(rollbackFor = Exception.class)
     public void confirmOrder(Long id) {
         MallMember member = LoginUserUtil.getLoginUser();
-        MallOrderInfo orderInfo = this.baseMapper.selectOrderByMemberIdAndId(member.getId(), id);
+//        MallOrderInfo orderInfo = this.baseMapper.selectOrderByMemberIdAndId(member.getId(), id);
+        MallOrderInfo orderInfo = this.baseMapper.selectOne(
+                new LambdaQueryWrapper<MallOrderInfo>()
+                .eq(MallOrderInfo::getMemberId, member.getId())
+                .eq(MallOrderInfo::getId, id)
+                .last("limit 1")
+        );
         if (orderInfo == null || AppContants.DEL_FLAG_Y == orderInfo.getDelFlag()) {
             throw new FebsException("订单不存在");
         }
@@ -904,6 +910,16 @@
         if (orderInfo.getStatus() != OrderStatusEnum.WAIT_FINISH.getValue()) {
             throw new FebsException("该状态不能确认收货");
         }
+        if(orderInfo.getDeliveryType().equals(1)){
+            List<MallOrderItem> mallOrderItems = mallOrderItemMapper.selectList(
+                    new LambdaQueryWrapper<MallOrderItem>()
+                            .eq(MallOrderItem::getOrderId, id)
+                            .eq(MallOrderItem::getLeaderState, 0)
+            );
+            if(CollUtil.isNotEmpty(mallOrderItems)){
+                throw new FebsException("请先核销"+mallOrderItems.get(0).getGoodsName());
+            }
+        }
 
         List<MallRefundEntity> mallRefundEntities = mallRefundMapper.selectByItemIdAndOrderIdAndState(null, orderInfo.getId(), 3);
         if(CollUtil.isNotEmpty(mallRefundEntities)){

--
Gitblit v1.9.1