From 1e630a0e74dab5ae9e2704de890bbb16b951ec99 Mon Sep 17 00:00:00 2001
From: zhibing.pu <393733352@qq.com>
Date: 星期五, 23 八月 2024 15:46:08 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/2.0' into 2.0

---
 ManagementIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TOrderPrivateCarController.java |  105 +++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 103 insertions(+), 2 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 4a2465b..7c8f569 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
@@ -20,6 +20,7 @@
 import com.stylefeng.guns.modular.system.dao.TSystemPriceMapper;
 import com.stylefeng.guns.modular.system.model.*;
 import com.stylefeng.guns.modular.system.service.*;
+import com.stylefeng.guns.modular.system.util.ChinaMobileUtil;
 import com.stylefeng.guns.modular.system.util.GoogleMap.FleetEngineUtil;
 import com.stylefeng.guns.modular.system.util.HttpRequestUtil;
 import com.stylefeng.guns.modular.system.util.PushURL;
@@ -217,11 +218,15 @@
     @ResponseBody
     public Object frozenOrder(@RequestParam Integer tOrderPrivateCarId) throws Exception {
         TOrderPrivateCar orderPrivateCar = tOrderPrivateCarService.selectById(tOrderPrivateCarId);
+
+        //添加已收入明细
+        TDriver tDriver = driverService.selectById(orderPrivateCar.getDriverId());
         orderPrivateCar = this.setMoney(orderPrivateCar, 0D, 0D);//计算费用
+
         //添加已收入明细
         TCompany company = companyService.selectById(orderPrivateCar.getCompanyId());
-        TDriver tDriver = driverService.selectById(orderPrivateCar.getDriverId());
         Double taxi = company.getSpeMoney().doubleValue();
+        Integer language =tDriver.getLanguage();
         BigDecimal d = null;//企业收入
         BigDecimal c = null;//司机收入
         if(company.getIsSpeFixedOrProportional() == 2){//固定
@@ -249,8 +254,100 @@
             driverService.updateById(driver);
         }
         if (orderPrivateCar.getIsFrozen() == 1){
+            TOrderPrivateCar orderPrivateCar1 = tOrderPrivateCarService.selectById(tOrderPrivateCarId);
+            if(orderPrivateCar1.getArriveTime()==null){
+                orderPrivateCar1.setArriveTime(orderPrivateCar1.getStartServiceTime());
+            }
+            orderPrivateCar1 = this.setMoney(orderPrivateCar1, 0D, 0D);//计算费用
+
+            orderPrivateCar1.setOrderMoney(orderPrivateCar1.getOrderMoney().add(orderPrivateCar1.getParkMoney()).add(orderPrivateCar1.getRoadTollMoney()));
+            //判断是否首单免费-免费直接完成
+            Integer orderNumber = tOrderPrivateCarService.selectCount(new EntityWrapper<TOrderPrivateCar>().eq("userId",orderPrivateCar1.getUserId()).last("and (state=8 or state=9)"));
+
+            if(orderNumber<=0){//判断是否是首单
+                //判断是否免单
+                TUser userInfo = userService.selectById(orderPrivateCar1.getUserId());
+                if(userInfo.getFreeMoney().doubleValue()>0d){
+                    if(orderPrivateCar1.getOrderMoney().compareTo(userInfo.getFreeMoney())<=-1){
+                        orderPrivateCar1.setState(8);
+                        orderPrivateCar1.setIsFree(2);
+                        //添加已收入明细
+                        TCompany tCompany = companyService.selectById(orderPrivateCar1.getCompanyId());
+                        BigDecimal speMoney = tCompany.getSpeMoney();
+
+                        if(tCompany.getIsSpeFixedOrProportional() == 2){//固定
+                            d = speMoney;
+                            c = orderPrivateCar1.getOrderMoney().subtract(d);//只有出行金额参与抽成,其余归属司机
+                        }
+                        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);
+                        }
+                        incomeService.saveData(1, orderPrivateCar1.getCompanyId(), 2, orderPrivateCar1.getId(), 1, d.doubleValue());
+                        incomeService.saveData(2, orderPrivateCar1.getDriverId(), 2, orderPrivateCar1.getId(), 1, c.doubleValue());
+                        TDriver driver = driverService.selectById(orderPrivateCar1.getDriverId());
+                        driver.setBusinessMoney(new BigDecimal(null != driver.getBusinessMoney() ? driver.getBusinessMoney() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+                        driver.setLaveBusinessMoney(new BigDecimal(null != driver.getLaveBusinessMoney() ? driver.getLaveBusinessMoney() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+                        if (null != driver.getBalance()){
+                            driver.setBalance(driver.getBalance().add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN));
+                        }else{
+                            driver.setBalance(BigDecimal.ZERO.add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN));
+                        }
+                        driverService.updateById(driver);
+                    }else{
+                        orderPrivateCar1.setState(7);
+                        orderPrivateCar1.setOrderMoney(orderPrivateCar1.getOrderMoney().subtract(userInfo.getFreeMoney()));
+                        orderPrivateCar1.setFreeMoney(userInfo.getFreeMoney());
+
+                    }
+
+                }else{
+                    orderPrivateCar1.setState(7);
+                }
+
+            }else{
+                orderPrivateCar1.setState(7);
+            }
+
+            Map<String, String> map = chinaMobileUtil.midAxbUnBindSend(orderPrivateCar1.getBindId(),orderPrivateCar1.getTelX());
+            if(String.valueOf(map.get("code")).equals("200")){
+                orderPrivateCar1.setTelX("");
+                orderPrivateCar1.setBindId("");
+            }
+            tOrderPrivateCarService.updateById(orderPrivateCar1);
+
+
+            pushUtil.removeTask(orderPrivateCar1.getId(), 1);//删除定时任务,结束推送数据
+            systemNoticeService.addSystemNotice(1, language == 1 ? "司机已结束本次行程,谢谢使用" : language == 2 ?
+                    "The driver has finished the trip,thank you for using I-GO" : "Le chauffeur a terminé le trajet, merci d'utiliser I-GO", orderPrivateCar1.getUserId());
+
+            //回滚司机状态为空闲
+            TDriver driver = driverService.selectById(orderPrivateCar1.getDriverId());
+            driver.setState(2);
+            driverService.updateById(driver);
+
+            TOrderPrivateCar finalOrderTaxi = orderPrivateCar1;
+            new Thread(new Runnable() {
+                @Override
+                public void run() {
+                    pushUtil.pushOrderState(1, finalOrderTaxi.getUserId(), finalOrderTaxi.getId(), 1, finalOrderTaxi.getState(), 0, "");
+                    pushUtil.pushOrderState(2, finalOrderTaxi.getDriverId(), finalOrderTaxi.getId(), 1, finalOrderTaxi.getState(), 0, "");
+                }
+            }).start();
+
+            TOrderPrivateCar finalOrderPrivateCar = orderPrivateCar1;
+            new Thread(()->{
+                try {
+                    //上报google
+                    fleetEngineUtil.reportBillableEvent(finalOrderPrivateCar.getTripId());
+                    System.err.println("上报时间:{},tripid:{},created_at:{},completed_at:{}"+ System.currentTimeMillis()+ finalOrderPrivateCar.getTripId()+
+                            finalOrderPrivateCar.getInsertTime().getTime()+finalOrderPrivateCar.getEndServiceTime().getTime());
+                }catch (Exception e){
+                    e.printStackTrace();
+                }
+            }).start();
             // 冻结订单需要给司机推送一个消息;
-            TOrderPrivateCar finalOrderPrivateCar = orderPrivateCar;
             new Thread(new Runnable() {
                 @Override
                 public void run() {
@@ -265,7 +362,11 @@
         return SUCCESS_TIP;
     }
     @Autowired
+    private ChinaMobileUtil chinaMobileUtil;
+    @Autowired
     private PushUtil pushUtil;
+    @Autowired
+    private ITSystemNoticeService systemNoticeService;
     @Resource
     private TSystemPriceMapper systemPriceMapper;
     public TOrderPrivateCar setMoney(TOrderPrivateCar orderPrivateCar, Double parkingFee, Double crossingFee) throws Exception {

--
Gitblit v1.7.1