From a62110663f11da3c7853f9616521fc780ae845c1 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期三, 04 十二月 2024 10:47:44 +0800
Subject: [PATCH] 处理异常订单记录

---
 UserZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java |   42 +++++++++++++++++++++++++++++++++++++++---
 1 files changed, 39 insertions(+), 3 deletions(-)

diff --git a/UserZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java b/UserZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
index 0142c10..601ce15 100644
--- a/UserZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
+++ b/UserZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
@@ -353,6 +353,7 @@
 
 
         // TODO: 2021/5/11 修改,根据后台设定的派单范围查询范围内有无司机,将单子指派给距离最近的司机(距离相同随机取),范围内没有司机再进行推单流程
+        System.out.println("=======3333======>");
         if(orderPrivateCar.getState() == 1){
             Company query = companyCityService.query(orderPrivateCar.getStartLon().toString(), orderPrivateCar.getStartLat().toString());
             if(null == query){
@@ -360,6 +361,7 @@
             }
             AssignOrder assignOrder = assignOrderService.selectOne(new EntityWrapper<AssignOrder>().eq("companyId", query.getId()).eq("type", 1));
             if(null != assignOrder){//配置了指派规则才处理
+                System.out.println("=======4444======>");
                 //获取空闲司机
                 List<Driver> drivers = driverService.queryIdleDriver(1, orderPrivateCar.getServerCarModelId(), orderPrivateCar.getStartLon(), orderPrivateCar.getStartLat(), assignOrder.getDistance(), null);//获取范围内空闲司机
                 if(drivers.size() > 0){//有司机,直接指派给司机
@@ -370,7 +372,26 @@
                             Driver driver = null;
                             int m = 0;
                             int index = 0;
+                            System.out.println("=======5555======>");
+                            // 查询预约单
+                            List<Integer> driverIds = drivers.stream().map(Driver::getId).collect(Collectors.toList());
+                            List<OrderPrivateCar> orderPrivateCarss = orderPrivateCarMapper.queryOrderByState(driverIds, 2, 1, 2, 3, 4, 5, 6,  11);
+                            List<Integer> orderPrivateCarDriverIds = orderPrivateCars.stream().map(OrderPrivateCar::getDriverId).collect(Collectors.toList());
                             for(int j = 0; j < drivers.size(); j++){
+                                Driver driver1 = drivers.get(j);
+                                // 判断该司机是否有30分钟内预约单
+                                long count = orderPrivateCarss.stream().filter(orderPrivateCar1 -> driver1.getId().equals(orderPrivateCar1.getDriverId())
+                                        && DateUtil.dateToLocalDateTime(orderPrivateCar1.getTravelTime()).minusMinutes(30).isBefore(LocalDateTime.now())
+                                        && DateUtil.dateToLocalDateTime(orderPrivateCar1.getTravelTime()).isAfter(LocalDateTime.now())).count();
+                                System.out.println("======1=======>"+orderPrivateCar.getOrderType());
+                                System.out.println("=======2======>"+orderPrivateCarDriverIds);
+                                System.out.println("=======3======>"+driver.getId());
+                                if(orderPrivateCar.getOrderType() == 2 && orderPrivateCarDriverIds.contains(driver.getId())){
+                                    continue;
+                                }
+                                if(count > 0){
+                                    continue;
+                                }
                                 String value = redisUtil.getValue("DRIVER" + drivers.get(j).getId());
                                 if(null != value){
 //                                Map<String, String> distance1 = gdMapElectricFenceUtil.getDistance(orderPrivateCar.getStartLon() + "," + orderPrivateCar.getStartLat(), value, 0);//计算距离
@@ -429,7 +450,9 @@
 //                        orderPrivateCar.setBindId(map.get("bindId"));
 //                    }
 
-                    dr.setState(3);
+                    if(orderPrivateCar.getOrderType() != 2){
+                        dr.setState(3);
+                    }
                     driverService.updateById(dr);
                     this.updateById(orderPrivateCar);
 
@@ -801,6 +824,7 @@
                             // 查询预约单
                             List<Integer> driverIds = list.stream().map(Driver::getId).collect(Collectors.toList());
                             List<OrderPrivateCar> orderPrivateCars = orderPrivateCarMapper.queryOrderByState(driverIds, 2, 1, 2, 3, 4, 5, 6,  11);
+                            List<Integer> orderPrivateCarDriverIds = orderPrivateCars.stream().map(OrderPrivateCar::getDriverId).collect(Collectors.toList());
                             double driverProportion = pushOrder.getDriverProportion() / 100;//推送占比计算成小数
                             int lastIndex = Double.valueOf(list.size() * driverProportion).intValue();//计算占比转成整数(下标截取)
                             list = list.subList(0, lastIndex);//获取空闲司机中占比数据
@@ -809,6 +833,12 @@
                                 long count = orderPrivateCars.stream().filter(orderPrivateCar1 -> driver.getId().equals(orderPrivateCar1.getDriverId())
                                         && DateUtil.dateToLocalDateTime(orderPrivateCar1.getTravelTime()).minusMinutes(30).isBefore(LocalDateTime.now())
                                         && DateUtil.dateToLocalDateTime(orderPrivateCar1.getTravelTime()).isAfter(LocalDateTime.now())).count();
+                                System.out.println("======1=======>"+orderPrivateCar.getOrderType());
+                                System.out.println("=======2======>"+orderPrivateCarDriverIds);
+                                System.out.println("=======3======>"+driver.getId());
+                                if(orderPrivateCar.getOrderType() == 2 && orderPrivateCarDriverIds.contains(driver.getId())){
+                                    continue;
+                                }
                                 if(count > 0){
                                     continue;
                                 }
@@ -1038,10 +1068,16 @@
             resultUtil = payMoneyUtil.weixinpay("完成订单",orderId +"", code,orderMoney+"","/base/wxPayOrderTaxi","JSAPI",userInfo.getAppletsOpenId());
             if(resultUtil.getCode()==200){
                 paymentRecordService.saveData(1, orderPrivateCar.getUserId(), 1, orderId, 1, 1, orderMoney, null, 1, code);//添加预支付数据
+                long millis = System.currentTimeMillis();
                 new Thread(()->{
-                    long time = orderPrivateCar.getInsertTime().getTime();
+                    long time = millis;
+                    try {
+                        Thread.sleep(5000);
+                    } catch (InterruptedException e) {
+                        throw new RuntimeException(e);
+                    }
                     //订单创建后15分钟
-                    while (System.currentTimeMillis() - time <= 900000) {
+                    while ((System.currentTimeMillis() - time) <= 900000) {
                         try {
                             String value1 = redisUtil.getValue(orderId + "_status_1");
                             if(ToolUtil.isNotEmpty(value1) && "8".equals(value1)){

--
Gitblit v1.7.1