From 42490ec10cb18dd38deba7b400935dd91c976065 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期五, 25 四月 2025 16:36:15 +0800
Subject: [PATCH] 修改bug

---
 DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java |  131 +++++++++++++++++++++----------------------
 1 files changed, 63 insertions(+), 68 deletions(-)

diff --git a/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java b/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java
index 3240c07..2665b81 100644
--- a/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java
+++ b/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java
@@ -455,63 +455,7 @@
                 orderTaxi.setGetoffAddress(address);
                 orderTaxi.setGetoffTime(new Date());
                 orderTaxi.setEndServiceTime(new Date());
-                if(orderTaxi.getPayManner()==3){
-                    orderTaxi.setState(9);
-                    Driver driver = driverService.selectById(orderTaxi.getDriverId());
-
-                    Company company = companyService.selectById(driver.getFranchiseeId());
-                    if(Objects.isNull(company)){
-                        company = companyService.selectById(driver.getCompanyId());
-                    }
-                    TransactionDetails transactionDetails = new TransactionDetails();
-                    driver.setBalance(driver.getBalance() - company.getFixedDeduction());
-                    transactionDetails.setMoney(company.getFixedDeduction());
-                    // 新增扣除使用费记录
-                    transactionDetails.setUserId(driver.getId());
-                    transactionDetails.setInsertTime(new Date());
-                    transactionDetails.setRemark("软件使用费");
-                    transactionDetails.setState(2);
-                    transactionDetails.setType(1);
-                    transactionDetails.setUserType(2);
-                    transactionDetails.setOrderType(6);
-                    transactionDetails.setOrderId(orderTaxi.getId());
-                    transactionDetailsMapper.insert(transactionDetails);
-                    driverService.updateById(driver);
-                }
-                //打表计费,直接订单完成支付,
-                if(orderTaxi.getPayManner()==2){
-                    orderTaxi = this.setMoney2(orderTaxi, 0D, 0D);
-                    //在线上计费的基础上随机加0.01-1的金额
-                    Double orderMoney = orderTaxi.getOrderMoney() + (new BigDecimal(Math.random()).setScale(2, BigDecimal.ROUND_DOWN).doubleValue());
-                    orderTaxi.setState(8);
-                    orderTaxi.setOrderMoney(orderMoney);
-                    orderTaxi.setPayMoney(orderMoney);
-                    Driver driver = driverService.selectById(orderTaxi.getDriverId());
-    
-                    Company company = companyService.selectById(driver.getFranchiseeId());
-                    if(Objects.isNull(company)){
-                        company = companyService.selectById(driver.getCompanyId());
-                    }
-                    TransactionDetails transactionDetails = new TransactionDetails();
-                    driver.setBalance(driver.getBalance() - company.getMeterPrintingFee());
-                    transactionDetails.setMoney(company.getMeterPrintingFee());
-                    // 新增扣除使用费记录
-                    transactionDetails.setUserId(driver.getId());
-                    transactionDetails.setInsertTime(new Date());
-                    transactionDetails.setRemark("软件使用费");
-                    transactionDetails.setState(2);
-                    transactionDetails.setType(1);
-                    transactionDetails.setUserType(2);
-                    transactionDetails.setOrderType(6);
-                    transactionDetails.setOrderId(orderTaxi.getId());
-                    transactionDetailsMapper.insert(transactionDetails);
-                    driverService.updateById(driver);
-                }
-                //线上计费,计算费用后修改为待支付
-                if(orderTaxi.getPayManner()==1){
-                    orderTaxi = this.setMoney2(orderTaxi, 0D, 0D);
-                    orderTaxi.setState(7);
-                }
+                orderTaxi.setState(6);
                 //回滚司机状态为空闲
                 Driver driver = driverService.selectById(orderTaxi.getDriverId());
                 driver.setState(2);
@@ -550,21 +494,72 @@
     public ResultUtil confirmFees(Integer orderId, Integer type, Double travelFee, Double parkingFee, Double crossingFee) throws Exception {
         OrderTaxi orderTaxi = this.selectById(orderId);
         orderTaxi.setPayManner(type);
-        if(type == 2){//其他支付,不需要操作,直接完成订单
-            orderTaxi = this.setMoney1(orderTaxi, travelFee, parkingFee, crossingFee);
-            orderTaxi.setState(7);
-        }else if (type == 1){
+        if(orderTaxi.getPayManner()==3){
+            orderTaxi.setState(9);
+            Driver driver = driverService.selectById(orderTaxi.getDriverId());
+        
+            Company company = companyService.selectById(driver.getFranchiseeId());
+            if(Objects.isNull(company)){
+                company = companyService.selectById(driver.getCompanyId());
+            }
+            TransactionDetails transactionDetails = new TransactionDetails();
+            driver.setBalance(driver.getBalance() - company.getFixedDeduction());
+            transactionDetails.setMoney(company.getFixedDeduction());
+            // 新增扣除使用费记录
+            transactionDetails.setUserId(driver.getId());
+            transactionDetails.setInsertTime(new Date());
+            transactionDetails.setRemark("软件使用费");
+            transactionDetails.setState(2);
+            transactionDetails.setType(1);
+            transactionDetails.setUserType(2);
+            transactionDetails.setOrderType(6);
+            transactionDetails.setOrderId(orderTaxi.getId());
+            transactionDetailsMapper.insert(transactionDetails);
+            driverService.updateById(driver);
+        }
+        //打表计费,直接订单完成支付,
+        if(orderTaxi.getPayManner()==2){
             orderTaxi = this.setMoney2(orderTaxi, parkingFee, crossingFee);
-            orderTaxi.setState(7);
-        }else {
+            //在线上计费的基础上随机加0.01-1的金额
+            Double orderMoney = orderTaxi.getOrderMoney() + (new BigDecimal(Math.random()).setScale(2, BigDecimal.ROUND_DOWN).doubleValue());
             orderTaxi.setState(8);
+            orderTaxi.setOrderMoney(orderMoney);
+            orderTaxi.setPayMoney(orderMoney);
+            Driver driver = driverService.selectById(orderTaxi.getDriverId());
+        
+            Company company = companyService.selectById(driver.getFranchiseeId());
+            if(Objects.isNull(company)){
+                company = companyService.selectById(driver.getCompanyId());
+            }
+            TransactionDetails transactionDetails = new TransactionDetails();
+            Double meterPrintingFee = company.getMeterPrintingFee();
+            Double laveBusinessMoney = driver.getLaveBusinessMoney();
+            Double laveActivityMoney = driver.getLaveActivityMoney();
+            if(null != laveBusinessMoney && laveBusinessMoney.compareTo(meterPrintingFee) >= 0){
+                driver.setLaveBusinessMoney(new BigDecimal(laveBusinessMoney).subtract(new BigDecimal(meterPrintingFee)).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+            }else if(null != laveActivityMoney && laveActivityMoney.compareTo(meterPrintingFee) >= 0){
+                driver.setLaveActivityMoney(new BigDecimal(laveActivityMoney).subtract(new BigDecimal(meterPrintingFee)).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+            }
+            driver.setBalance(driver.getBalance() - meterPrintingFee);
+            transactionDetails.setMoney(meterPrintingFee);
+            // 新增扣除使用费记录
+            transactionDetails.setUserId(driver.getId());
+            transactionDetails.setInsertTime(new Date());
+            transactionDetails.setRemark("软件使用费");
+            transactionDetails.setState(2);
+            transactionDetails.setType(1);
+            transactionDetails.setUserType(2);
+            transactionDetails.setOrderType(6);
+            transactionDetails.setOrderId(orderTaxi.getId());
+            transactionDetailsMapper.insert(transactionDetails);
+            driverService.updateById(driver);
+        }
+        //线上计费,计算费用后修改为待支付
+        if(orderTaxi.getPayManner()==1){
+            orderTaxi = this.setMoney2(orderTaxi, crossingFee, crossingFee);
+            orderTaxi.setState(7);
         }
         this.updateById(orderTaxi);
-
-        //回滚司机状态为空闲
-        Driver driver = driverService.selectById(orderTaxi.getDriverId());
-        driver.setState(2);
-        driverService.updateById(driver);
 
         OrderTaxi finalOrderTaxi = orderTaxi;
         new Thread(new Runnable() {

--
Gitblit v1.7.1