From e8f8d89a4248cd4d0a7138cc2e5a36ea9b136699 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 11 Feb 2025 17:03:01 +0800
Subject: [PATCH] feat(mall): 添加订单一键发货和取消发货功能

---
 src/main/java/cc/mrbird/febs/pay/controller/FiuuReturnController.java |   25 +++++++++++++++++--------
 1 files changed, 17 insertions(+), 8 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/pay/controller/FiuuReturnController.java b/src/main/java/cc/mrbird/febs/pay/controller/FiuuReturnController.java
index c14b75b..7c9e498 100644
--- a/src/main/java/cc/mrbird/febs/pay/controller/FiuuReturnController.java
+++ b/src/main/java/cc/mrbird/febs/pay/controller/FiuuReturnController.java
@@ -8,6 +8,7 @@
 import cc.mrbird.febs.mall.entity.MallOrderInfo;
 import cc.mrbird.febs.mall.mapper.MallMoneyFlowMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.json.JSONObject;
 import cn.hutool.json.JSONUtil;
@@ -37,6 +38,8 @@
     private MallOrderInfoMapper mallOrderInfoMapper;
     @Resource
     private MallMoneyFlowMapper mallMoneyFlowMapper;
+    @Resource
+    private IApiMallMemberWalletService memberWalletService;
 
     @PostMapping("/payment/callback")
     public String handlePaymentCallback(
@@ -92,15 +95,21 @@
 
         MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOne(new LambdaQueryWrapper<MallMoneyFlow>().eq(MallMoneyFlow::getOrderNo, orderId));
         if (mallMoneyFlow != null) {
-            // 更新订单状态为已支付
-            mallMoneyFlow.setStatus(2);
-            mallMoneyFlowMapper.updateById(mallMoneyFlow);
+            if(1 == mallMoneyFlow.getStatus()){
+                memberWalletService.addBalance(mallMoneyFlow.getAmount(),mallMoneyFlow.getMemberId());
+                // 更新订单状态为已支付
+                mallMoneyFlow.setStatus(2);
+                mallMoneyFlowMapper.updateById(mallMoneyFlow);
+            }
+        }else{
+            MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(Long.parseLong(orderId));
+            if(mallOrderInfo != null){
+                if("1" == mallOrderInfo.getPayResult()){
+                    return "payment-success";
+                }
+                updateOrderStatus(orderId, status, amount, payDate, tranId);
+            }
         }
-        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(Long.parseLong(orderId));
-        if(mallOrderInfo != null){
-            updateOrderStatus(orderId, status, amount, payDate, tranId);
-        }
-        // 跳转到支付成功页面
         return "payment-success";
     }
 

--
Gitblit v1.9.1