From 909804c31a95a9d76abd2c50761152e95bde5406 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 22 May 2025 10:54:30 +0800
Subject: [PATCH] refactor(goods): 注释掉新增样品按钮

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |   42 +++++++++++++++++++++++++++---------------
 1 files changed, 27 insertions(+), 15 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 5fdf95f..9321b44 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
@@ -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());
@@ -477,7 +483,7 @@
         if (MallGoodsCoupon.TYPE_ONE == type) {
             realAmount = mallGoodsCoupon.getRealAmount();
         } else if (MallGoodsCoupon.TYPE_TWO == type) {
-            BigDecimal divideTime = totalAmount.divide(costAmount, 0, RoundingMode.DOWN); // 累计减免次数
+            BigDecimal divideTime = totalAmount.divide(costAmount, 0, RoundingMode.HALF_DOWN); // 累计减免次数
             realAmount = divideTime.multiply(realAmount); // 实际减免金额
         }
 
@@ -489,17 +495,17 @@
         for (Map.Entry<Long, BigDecimal> entry : skuMap.entrySet()) {
             Long keySkuId = entry.getKey();
             BigDecimal valueSkuAmount = entry.getValue();
-            BigDecimal divide = valueSkuAmount.divide(totalAmount, 4, RoundingMode.DOWN); // 每个商品占符合满减的总额的比例
+            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.DOWN); // 每个SKU的减免金额(比例*减免金额)
-                skuRealAmount = valueSkuAmount.subtract(bigDecimalOne.max(BigDecimal.ZERO)).setScale(2, RoundingMode.DOWN);
+                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.DOWN); // 累计减免次数
+                BigDecimal divideTime = totalAmount.divide(costAmount, 0, RoundingMode.HALF_DOWN); // 累计减免次数
                 BigDecimal multiply = divideTime.multiply(realAmount); // 实际减免金额
-                BigDecimal bigDecimalTwo = multiply.multiply(divide).setScale(2, RoundingMode.DOWN); // 每个SKU的减免金额(比例*实际减免金额)
-                skuRealAmount = valueSkuAmount.subtract(bigDecimalTwo.max(BigDecimal.ZERO)).setScale(2, RoundingMode.DOWN);
+                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);
             }
             couponAmountMap.put(keySkuId, skuRealAmount);
@@ -511,7 +517,7 @@
             for (Map.Entry<Long, BigDecimal> entry : couponAmountMap.entrySet()) {
                 Long keySkuId = entry.getKey();
                 BigDecimal skuRealAmount = entry.getValue();
-                BigDecimal newSkuRealAmount = skuRealAmount.subtract(difference).setScale(2, RoundingMode.DOWN);
+                BigDecimal newSkuRealAmount = skuRealAmount.subtract(difference).setScale(2, RoundingMode.HALF_DOWN);
                 couponAmountMap.put(keySkuId, newSkuRealAmount);
                 break; // 调整最后一个商品的减免金额
             }
@@ -1086,6 +1092,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());
@@ -1106,7 +1113,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){
@@ -1129,6 +1140,7 @@
             apiLeaderRefundOrderDto.setItemId(mallOrderItem.getId());
             apiLeaderRefundOrderDto.setAgreeState(1);
             iApiMallTeamLeaderService.leaderRefundOrder(apiLeaderRefundOrderDto);
+            i++;
         }
         return new FebsResponse().success();
     }

--
Gitblit v1.9.1