From c6ac1561db0b2f1c8e3a799d7f49808f4bae67c7 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 27 May 2025 15:55:58 +0800
Subject: [PATCH] refactor(mall): 优化订单收货类型判断逻辑

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |  297 +++++++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 228 insertions(+), 69 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 52c314f..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
@@ -109,7 +109,7 @@
             throw new FebsException("请重新选择收货地址信息");
         }
 
-        String orderNo = MallUtils.getOrderNum();
+        String orderNo = MallUtils.getOrderNum("O");
         MallOrderInfo orderInfo = new MallOrderInfo();
         orderInfo.setOrderNo(orderNo);
         orderInfo.setOrderTime(new Date());
@@ -209,12 +209,16 @@
 
                     MallGoods mallGoods = mallGoodsMapper.selectById(sku.getGoodsId());
                     // todo 纯积分商品一个账号限制购买一次
-//                    if (new BigDecimal(mallGoods.getPresentPrice()).compareTo(BigDecimal.ZERO) == 0) {
-//                        List<MallOrderItem> items = mallOrderItemMapper.selectItemByGoodsIdUnCancel(mallGoods.getId(), member.getId());
-//                        if (CollUtil.isNotEmpty(items)) {
-//                            throw new FebsException("积分商品一个账号只能购买一次");
-//                        }
-//                    }
+                    if (new BigDecimal(mallGoods.getPresentPrice()).compareTo(BigDecimal.ZERO) == 0) {
+                        Integer cnt = item.getCnt();
+                        if(1 < cnt){
+                            throw new FebsException("积分商品限购一件");
+                        }
+                        List<MallOrderItem> items = mallOrderItemMapper.selectItemByGoodsIdUnCancel(mallGoods.getId(), member.getId());
+                        if (CollUtil.isNotEmpty(items)) {
+                            throw new FebsException("积分商品一个账号限购一次");
+                        }
+                    }
 
                     if (MallGoods.ISSALE_STATUS_DISABLED.equals(mallGoods.getIsSale())) {
                         throw new FebsException(mallGoods.getGoodsName() + "已下架");
@@ -226,6 +230,7 @@
                     }
 
                     BigDecimal amount = sku.getPresentPrice().multiply(BigDecimal.valueOf(item.getCnt()));
+                    BigDecimal levelOnePrice = sku.getLevelOnePrice().multiply(BigDecimal.valueOf(item.getCnt()));
                     //是否使用优惠卷
                     if(ObjectUtil.isNotEmpty(addOrderDto.getMemberCouponId())){
                         Long memberCouponId = addOrderDto.getMemberCouponId();
@@ -238,6 +243,7 @@
                         }
                     }
                     orderItem.setAmount(amount);
+                    orderItem.setLevelOnePrice(levelOnePrice);
                     orderItem.setScoreAmount(scoreAmountMap.get(item.getSkuId()));
                     orderItem.setCnt(item.getCnt());
                     orderItem.setOrderId(orderInfo.getId());
@@ -275,10 +281,21 @@
 
         mallMemberCoupon.setState(2);
         mallMemberCouponMapper.updateById(mallMemberCoupon);
-        //运费
-        BigDecimal delivaryAmount = addOrderDto.getDeliveryAmount() == null ? BigDecimal.ZERO : addOrderDto.getDeliveryAmount();
-        orderInfo.setCarriage(delivaryAmount);
 
+        BigDecimal delivaryAmount = BigDecimal.ZERO;
+        if(StrUtil.isEmpty(addOrderDto.getTakeUniqueCode())){
+            delivaryAmount = addOrderDto.getDeliveryAmount() == null ? BigDecimal.ZERO : addOrderDto.getDeliveryAmount();
+            orderInfo.setCarriage(delivaryAmount);
+        }else{
+            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(addOrderDto.getTakeUniqueCode());
+            if(ObjectUtil.isEmpty(mallTeamLeader)){
+                throw new FebsException("自提点信息异常");
+            }
+            orderInfo.setCarriage(delivaryAmount);
+            orderInfo.setTakeCode(ShareCodeUtil.toSerialCode(orderInfo.getId()) + MallUtils.getRandomNum(10));
+            orderInfo.setTakeUniqueCode(mallTeamLeader.getUniqueCode());
+            orderInfo.setDeliveryType(1);
+        }
         total = total.add(delivaryAmount);
         orderInfo.setAmount(total);
         orderInfo.setScoreAmount(totalScoreAmount);
@@ -294,6 +311,7 @@
         orderInfo.setLatitude(address.getLatitude());
         orderInfo.setLongitude(address.getLongitude());
         this.baseMapper.updateById(orderInfo);
+
         //过期时间修改成24小时
         agentProducer.sendOrderCancelDelayMsg(orderInfo.getId(),  24 * 60 * 60 * 1000L);
         return orderInfo.getId();
@@ -317,6 +335,7 @@
 
         for (AddOrderItemDto item : items) {
             Long skuId = item.getSkuId();
+            Integer cnt = item.getCnt();
             MallGoodsSku sku = skusAll.stream().filter(s -> s.getId().equals(skuId)).findFirst().orElse(null);
             if (ObjectUtil.isNotEmpty(sku)) {
                 Long goodsId = sku.getGoodsId();
@@ -324,13 +343,98 @@
                 if (ObjectUtil.isNotEmpty(mallGoods)) {
                     BigDecimal multi = mallGoods.getStaticProp().divide(BigDecimal.valueOf(100), 4, RoundingMode.HALF_DOWN);
                     //获取该商品该规格的积分
-                    BigDecimal scoreAmount = sku.getOriginalPrice().multiply(multi).setScale(0, RoundingMode.HALF_DOWN);
+                    BigDecimal scoreAmount = sku.getOriginalPrice().multiply(multi).multiply(new BigDecimal(cnt)).setScale(0, RoundingMode.HALF_DOWN);
                     scoreAmountMap.put(skuId, scoreAmount);
                 }
             }
         }
         return scoreAmountMap;
     }
+
+//    /**
+//     * 根据传入的优惠卷ID和商品明细集合计算出每个商品获取的实际支付金额
+//     * @param memberCouponId 优惠卷ID
+//     * @param items 商品明细
+//     * @return Map<Long,BigDecimal> skuId,实际支付金额
+//     */
+//    @Override
+//    public Map<Long,BigDecimal> getCouponAmountMap(Long memberCouponId,List<AddOrderItemDto> items){
+//        HashMap<Long,BigDecimal> couponAmountMap = new HashMap<>();
+//        MallMemberCoupon mallMemberCoupon = mallMemberCouponMapper.selectById(memberCouponId);
+//        if(ObjectUtil.isEmpty(mallMemberCoupon)){
+//            return couponAmountMap;
+//        }
+//        Integer state = mallMemberCoupon.getState();
+//        if(1 != state){
+//            return couponAmountMap;
+//        }
+//        Long couponId = mallMemberCoupon.getCouponId();//优惠卷ID
+//        List<Long> goodsIdsAll = couponGoodsMapper.selectByCouponId(couponId);
+//        List<MallGoodsSku> skusAll = mallGoodsSkuMapper.selectSkuIdsByGoodsId(goodsIdsAll);//获取该优惠卷绑定的全部商品sku
+//        List<Long> skuIdsAll = skusAll.stream().map(MallGoodsSku::getId).collect(Collectors.toList());//获取该优惠卷绑定的全部商品skuIDS
+//        List<Long> skuIds = items.stream().map(AddOrderItemDto::getSkuId).collect(Collectors.toList());//订单中的全部skuIds
+//
+//        /**
+//         * 获取这张优惠卷生效的skuIds
+//         */
+//        Set<Long> intersection = skuIdsAll.stream()
+//                .filter(item -> skuIds.contains(item))
+//                .collect(Collectors.toSet());//获取两个集合的交集
+//        if(CollUtil.isEmpty(intersection)){
+//            return couponAmountMap;
+//        }
+//        HashMap<Long,BigDecimal> skuMap = new HashMap<>();//每个订单详情的ID和amount的map
+//        List<MallGoodsSku> skus = mallGoodsSkuMapper.selectByIds(new ArrayList<>(intersection));
+//        BigDecimal totalAmount = BigDecimal.ZERO;//订单中的总金额
+//        Map<Long, AddOrderItemDto> itemMap = new HashMap<>();// 预先将items转换为Map,以skuId作为键
+//        for (AddOrderItemDto addOrderItemDto : items) {
+//            itemMap.put(addOrderItemDto.getSkuId(), addOrderItemDto);
+//        }
+//        for(MallGoodsSku mallGoodsSku : skus){
+//            Long id = mallGoodsSku.getId();
+//            BigDecimal presentPrice = mallGoodsSku.getPresentPrice();
+//            // 检查itemMap中是否存在该商品
+//            AddOrderItemDto addOrderItemDto = itemMap.get(id);
+//            if (addOrderItemDto != null) {
+//                BigDecimal skuAmount = presentPrice.multiply(BigDecimal.valueOf(addOrderItemDto.getCnt()));
+//                totalAmount = totalAmount.add(skuAmount);
+//                skuMap.put(id,skuAmount);
+//            }
+//        }
+//
+//        /**
+//         * 计算每个商品利用优惠卷打折的具体金额
+//         */
+//        MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(mallMemberCoupon.getCouponId());
+//        BigDecimal costAmount = mallGoodsCoupon.getCostAmount();
+//        BigDecimal realAmount = mallGoodsCoupon.getRealAmount();
+//        if(totalAmount.compareTo(costAmount) < 0){
+//            return couponAmountMap;
+//        }
+//        HashMap<Long,BigDecimal> skuMapPercent = new HashMap<>();//每个订单详情的ID和amount的map
+//        for (Map.Entry<Long,BigDecimal> entry : skuMap.entrySet()) {
+//            Long keySkuId = entry.getKey();
+//            BigDecimal valueSkuAmount = entry.getValue();
+//            BigDecimal divide = valueSkuAmount.divide(totalAmount, 4, BigDecimal.ROUND_DOWN);//每个商品占符合满减的总额的比例
+//            skuMapPercent.put(keySkuId,divide);
+//            Integer type = mallGoodsCoupon.getType();
+//            if(MallGoodsCoupon.TYPE_ONE == type){
+//                BigDecimal bigDecimal = realAmount.multiply(divide).setScale(0, BigDecimal.ROUND_DOWN);//每个SKU的减免金额(比例*减免金额)
+//                BigDecimal skuRealAmount = valueSkuAmount.subtract(bigDecimal.compareTo(BigDecimal.ZERO) > 0 ? bigDecimal : BigDecimal.ZERO);//实际支付金额
+//                couponAmountMap.put(keySkuId,skuRealAmount);
+//            }
+//            if(MallGoodsCoupon.TYPE_TWO == type){
+//                BigDecimal divideTime = totalAmount.divide(costAmount, 0, BigDecimal.ROUND_DOWN);//累计减免次数
+//                BigDecimal multiply = divideTime.multiply(realAmount);//实际减免金额
+//                BigDecimal bigDecimal = multiply.multiply(divide).setScale(0, BigDecimal.ROUND_DOWN);//每个SKU的减免金额(比例*实际减免金额)
+//                BigDecimal skuRealAmount = valueSkuAmount.subtract(bigDecimal.compareTo(BigDecimal.ZERO) > 0 ? bigDecimal : BigDecimal.ZERO);//实际支付金额
+//                couponAmountMap.put(keySkuId,skuRealAmount);
+//            }
+//        }
+//        return couponAmountMap;
+//    }
+
+
 
     /**
      * 根据传入的优惠卷ID和商品明细集合计算出每个商品获取的实际支付金额
@@ -339,79 +443,98 @@
      * @return Map<Long,BigDecimal> skuId,实际支付金额
      */
     @Override
-    public Map<Long,BigDecimal> getCouponAmountMap(Long memberCouponId,List<AddOrderItemDto> items){
-        HashMap<Long,BigDecimal> couponAmountMap = new HashMap<>();
-        MallMemberCoupon mallMemberCoupon = mallMemberCouponMapper.selectById(memberCouponId);
-        if(ObjectUtil.isEmpty(mallMemberCoupon)){
-            return couponAmountMap;
-        }
-        Integer state = mallMemberCoupon.getState();
-        if(1 != state){
-            return couponAmountMap;
-        }
-        Long couponId = mallMemberCoupon.getCouponId();//优惠卷ID
-        List<Long> goodsIdsAll = couponGoodsMapper.selectByCouponId(couponId);
-        List<MallGoodsSku> skusAll = mallGoodsSkuMapper.selectSkuIdsByGoodsId(goodsIdsAll);//获取该优惠卷绑定的全部商品sku
-        List<Long> skuIdsAll = skusAll.stream().map(MallGoodsSku::getId).collect(Collectors.toList());//获取该优惠卷绑定的全部商品skuIDS
-        List<Long> skuIds = items.stream().map(AddOrderItemDto::getSkuId).collect(Collectors.toList());//订单中的全部skuIds
+    public Map<Long, BigDecimal> getCouponAmountMap(Long memberCouponId, List<AddOrderItemDto> items) {
+        HashMap<Long, BigDecimal> couponAmountMap = new HashMap<>();
+        // 获取优惠券信息
+        Optional<MallMemberCoupon> optionalMallMemberCoupon = Optional.ofNullable(mallMemberCouponMapper.selectById(memberCouponId));
+        MallMemberCoupon mallMemberCoupon = optionalMallMemberCoupon.orElse(null);
 
-        /**
-         * 获取这张优惠卷生效的skuIds
-         */
-        Set<Long> intersection = skuIdsAll.stream()
-                .filter(item -> skuIds.contains(item))
-                .collect(Collectors.toSet());//获取两个集合的交集
-        if(CollUtil.isEmpty(intersection)){
+        if (mallMemberCoupon == null || mallMemberCoupon.getState() != 1) {
             return couponAmountMap;
         }
-        HashMap<Long,BigDecimal> skuMap = new HashMap<>();//每个订单详情的ID和amount的map
-        List<MallGoodsSku> skus = mallGoodsSkuMapper.selectByIds(new ArrayList<>(intersection));
-        BigDecimal totalAmount = BigDecimal.ZERO;//订单中的总金额
-        Map<Long, AddOrderItemDto> itemMap = new HashMap<>();// 预先将items转换为Map,以skuId作为键
-        for (AddOrderItemDto addOrderItemDto : items) {
-            itemMap.put(addOrderItemDto.getSkuId(), addOrderItemDto);
+
+        Set<Long> intersection = items.stream().map(AddOrderItemDto::getSkuId).collect(Collectors.toSet()); // 订单中的全部skuIds
+
+        if (intersection.isEmpty()) {
+            return couponAmountMap;
         }
-        for(MallGoodsSku mallGoodsSku : skus){
+
+        // 获取订单详情的ID和amount的map
+        Map<Long, AddOrderItemDto> itemMap = items.stream()
+                .collect(Collectors.toMap(AddOrderItemDto::getSkuId, item -> item));
+
+        List<MallGoodsSku> skus = mallGoodsSkuMapper.selectList(
+                new LambdaQueryWrapper<MallGoodsSku>()
+                        .select(MallGoodsSku::getId, MallGoodsSku::getPresentPrice)
+                        .in(MallGoodsSku::getId, intersection)
+        );
+        BigDecimal totalAmount = BigDecimal.ZERO;
+        Map<Long, BigDecimal> skuMap = new HashMap<>();
+
+        for (MallGoodsSku mallGoodsSku : skus) {
             Long id = mallGoodsSku.getId();
             BigDecimal presentPrice = mallGoodsSku.getPresentPrice();
-            // 检查itemMap中是否存在该商品
             AddOrderItemDto addOrderItemDto = itemMap.get(id);
             if (addOrderItemDto != null) {
                 BigDecimal skuAmount = presentPrice.multiply(BigDecimal.valueOf(addOrderItemDto.getCnt()));
                 totalAmount = totalAmount.add(skuAmount);
-                skuMap.put(id,skuAmount);
+                skuMap.put(id, skuAmount);
             }
         }
 
-        /**
-         * 计算每个商品利用优惠卷打折的具体金额
-         */
-        MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(mallMemberCoupon.getCouponId());
-        BigDecimal costAmount = mallGoodsCoupon.getCostAmount();
-        BigDecimal realAmount = mallGoodsCoupon.getRealAmount();
-        if(totalAmount.compareTo(costAmount) < 0){
+        // 计算每个商品利用优惠卷打折的具体金额
+        Optional<MallGoodsCoupon> optionalMallGoodsCoupon = Optional.ofNullable(mallGoodsCouponMapper.selectById(mallMemberCoupon.getCouponId()));
+        MallGoodsCoupon mallGoodsCoupon = optionalMallGoodsCoupon.orElse(null);
+        if (mallGoodsCoupon == null) {
             return couponAmountMap;
         }
-        HashMap<Long,BigDecimal> skuMapPercent = new HashMap<>();//每个订单详情的ID和amount的map
-        for (Map.Entry<Long,BigDecimal> entry : skuMap.entrySet()) {
+
+        BigDecimal costAmount = mallGoodsCoupon.getCostAmount();
+        BigDecimal realAmount = mallGoodsCoupon.getRealAmount();
+        Integer type = mallGoodsCoupon.getType();
+        if (MallGoodsCoupon.TYPE_ONE == type) {
+            realAmount = mallGoodsCoupon.getRealAmount();
+        } else if (MallGoodsCoupon.TYPE_TWO == type) {
+            BigDecimal divideTime = totalAmount.divide(costAmount, 0, RoundingMode.HALF_DOWN); // 累计减免次数
+            realAmount = divideTime.multiply(realAmount); // 实际减免金额
+        }
+
+        if (totalAmount.compareTo(costAmount) < 0) {
+            return couponAmountMap;
+        }
+
+        BigDecimal totalDiscount = BigDecimal.ZERO;
+        for (Map.Entry<Long, BigDecimal> entry : skuMap.entrySet()) {
             Long keySkuId = entry.getKey();
             BigDecimal valueSkuAmount = entry.getValue();
-            BigDecimal divide = valueSkuAmount.divide(totalAmount, 4, BigDecimal.ROUND_DOWN);//每个商品占符合满减的总额的比例
-            skuMapPercent.put(keySkuId,divide);
-            Integer type = mallGoodsCoupon.getType();
-            if(MallGoodsCoupon.TYPE_ONE == type){
-                BigDecimal bigDecimal = realAmount.multiply(divide).setScale(0, BigDecimal.ROUND_DOWN);//每个SKU的减免金额(比例*减免金额)
-                BigDecimal skuRealAmount = valueSkuAmount.subtract(bigDecimal.compareTo(BigDecimal.ZERO) > 0 ? bigDecimal : BigDecimal.ZERO);//实际支付金额
-                couponAmountMap.put(keySkuId,skuRealAmount);
+            BigDecimal divide = valueSkuAmount.divide(totalAmount, 4, RoundingMode.HALF_DOWN); // 每个商品占符合满减的总额的比例
+            BigDecimal skuRealAmount = BigDecimal.ZERO;
+            if (MallGoodsCoupon.TYPE_ONE == type) {
+                BigDecimal bigDecimalOne = realAmount.multiply(divide).setScale(2, RoundingMode.HALF_DOWN); // 每个SKU的减免金额(比例*减免金额)
+                skuRealAmount = valueSkuAmount.subtract(bigDecimalOne.max(BigDecimal.ZERO)).setScale(2, RoundingMode.HALF_DOWN);
+                totalDiscount = totalDiscount.add(bigDecimalOne);
+            } else if (MallGoodsCoupon.TYPE_TWO == type) {
+                BigDecimal divideTime = totalAmount.divide(costAmount, 0, RoundingMode.HALF_DOWN); // 累计减免次数
+                BigDecimal multiply = divideTime.multiply(realAmount); // 实际减免金额
+                BigDecimal bigDecimalTwo = multiply.multiply(divide).setScale(2, RoundingMode.HALF_DOWN); // 每个SKU的减免金额(比例*实际减免金额)
+                skuRealAmount = valueSkuAmount.subtract(bigDecimalTwo.max(BigDecimal.ZERO)).setScale(2, RoundingMode.HALF_DOWN);
+                totalDiscount = totalDiscount.add(bigDecimalTwo);
             }
-            if(MallGoodsCoupon.TYPE_TWO == type){
-                BigDecimal divideTime = totalAmount.divide(costAmount, 0, BigDecimal.ROUND_DOWN);//累计减免次数
-                BigDecimal multiply = divideTime.multiply(realAmount);//实际减免金额
-                BigDecimal bigDecimal = multiply.multiply(divide).setScale(0, BigDecimal.ROUND_DOWN);//每个SKU的减免金额(比例*实际减免金额)
-                BigDecimal skuRealAmount = valueSkuAmount.subtract(bigDecimal.compareTo(BigDecimal.ZERO) > 0 ? bigDecimal : BigDecimal.ZERO);//实际支付金额
-                couponAmountMap.put(keySkuId,skuRealAmount);
+            couponAmountMap.put(keySkuId, skuRealAmount);
+        }
+
+        // 调整最后一个商品的减免金额以确保总减免金额达到预期
+        if (totalDiscount.compareTo(realAmount) < 0) {
+            BigDecimal difference = realAmount.subtract(totalDiscount);
+            for (Map.Entry<Long, BigDecimal> entry : couponAmountMap.entrySet()) {
+                Long keySkuId = entry.getKey();
+                BigDecimal skuRealAmount = entry.getValue();
+                BigDecimal newSkuRealAmount = skuRealAmount.subtract(difference).setScale(2, RoundingMode.HALF_DOWN);
+                couponAmountMap.put(keySkuId, newSkuRealAmount);
+                break; // 调整最后一个商品的减免金额
             }
         }
+
         return couponAmountMap;
     }
 
@@ -588,7 +711,7 @@
 
                     orderInfo.setPayOrderNo(payResultStr);
                     orderInfo.setPayMethod("支付宝支付");
-                    agentProducer.sendOrderReturn(orderInfo.getId());
+//                    agentProducer.sendOrderReturn(orderInfo.getId());
                     break;
                 case "3":
 
@@ -621,7 +744,7 @@
                             ScoreFlowTypeEnum.PAY_BALANCE.getValue(),
                             orderInfo.getOrderNo(),
                             FlowTypeEnum.BALANCE.getValue(),
-                            StrUtil.format(ScoreFlowTypeEnum.PAY_BALANCE.getDesc(),orderInfo.getScoreAmount()),
+                            StrUtil.format(ScoreFlowTypeEnum.PAY_BALANCE.getDesc(),orderInfo.getAmount()),
                             2
                     );
                     agentProducer.sendOrderCoupon(orderInfo.getId());
@@ -732,7 +855,21 @@
 //            }
 //        }
 
+
         OrderDetailVo orderDetailVo = MallOrderInfoConversion.INSTANCE.entityToDetailVo(orderInfo);
+        if(StrUtil.isNotEmpty(orderInfo.getTakeUniqueCode())){
+            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(orderInfo.getTakeUniqueCode());
+
+            if(ObjectUtil.isNotEmpty(mallTeamLeader)){
+                orderDetailVo.setLeaderName(mallTeamLeader.getName());
+                orderDetailVo.setLeaderPhone(mallTeamLeader.getPhone());
+                orderDetailVo.setAddressPic(mallTeamLeader.getAddressPic());
+                orderDetailVo.setAddressArea(mallTeamLeader.getAddressArea());
+                orderDetailVo.setDetailAddress(mallTeamLeader.getDetailAddress());
+                orderDetailVo.setLeaderLongitude(mallTeamLeader.getLongitude());
+                orderDetailVo.setLeaderLatitude(mallTeamLeader.getLatitude());
+            }
+        }
 
         MallExpressInfo expressInfo = expressInfoMapper.selectByOrderId(orderInfo.getId());
         if(ObjectUtil.isNotEmpty(expressInfo)){
@@ -759,13 +896,29 @@
     @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("订单不存在");
         }
 
         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);
@@ -950,7 +1103,7 @@
                 mallGoodsComment.setSkuName(mallGoodsSku.getSkuName());
                 mallGoodsComment.setStyleId(mallGoodsSku.getStyleId());
                 mallGoodsComment.setStyleName(mallGoodsSku.getStyleName());
-                mallGoodsComment.setShowState(MallGoodsComment.SHOW_STATE_ENABLE);
+                mallGoodsComment.setShowState(MallGoodsComment.SHOW_STATE_DISABLED);
                 mallGoodsCommentMapper.insert(mallGoodsComment);
             }
         }
@@ -981,6 +1134,7 @@
         if(CollUtil.isEmpty(mallOrderItemList)){
             return new FebsResponse().fail().message("订单不存在");
         }
+        int i = 0;
         for(MallOrderItem mallOrderItem : mallOrderItemList){
             QueryWrapper<MallRefundEntity> objectQueryWrapper = new QueryWrapper<>();
             objectQueryWrapper.eq("member_id",member.getId());
@@ -1001,7 +1155,11 @@
                     mallRefundEntity.setType(3);
                 }
                 mallRefundEntity.setState(3);
-                mallRefundEntity.setAmount(mallOrderItem.getAmount());
+                if(i == 0){
+                    mallRefundEntity.setAmount(mallOrderItem.getAmount().add(mallOrderInfo.getCarriage()));
+                }else{
+                    mallRefundEntity.setAmount(mallOrderItem.getAmount());
+                }
                 mallRefundMapper.insert(mallRefundEntity);
             }else{
                 if(mallRefund.getState() == 1){
@@ -1024,6 +1182,7 @@
             apiLeaderRefundOrderDto.setItemId(mallOrderItem.getId());
             apiLeaderRefundOrderDto.setAgreeState(1);
             iApiMallTeamLeaderService.leaderRefundOrder(apiLeaderRefundOrderDto);
+            i++;
         }
         return new FebsResponse().success();
     }

--
Gitblit v1.9.1