From b69f7d42b91856b9448676a51eefef6b36f6bdb3 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 13 二月 2025 10:30:49 +0800
Subject: [PATCH] Merge branch 'master' of https://gitee.com/xiaochen991015/xizang

---
 ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/PayController.java |   17 +++++++++++------
 1 files changed, 11 insertions(+), 6 deletions(-)

diff --git a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/PayController.java b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/PayController.java
index f6058a5..bf1c494 100644
--- a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/PayController.java
+++ b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/PayController.java
@@ -16,6 +16,7 @@
 import io.swagger.annotations.ApiOperation;
 import org.apache.poi.ss.formula.functions.T;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
@@ -52,21 +53,25 @@
 
     @ApiOperation(value = "线下支付")
     @PostMapping("offlinePay")
+    @Transactional(rollbackFor = Exception.class)
     public R offlinePay(@Validated @RequestBody OfflinePayDto dto){
         List<TBill> tBills = tBillService.listByIds(dto.getBillIds());
+        TBillConfirm confirm = new TBillConfirm();
+        confirm.setBillId(CollectionUtil.join(dto.getBillIds(),","));
+        confirm.setVoucher(dto.getVoucher());
+        confirm.setPayFeesMoney(new BigDecimal(dto.getAmount()).divide(AmountConstant.b100).setScale(2, RoundingMode.HALF_DOWN).doubleValue());
+        confirm.setPayTime(dto.getPayTime());
+        tBillConfirmService.save(confirm);
         for (TBill tBill : tBills) {
             TBill save = new TBill();
             save.setId(tBill.getId());
             save.setPayFeesType(2);
             save.setVoucher(dto.getVoucher());
             save.setPayFeesStatus("2");
-            tBillService.lockAndUpdateInfo(save);
+            save.setConfirmId(confirm.getId());
+            tBillService.lockAndUpdateInfo(save,1);
         }
-        TBillConfirm confirm = new TBillConfirm();
-        confirm.setBillId(CollectionUtil.join(dto.getBillIds(),","));
-        confirm.setVoucher(dto.getVoucher());
-        confirm.setPayFeesMoney(new BigDecimal(dto.getAmount()).divide(AmountConstant.b100).setScale(2, RoundingMode.HALF_DOWN).doubleValue());
-        tBillConfirmService.save(confirm);
+
         return R.ok();
     }
 

--
Gitblit v1.7.1