From dc3cfaa745eb7303e312ce7ba61a7019e5f12e4b Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期四, 21 八月 2025 00:22:42 +0800
Subject: [PATCH] 修改bug

---
 UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java |  183 +++++++++++++++++++++++++++------------------
 1 files changed, 109 insertions(+), 74 deletions(-)

diff --git a/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java b/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java
index 9605ec5..f55402a 100644
--- a/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java
+++ b/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java
@@ -180,7 +180,11 @@
 	@Autowired
 	private TAbnormalPayOrderMapper abnormalPayOrderMapper;
 
-
+	@Resource
+	private CarMapper carMapper;
+	
+	@Resource
+	private CarModelMapper carModelMapper;
 
 	@Autowired
 	private TDriverPromotionActivityService driverPromotionActivityService;
@@ -1259,7 +1263,6 @@
 		orderCrossCity.setPassengers(userInfo.getNickName());
 		orderCrossCity.setPassengersPhone(userInfo.getPhone());
 		orderCrossCity.setPeopleNumber(orderCrossCityWarpper.getPeopleNumber());
-		orderCrossCity.setSeatNumber(orderCrossCityWarpper.getSeatNumber());
 		List<OrderCrossCity> orderCrossCities = this.selectList(new EntityWrapper<OrderCrossCity>().eq("orderNum", orderCrossCity.getOrderNum()).eq("isDelete", 1));
 		orderCrossCity.setSort(orderCrossCities.size() + 1);
 		orderCrossCity.setState(7);//待支付
@@ -1271,6 +1274,11 @@
 		orderCrossCity.setIsDelete(1);
 		orderCrossCity.setRemark(orderCrossCityWarpper.getRemark());
 		orderCrossCity.setIsReassign(1);
+		if(1 == orderCrossCity.getTravelMode()){
+			orderCrossCity.setSeatNumber(orderCrossCityWarpper.getSeatNumber());
+		}else{
+			orderCrossCity.setSeatNumber(lineShiftDriver.getLaveSeatNumber());
+		}
 //        //调用高德创建轨迹
 //        String s = gdFalconUtil.selectTerminal(driver.getPhone());
 //        String track = gdFalconUtil.createTrack(s);
@@ -1289,7 +1297,15 @@
 
 		// 是否推广订单
 		Integer promotion = isPromotion(uid);
-		orderCrossCity.setPromotion(promotion);
+		if(promotion!=null){
+			orderCrossCity.setPromotion(2);
+			Driver driver1 = driverService.selectById(promotion);
+			orderCrossCity.setPromotionUser(driver1.getName());
+			orderCrossCity.setPromotionPhone(driver1.getPhone());
+			orderCrossCity.setPromotionDriverId(promotion);
+		}else{
+			orderCrossCity.setPromotion(1);
+		}
 
 		this.insert(orderCrossCity);
 		
@@ -1384,17 +1400,17 @@
 		return ResultUtil.success(baseWarpper);
 	}
 
+
 	private Integer isPromotion(Integer userId){
 		UserInfo userInfo = userInfoService.selectById(userId);
 		if(userInfo.getBindDriverId()!=null && userInfo.getBindExpireDate().getTime()<=System.currentTimeMillis()){
 			String registAreaCode = userInfo.getRegistAreaCode();
-			TDriverPromotionActivity tDriverPromotionActivity = driverPromotionActivityService.selectOne(new EntityWrapper<TDriverPromotionActivity>().eq("districtCode", registAreaCode).ge("startTime", new Date()).lt("endTime", new Date()).last("AND FIND_IN_SET(" + 3 + ", bizType) limit 1"));
+			TDriverPromotionActivity tDriverPromotionActivity = driverPromotionActivityService.selectOne(new EntityWrapper<TDriverPromotionActivity>().eq("state",1).eq("districtCode", registAreaCode).le("startTime", new Date()).ge("endTime", new Date()).last("AND FIND_IN_SET(" + 3 + ", bizType) limit 1"));
 			if(tDriverPromotionActivity!=null){
-				return 2;
+				return userInfo.getBindDriverId();
 			}
 		}
 		return null;
-
 	}
 	/**
 	 * 获取订单
@@ -1433,7 +1449,12 @@
         if(map.get("abnormalIntro")!=null){
             map.put("appealStatus", 1);
         }
-        
+        if(map.get("travelMode")!=null &&map.get("travelMode").toString().equals("2") ){
+            map.put("zwNum", 1);
+        }else {
+			map.put("zwNum", 2);
+		}
+
 		Map<String, String> geocode = gdMapGeocodingUtil.geocode(map.get("startLon").toString(), map.get("startLat").toString());
 		map.put("startCity", geocode.get("city"));
 		geocode = gdMapGeocodingUtil.geocode(map.get("endLon").toString(), map.get("endLat").toString());
@@ -1982,17 +2003,30 @@
 					}
 				}).start();
 			}
+			Driver driver = driverService.selectById(orderCrossCity.getDriverId());
 			
 			//修改司机座位
-			LineShiftDriver lineShiftDriver = lineShiftDriverMapper.selectById(orderCrossCity.getLineShiftDriverId());
-			lineShiftDriver.setLaveSeat(lineShiftDriver.getLaveSeat() + orderCrossCity.getPeopleNumber());
-			lineShiftDriver.setLaveSeatNumber(lineShiftDriver.getLaveSeatNumber() + (orderCrossCity.getTravelMode() == 1 ? "," : "") + orderCrossCity.getSeatNumber());
-			lineShiftDriverMapper.updateById(lineShiftDriver);
+			if(1 == orderCrossCity.getTravelMode()){
+				LineShiftDriver lineShiftDriver = lineShiftDriverMapper.selectById(orderCrossCity.getLineShiftDriverId());
+				lineShiftDriver.setLaveSeat(lineShiftDriver.getLaveSeat() + orderCrossCity.getPeopleNumber());
+				lineShiftDriver.setLaveSeatNumber(lineShiftDriver.getLaveSeatNumber() + (orderCrossCity.getTravelMode() == 1 ? "," : "") + orderCrossCity.getSeatNumber());
+				lineShiftDriverMapper.updateById(lineShiftDriver);
+			}else{
+				Car car = carMapper.selectById(driver.getCarId());
+				CarModel carModel = carModelMapper.selectById(car.getCarModelId());
+				LineShiftDriver lineShiftDriver = lineShiftDriverMapper.selectById(orderCrossCity.getLineShiftDriverId());
+				lineShiftDriver.setLaveSeat(carModel.getSeat() - 1);
+				String seatNumber = "";
+				for(int i = 1; i < carModel.getSeat(); i++){
+					seatNumber += i + ",";
+				}
+				lineShiftDriver.setLaveSeatNumber(seatNumber.substring(0, seatNumber.length() - 1));
+				lineShiftDriverMapper.updateById(lineShiftDriver);
+			}
 			
 			//修改司机为空闲
 			List<OrderCrossCity> orderCrossCities = orderCrossCityMapper.queryByDriverId(orderCrossCity.getDriverId(), 2, 3, 4, 5, 11);
 			if (orderCrossCities.size() == 0) {
-				Driver driver = driverService.selectById(orderCrossCity.getDriverId());
 				driver.setState(2);
 				driverService.updateById(driver);
 			}
@@ -2100,64 +2134,67 @@
 	@Override
 	public OrderServerWarpper queryOrderServer(Integer orderId, Integer uid) throws Exception {
 		OrderCrossCity orderCrossCity = this.selectById(orderId);
-		//计算预计距离和剩余时间
-		String value = (String) redisTemplate.opsForValue().get("DRIVER" + String.valueOf(orderCrossCity.getDriverId()));
-		if (null == value || "".equals(value)) {
-			System.err.println("司机没有上传位置信息");
+		if(null != orderCrossCity){
+			//计算预计距离和剩余时间
+			String value = (String) redisTemplate.opsForValue().get("dache:DRIVER" + String.valueOf(orderCrossCity.getDriverId()));
+			if (null == value || "".equals(value)) {
+				System.err.println("司机没有上传位置信息");
+				
+				//调用获取轨迹中的数据
+				List<Map<String, Object>> list = orderPositionService.queryTrack(orderId, 3);
+				if (list.size() > 0) {
+					Map<String, Object> map = list.get(list.size() - 1);
+					value = map.get("lon") + "," + map.get("lat");
+				}
+			}
 			
-			//调用获取轨迹中的数据
-			List<Map<String, Object>> list = orderPositionService.queryTrack(orderId, 3);
-			if (list.size() > 0) {
-				Map<String, Object> map = list.get(list.size() - 1);
-				value = map.get("lon") + "," + map.get("lat");
+			OrderServerWarpper orderServerWarpper = new OrderServerWarpper();
+			orderServerWarpper.setOrderId(orderCrossCity.getId());
+			orderServerWarpper.setOrderType(3);
+			orderServerWarpper.setState(orderCrossCity.getState());
+			orderServerWarpper.setLon(null != value ? value.split(",")[0] : "0.0");
+			orderServerWarpper.setLat(null != value ? value.split(",")[1] : "0.0");
+			orderServerWarpper.setReassignNotice(orderCrossCity.getReassignNotice());
+			if (orderCrossCity.getState() == 2 || orderCrossCity.getState() == 3) {//前往预约地
+				// TODO: 2023/11/4 无法修改
+				Map<String, String> distance = gdMapElectricFenceUtil.getDistance(value, orderCrossCity.getStartLon() + "," + orderCrossCity.getStartLat(), 1);
+				String d = "0";
+				String t = "0";
+				if (null == distance) {
+					System.err.println("查询距离出错了");
+				} else {
+					d = new BigDecimal(distance.get("distance")).divide(new BigDecimal(1000), new MathContext(2, RoundingMode.HALF_EVEN)).toString();
+					t = new BigDecimal(distance.get("duration")).divide(new BigDecimal(60), new MathContext(2, RoundingMode.HALF_EVEN)).intValue() + "";
+				}
+				orderServerWarpper.setReservationMileage(d);
+				orderServerWarpper.setReservationTime(t);
+				orderServerWarpper.setServedMileage("0");
+				orderServerWarpper.setServedTime("0");
+				orderServerWarpper.setLaveMileage("0");
+				orderServerWarpper.setLaveTime("0");
 			}
-		}
-		
-		OrderServerWarpper orderServerWarpper = new OrderServerWarpper();
-		orderServerWarpper.setOrderId(orderCrossCity.getId());
-		orderServerWarpper.setOrderType(3);
-		orderServerWarpper.setState(orderCrossCity.getState());
-		orderServerWarpper.setLon(null != value ? value.split(",")[0] : "0.0");
-		orderServerWarpper.setLat(null != value ? value.split(",")[1] : "0.0");
-		orderServerWarpper.setReassignNotice(orderCrossCity.getReassignNotice());
-		if (orderCrossCity.getState() == 2 || orderCrossCity.getState() == 3) {//前往预约地
-			// TODO: 2023/11/4 无法修改
-			Map<String, String> distance = gdMapElectricFenceUtil.getDistance(value, orderCrossCity.getStartLon() + "," + orderCrossCity.getStartLat(), 1);
-			String d = "0";
-			String t = "0";
-			if (null == distance) {
-				System.err.println("查询距离出错了");
-			} else {
-				d = new BigDecimal(distance.get("distance")).divide(new BigDecimal(1000), new MathContext(2, RoundingMode.HALF_EVEN)).toString();
-				t = new BigDecimal(distance.get("duration")).divide(new BigDecimal(60), new MathContext(2, RoundingMode.HALF_EVEN)).intValue() + "";
+			if (orderCrossCity.getState() == 5 || orderCrossCity.getState() == 6) {//服务中
+				// TODO: 2023/11/4 无法修改
+				Map<String, String> distance = gdMapElectricFenceUtil.getDistance(value, orderCrossCity.getEndLon() + "," + orderCrossCity.getEndLat(), 1);
+				String d = "0";
+				String t = "0";
+				if (null == distance) {
+					System.err.println("查询距离出错了");
+				} else {
+					d = new BigDecimal(distance.get("distance")).divide(new BigDecimal(1000), new MathContext(2, RoundingMode.HALF_EVEN)).toString();
+					t = new BigDecimal(distance.get("duration")).divide(new BigDecimal(60), new MathContext(2, RoundingMode.HALF_EVEN)).intValue() + "";
+				}
+				orderServerWarpper.setReservationMileage("0");
+				orderServerWarpper.setReservationTime("0");
+				orderServerWarpper.setServedMileage(String.valueOf(orderCrossCity.getMileage() / 1000));
+				orderServerWarpper.setServedTime(Long.valueOf((new Date().getTime() - orderCrossCity.getStartServiceTime().getTime()) / 60000).intValue() + "");
+				orderServerWarpper.setLaveMileage(d);
+				orderServerWarpper.setLaveTime(t);
 			}
-			orderServerWarpper.setReservationMileage(d);
-			orderServerWarpper.setReservationTime(t);
-			orderServerWarpper.setServedMileage("0");
-			orderServerWarpper.setServedTime("0");
-			orderServerWarpper.setLaveMileage("0");
-			orderServerWarpper.setLaveTime("0");
+			
+			return orderServerWarpper;
 		}
-		if (orderCrossCity.getState() == 5 || orderCrossCity.getState() == 6) {//服务中
-			// TODO: 2023/11/4 无法修改
-			Map<String, String> distance = gdMapElectricFenceUtil.getDistance(value, orderCrossCity.getEndLon() + "," + orderCrossCity.getEndLat(), 1);
-			String d = "0";
-			String t = "0";
-			if (null == distance) {
-				System.err.println("查询距离出错了");
-			} else {
-				d = new BigDecimal(distance.get("distance")).divide(new BigDecimal(1000), new MathContext(2, RoundingMode.HALF_EVEN)).toString();
-				t = new BigDecimal(distance.get("duration")).divide(new BigDecimal(60), new MathContext(2, RoundingMode.HALF_EVEN)).intValue() + "";
-			}
-			orderServerWarpper.setReservationMileage("0");
-			orderServerWarpper.setReservationTime("0");
-			orderServerWarpper.setServedMileage(String.valueOf(orderCrossCity.getMileage() / 1000));
-			orderServerWarpper.setServedTime(Long.valueOf((new Date().getTime() - orderCrossCity.getStartServiceTime().getTime()) / 60000).intValue() + "");
-			orderServerWarpper.setLaveMileage(d);
-			orderServerWarpper.setLaveTime(t);
-		}
-		
-		return orderServerWarpper;
+		return new OrderServerWarpper();
 	}
 	
 	
@@ -2416,7 +2453,7 @@
 							OrderPrivateCarServiceImpl.orderIds.add(orderPrivateCar.getId());//添加记录,防止调用接口重复提醒无人接单
 							OpenCity openCity = openCityService.openCity1(orderPrivateCar.getStartLon().toString(), orderPrivateCar.getStartLat().toString());
 							List<PushOrder> querys = pushOrderService.querys(null, 1, openCity.getId());//获取需要推送的次数
-							for (int i = 1; i <= querys.size() + 5; i++) {
+							for (int i = 1; i <= querys.size() + 15; i++) {
 								//订单被抢后的处理
 								Integer state = orderPrivateCarMapper.selectById(orderId).getState();
 								if (state != 1) {
@@ -2435,7 +2472,7 @@
 									for (Map<String, Integer> map : datas) {
 										Integer orderType = map.get("orderType");
 										Integer orderId = map.get("orderId");
-										if (orderType == 1 && orderId != orderPrivateCar.getId()) {
+										if (orderType == 1 && !orderId.equals(orderPrivateCar.getId())) {
 											orderPrivateCarMapper.deleteById(orderId);
 										}
 										if (orderType == 2) {
@@ -2471,7 +2508,7 @@
 								
 								//所有推送完后的处理
 								Boolean b = pushEndMap.get(orderPrivateCar.getCrossCityOrderId());
-								if (i == querys.size() + 5 && state == 1 && (null != b && !b.booleanValue())) {
+								if (i == querys.size() + 15 && state == 1 && (null != b && !b.booleanValue())) {
 									pushUtil.pushEndPush(1, orderPrivateCar.getUserId(), orderPrivateCar.getId(), 1);
 									OrderPrivateCarServiceImpl.orderIds.remove(orderPrivateCar.getId());
 									pushEndMap.put(orderPrivateCar.getCrossCityOrderId(), Boolean.TRUE);//推送后添加标识
@@ -2486,7 +2523,7 @@
 							OrderTaxiServiceImpl.orderIds.add(orderTaxi.getId());//添加记录,防止调用接口重复提醒无人接单
 							OpenCity openCity = openCityService.openCity1(orderTaxi.getStartLon().toString(), orderTaxi.getStartLat().toString());
 							List<PushOrder> querys = pushOrderService.querys(null, 2, openCity.getId());//获取需要推送的次数
-							for (int i = 1; i <= querys.size() + 5; i++) {
+							for (int i = 1; i <= querys.size() + 15; i++) {
 								//处理订单被抢
 								Integer state = orderTaxiMapper.selectById(orderId).getState();
 								if (state != 1) {
@@ -2508,7 +2545,7 @@
 										if (orderType == 1) {
 											orderPrivateCarMapper.deleteById(orderId);
 										}
-										if (orderType == 2 && orderId != orderTaxi.getId()) {
+										if (orderType == 2 && !orderId.equals(orderTaxi.getId())) {
 											orderTaxiMapper.deleteById(orderId);
 										}
 									}
@@ -2535,15 +2572,13 @@
 										if (bo) {
 											continue;
 										}
-										
-										
 										pushUtil.pushOrderState(2, driver.getId(), orderTaxi.getId(), 2, orderTaxi.getState(), pushOrder.getPushTime());
 									}
 								}
 								
 								//所有推送完后的处理
 								Boolean b = pushEndMap.get(orderTaxi.getCrossCityOrderId());
-								if (i == querys.size() + 5 && state == 1 && (null != b && !b.booleanValue())) {
+								if (i == querys.size() + 15 && state == 1 && (null != b && !b.booleanValue())) {
 									pushUtil.pushEndPush(1, orderTaxi.getUserId(), orderTaxi.getId(), 2);
 									OrderTaxiServiceImpl.orderIds.remove(orderTaxi.getId());
 									pushEndMap.put(orderTaxi.getCrossCityOrderId(), Boolean.TRUE);//推送后添加标识

--
Gitblit v1.7.1