From 9b867103f0d53bf913bb4ea93687820d92ee0515 Mon Sep 17 00:00:00 2001
From: xin <1099200748@qq.com>
Date: Thu, 14 Aug 2025 14:45:24 +0800
Subject: [PATCH] 退款订单

---
 oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java |   24 ++++++++++++++++++------
 1 files changed, 18 insertions(+), 6 deletions(-)

diff --git a/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java b/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java
index 6042c17..ba1eb63 100644
--- a/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java
+++ b/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java
@@ -54,7 +54,9 @@
     private final RedisUtils redisUtils;
     private final StoreService storeService;
     private final OrderOperationLogService operationLogService;
-    private final static String DESCRIBE = "哦应:";
+    private static final String DESCRIBE = "哦应:";
+    private static final String ORDER_KEY = "oying:order";
+    private static final String ORDER_STORE_KEY = "oying:order:store";
 
     @Override
     public PageResult<Order> queryAll(OrderQueryCriteria criteria, Page<Object> page) {
@@ -91,7 +93,8 @@
         if (!(address.getDistance().compareTo(BigDecimal.valueOf(store.getRadius())) <= 0)) {
             throw new BadRequestException("超出配送范围");
         }
-        String orderNum = redisUtils.generateOrderSn(GenerateEnum.ORDER.getKey());
+        // 订单号
+        String orderNum = redisUtils.generateSn(ORDER_KEY, GenerateEnum.ORDER.getKey());
         // 总金额
         BigDecimal amount = BigDecimal.ZERO;
         // 商品快照
@@ -128,7 +131,7 @@
         // 订单信息
         Order order = new Order();
         order.setOrderNum(orderNum);
-        order.setOrderStoreNum(redisUtils.generateOrderSn(Math.toIntExact(submit.getStoreId())).substring(orderNum.length() - 4));
+        order.setOrderStoreNum(redisUtils.generateSn(ORDER_STORE_KEY, Math.toIntExact(submit.getStoreId())).substring(orderNum.length() - 4));
         order.setOrderStatus(OrderStatusEnum.ZERO.getKey());
         order.setOrderStatusDescribe(OrderStatusEnum.ZERO.getValue());
         order.setOrderRemark(submit.getRemark() != null ? submit.getRemark() : "");
@@ -173,7 +176,6 @@
 
         OrderAddressSnapshot addressSnapshot = getOrderAddressSnapshot(orderNum, address);
 
-
         addressSnapshotService.save(addressSnapshot);
         orderMapper.insert(order);
         productSnapshotService.saveBatch(snapshots);
@@ -212,6 +214,7 @@
         }
         List<ProductInfo> products = new ArrayList<>();
         BigDecimal amount = BigDecimal.ZERO;
+        int count = 0;
         for (ProductOrder productOrder : criteria.getProducts()) {
             Product product = productService.getById(productOrder.getProductId());
             if (product == null) {
@@ -236,6 +239,7 @@
             info.setCount(productOrder.getCount());
             products.add(info);
             amount = BigDecimalUtils.add(amount, BigDecimalUtils.multiply(product.getPrice(), productOrder.getCount()));
+            count += productOrder.getCount();
         }
         if (!(amount.compareTo(store.getDeliveryMinimum()) >= 0)) {
             throw new BadRequestException("起送金额:" + store.getDeliveryMinimum());
@@ -246,6 +250,8 @@
         info.setAmount(amount);
         info.setPayAmount(amount);
         info.setPromotionAmount(BigDecimal.ZERO);
+        info.setDeliveryPrice(store.getDeliveryFee());
+        info.setPackagingPrice(BigDecimalUtils.multiply(store.getPackagingFee(), count));
         info.setUserAddresses(userAddressService.queryUserAddress(store.getLongitude(), store.getLatitude()));
         return info;
     }
@@ -261,7 +267,13 @@
     public OrderResponse getByOrderNum(String orderNum) {
         return new OrderResponse(orderMapper.getByOrderNum(orderNum),
                 addressSnapshotService.queryByOrderNum(orderNum),
-                operationLogService.getByOrderNum(orderNum));
+                operationLogService.getByOrderNum(orderNum, null));
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public Order queryByOrderNum(String orderNum) {
+        return orderMapper.getByOrderNum(orderNum);
     }
 
     @Override
@@ -278,7 +290,7 @@
 
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public void cancel(String orderNum) {
+    public synchronized void cancel(String orderNum) {
         OrderResponse response = getByOrderNum(orderNum);
         Order order = response.getOrder();
         if (order == null) {

--
Gitblit v1.9.3