From aba1baff88d0a04a39523177d20a91ba88aeb7eb Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 23 八月 2024 09:12:23 +0800
Subject: [PATCH] 2.0bug修改

---
 ManagementIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TOrderPrivateCarController.java |   36 +++++++++++++++++++++++++++---------
 1 files changed, 27 insertions(+), 9 deletions(-)

diff --git a/ManagementIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TOrderPrivateCarController.java b/ManagementIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TOrderPrivateCarController.java
index 15a69e6..abeb22e 100644
--- a/ManagementIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TOrderPrivateCarController.java
+++ b/ManagementIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TOrderPrivateCarController.java
@@ -72,6 +72,9 @@
     
     @Autowired
     private FleetEngineUtil fleetEngineUtil;
+    
+    @Resource
+    private ITUserService userService;
 
 
 
@@ -207,8 +210,7 @@
         return SUCCESS_TIP;
     }
 
-    @Resource
-    private ITUserService userService;
+
     @RequestMapping(value = "/frozenOrder")
     @ResponseBody
     public Object frozenOrder(@RequestParam Integer tOrderPrivateCarId) throws Exception {
@@ -216,9 +218,23 @@
 
         //添加已收入明细
         TDriver tDriver = driverService.selectById(orderPrivateCar.getDriverId());
+        orderPrivateCar = this.setMoney(orderPrivateCar, 0D, 0D);//计算费用
+
+        //添加已收入明细
+        TCompany company = companyService.selectById(orderPrivateCar.getCompanyId());
+        Double taxi = company.getSpeMoney().doubleValue();
         Integer language =tDriver.getLanguage();
         BigDecimal d = null;//企业收入
         BigDecimal c = null;//司机收入
+        if(company.getIsSpeFixedOrProportional() == 2){//固定
+            d = new BigDecimal(taxi);
+            c = orderPrivateCar.getOrderMoney().subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
+        }
+        if(company.getIsSpeFixedOrProportional() == 1){//比例
+            Double price = orderPrivateCar.getStartMoney().doubleValue() + orderPrivateCar.getMileageMoney().doubleValue() + orderPrivateCar.getWaitMoney().doubleValue()+ orderPrivateCar.getDurationMoney().doubleValue() + orderPrivateCar.getLongDistanceMoney().doubleValue();
+            d = new BigDecimal(price).multiply(new BigDecimal(taxi).divide(new BigDecimal(100))).setScale(2, BigDecimal.ROUND_HALF_EVEN);
+            c = orderPrivateCar.getOrderMoney().subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
+        }
         if(orderPrivateCar.getIsFrozen()==1){
             TDriver driver = driverService.selectById(orderPrivateCar.getDriverId());
             driver.setBusinessMoney(new BigDecimal(null != driver.getBusinessMoney() ? driver.getBusinessMoney() : 0).subtract(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
@@ -253,14 +269,14 @@
                         orderPrivateCar1.setState(8);
                         orderPrivateCar1.setIsFree(2);
                         //添加已收入明细
-                        TCompany company = companyService.selectById(orderPrivateCar1.getCompanyId());
-                        BigDecimal speMoney = company.getSpeMoney();
+                        TCompany tCompany = companyService.selectById(orderPrivateCar1.getCompanyId());
+                        BigDecimal speMoney = tCompany.getSpeMoney();
 
-                        if(company.getIsSpeFixedOrProportional() == 2){//固定
+                        if(tCompany.getIsSpeFixedOrProportional() == 2){//固定
                             d = speMoney;
                             c = orderPrivateCar1.getOrderMoney().subtract(d);//只有出行金额参与抽成,其余归属司机
                         }
-                        if(company.getIsSpeFixedOrProportional() == 1){//比例
+                        if(tCompany.getIsSpeFixedOrProportional() == 1){//比例
                             BigDecimal price = orderPrivateCar1.getStartMoney().add(orderPrivateCar1.getMileageMoney()).add(new BigDecimal(orderPrivateCar1.getWaitMoney())).add(orderPrivateCar1.getDurationMoney()).add(orderPrivateCar1.getLongDistanceMoney());
                             d = price.multiply(speMoney).divide(new BigDecimal(100), new MathContext(2, RoundingMode.HALF_EVEN));
                             c = orderPrivateCar1.getOrderMoney().subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
@@ -621,12 +637,14 @@
 
         tOrderPrivateCar.setState(10);
         tOrderPrivateCarService.updateById(tOrderPrivateCar);
-
+    
+        TUser tUser = userService.selectById(tOrderPrivateCar.getUserId());
+        Integer language = tUser.getLanguage();
         OrderCancel orderCancel = new OrderCancel();
         orderCancel.setOrderId(tOrderPrivateCarId);
         orderCancel.setOrderType(1);
-        orderCancel.setReason("The platform cancels the order");
-        orderCancel.setRemark("The platform cancels the order");
+        orderCancel.setReason(language == 1 ? "平台取消订单" : language == 2 ? "The platform cancelled the order" : "La plateforme a annulé la commande");
+        orderCancel.setRemark(language == 1 ? "平台取消订单" : language == 2 ? "The platform cancelled the order" : "La plateforme a annulé la commande");
         orderCancel.setUserType(2);
         orderCancel.setState(2);
         orderCancel.setInsertTime(new Date());

--
Gitblit v1.7.1