From b8143019423b5bb1344d26f6da594c9908783909 Mon Sep 17 00:00:00 2001
From: guyue <1721849008@qq.com>
Date: 星期一, 18 八月 2025 02:17:21 +0800
Subject: [PATCH] 优化

---
 UserOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java |   28 +++++++++++++++++++++++++---
 1 files changed, 25 insertions(+), 3 deletions(-)

diff --git a/UserOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java b/UserOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java
index 18c58b4..d6c9495 100644
--- a/UserOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java
+++ b/UserOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java
@@ -55,6 +55,7 @@
 import java.math.MathContext;
 import java.math.RoundingMode;
 import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -733,6 +734,7 @@
                     //推单操作
                     if(orderCrossCity.getState() == 1){
                         this.pushCrossCityOrder(orderCrossCity);
+                        System.out.println("推单!!");
                     }
                 } catch (Exception e) {
                     e.printStackTrace();
@@ -2477,7 +2479,10 @@
         LocalDateTime localDateTime = LocalDateTime.now();
         LocalDateTime dateTime = localDateTime.minusMinutes(30);
         String time = dateUtil.localDateTimeToStringHHmm(dateTime);
-        List<OrderCrossCity> orderCrossCities = this.selectList(new EntityWrapper<OrderCrossCity>().eq("state", 7).like("insertTime", time));
+        LocalDateTime start = LocalDateTime.parse(time + ":00", DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+        LocalDateTime end   = start.plusMinutes(1);
+
+        List<OrderCrossCity> orderCrossCities = this.selectList(new EntityWrapper<OrderCrossCity>().eq("state", 7).between("insertTime", start, end));
         if(!CollectionUtils.isEmpty(orderCrossCities)){
             for (OrderCrossCity orderCrossCity : orderCrossCities) {
                 orderCrossCity.setState(10);
@@ -2525,14 +2530,15 @@
                     if(ToolUtil.isNotEmpty(vehicle)){
                         integers = JSON.parseArray(vehicle).toJavaList(Integer.class);
                     }
-                    Company query = companyCityService.query(String.valueOf(orderCrossCity.getStartLon()), String.valueOf(orderCrossCity.getStartLat()));//获取起点所属分公司
+//                    Company query = companyCityService.query(String.valueOf(orderCrossCity.getStartLon()), String.valueOf(orderCrossCity.getStartLat()));//获取起点所属分公司
 //                    List<PushOrder> querys = pushOrderService.querys(null, 1, query.getId());//获取需要推送的次数
+                    Company query = companyService.selectById(1);
                     for(int i = 1; i <= 3; i++){
                         PushOrder pushOrder = pushOrderService.querys(i, 1, query.getId()).get(0);
                         //获取空闲司机
 //                        List<Driver> list = driverService.queryIdleDriver(1, orderCrossCity.getServerCarModelId(), orderCrossCity.getStartLon(), orderCrossCity.getStartLat(), pushOrder.getPushDistance(), null);//所有附近空闲司机
                         //获取同线路的同车型的跨城司机
-                        List<Driver> list = driverService.queryDriversByLineAndCarModel(orderCrossCity.getServerCarModelId(), orderCrossCity.getLineId());
+                        List<Driver> list = driverService.queryDriversByLineAndCarModel(3,orderCrossCity.getServerCarModelId(), orderCrossCity.getLineId());
                         if(list.size() > 0){
                             double driverProportion = pushOrder.getDriverProportion() / 100;//推送占比计算成小数
                             int lastIndex = Double.valueOf(list.size() * driverProportion).intValue();//计算占比转成整数(下标截取)
@@ -2560,6 +2566,22 @@
                         if(i == 3 && state == 1){
                             pushUtil.pushEndPush(1, orderCrossCity.getUserId(), orderCrossCity.getId(), 1);
                             orderIds.remove(orderCrossCity.getId());
+                            OrderCrossCity orderCrossCity1 = orderCrossCityMapper.selectById(orderCrossCity.getId());
+//                            if(orderCrossCity1.getState() == 7 && orderCrossCity1.getPayMoney() == null){
+                                orderCrossCity1.setState(10);
+                                orderCrossCityMapper.updateById(orderCrossCity1);
+
+                                OrderCancel orderCancel = new OrderCancel();
+                                orderCancel.setOrderId(orderCrossCity.getId());
+                                orderCancel.setOrderType(3);
+                                orderCancel.setReason("没有司机接单,系统自动取消订单");
+                                orderCancel.setRemark("没有司机接单,系统自动取消订单");
+                                orderCancel.setState(2);
+                                orderCancel.setInsertTime(new Date());
+                                orderCancel.setUserType(2);
+                                orderCancelService.insert(orderCancel);
+                                //TODO:退款
+//                            }
                         }
                     }
                 } catch (Exception e) {

--
Gitblit v1.7.1