From 0ab9dfd8f122195e4e9f09bd50c59e0a47450bec Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期三, 19 三月 2025 15:50:03 +0800
Subject: [PATCH] fix: resolve merge conflicts in .gitignore

---
 ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/PayController.java |   27 +++++++++++++++++++++++++--
 1 files changed, 25 insertions(+), 2 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 88fdae2..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
@@ -1,24 +1,34 @@
 package com.ruoyi.web.controller.api;
 
+import cn.hutool.core.collection.CollectionUtil;
+import com.ruoyi.common.constant.AmountConstant;
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.system.dto.MakeOrderDto;
 import com.ruoyi.system.dto.MakeOrderResp;
 import com.ruoyi.system.dto.OfflinePayDto;
 import com.ruoyi.system.model.TBill;
+import com.ruoyi.system.model.TBillConfirm;
+import com.ruoyi.system.service.TBillConfirmService;
 import com.ruoyi.system.service.TBillService;
 import com.ruoyi.system.service.TPayOrderService;
+import io.swagger.annotations.Api;
 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;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RestController;
 
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.util.Collections;
 import java.util.List;
 
+@Api(value = "支付订单")
 @RestController
 @RequestMapping("/t-pay")
 public class PayController {
@@ -30,6 +40,10 @@
 
     @Autowired
     TBillService tBillService;
+
+    @Autowired
+    TBillConfirmService tBillConfirmService;
+
     @ApiOperation(value = "创建支付订单")
     @PostMapping("makeOrder")
     public R<MakeOrderResp> makeOrder(@Validated @RequestBody MakeOrderDto dto){
@@ -37,18 +51,27 @@
         return R.ok(resp);
     }
 
-
+    @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.checkAndUpdate(save);
+            save.setConfirmId(confirm.getId());
+            tBillService.lockAndUpdateInfo(save,1);
         }
+
         return R.ok();
     }
 

--
Gitblit v1.7.1