From 8522e469e00e1cf6c0410165b0f76c806c13ca83 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期六, 16 八月 2025 09:17:04 +0800
Subject: [PATCH] 合并代码

---
 UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java |   73 +++++++++++++++++++++++++++++-------
 1 files changed, 59 insertions(+), 14 deletions(-)

diff --git a/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java b/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java
index 2cfd3a2..9b5da04 100644
--- a/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java
+++ b/UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java
@@ -170,9 +170,7 @@
 	@Autowired
 	private ITaxiCardService taxiCardService;
 	
-	@Autowired
-	private ITaxiCardPaymentService taxiCardPaymentService;
-	
+
 	@Autowired
 	private IUserUserService userUserService;
 	
@@ -1615,7 +1613,12 @@
 				//调用中台创建订单及拉起支付接口
 				TradeOrderCreateData tradeOrderCreateData = new TradeOrderCreateData();
 				tradeOrderCreateData.setTreatShopId(driver.getEmpId().toString());
-				tradeOrderCreateData.setField1("{\"profitSharing\":\"1\",\"isPromote\":\"" + (orderTaxi.getPromotion() == 2 ? 1 : 0) + "\"}");
+				//追缴单不要分账
+				if(0 == orderTaxi.getRecoveryOrder()){
+					tradeOrderCreateData.setField1("{\"profitSharing\":\"1\",\"isPromote\":\"" + (orderTaxi.getPromotion() == 2 ? 1 : 0) + "\"}");
+				}else{
+					tradeOrderCreateData.setField1("{\"profitSharing\":\"0\",\"isPromote\":\"0\"}");
+				}
 				tradeOrderCreateData.setCharge(new BigDecimal(orderMoney));
 				tradeOrderCreateData.setOrderId(orderTaxi.getTravelId());
 				tradeOrderCreateData.setOrderNo("TA" + orderTaxi.getId());
@@ -1629,6 +1632,11 @@
 				List<GoodsInfoRequest> goodsInfo = new ArrayList<>();
 				GoodsInfoRequest goodsInfoRequest = new GoodsInfoRequest();
 				goodsInfoRequest.setSubOpenId(userInfo.getAppletsOpenId());
+				if(0 == orderTaxi.getRecoveryOrder()){
+					goodsInfoRequest.setProfitSharing("1");
+				}else{
+					goodsInfoRequest.setProfitSharing("0");
+				}
 				goodsInfo.add(goodsInfoRequest);
 				tradeOrderCreateData.setGoodsInfo(goodsInfo);
 				TradeOrderCreate tradeOrderCreate = OrderUtil.tradeOrderCreate1(tradeOrderCreateData);
@@ -1641,7 +1649,7 @@
 			}else{
 				//拉起支付
 				TradePayOff1Data tradePayOff1Data = new TradePayOff1Data();
-				tradePayOff1Data.setPartnerPayId("PR" + orderTaxi.getId());
+				tradePayOff1Data.setPartnerPayId(orderTaxi.getTravelId());
 				tradePayOff1Data.setTotalFee(Double.valueOf(orderMoney * 100).intValue() + "");
 				tradePayOff1Data.setRetUrl(path);
 				tradePayOff1Data.setClientIp(ip);
@@ -1649,6 +1657,11 @@
 				List<GoodsInfoRequest> goodsInfo = new ArrayList<>();
 				GoodsInfoRequest goodsInfoRequest = new GoodsInfoRequest();
 				goodsInfoRequest.setSubOpenId(userInfo.getAppletsOpenId());
+				if(0 == orderTaxi.getRecoveryOrder()){
+					goodsInfoRequest.setProfitSharing("1");
+				}else{
+					goodsInfoRequest.setProfitSharing("0");
+				}
 				goodsInfo.add(goodsInfoRequest);
 				tradePayOff1Data.setGoodsInfo(goodsInfo);
 				PayInfo payInfo = OrderUtil.tradePayOff1(tradePayOff1Data);
@@ -1713,6 +1726,9 @@
 			//添加收入
 			Map<String, Object> map = incomeService.saveIncome(orderTaxi.getId(), 2, orderTaxi.getOrderMoney());
 			orderTaxi.setSplitAllocation(JSON.toJSONString(map));
+
+			this.updateAllColumnById(orderTaxi);
+			promotion(orderTaxi.getId());
 			
 			// TODO: 2020/5/24 这里需要给司机和用户推送订单状态
 			new Thread(new Runnable() {
@@ -1746,8 +1762,10 @@
 			resultUtil = appOrderController.placeAnOrder(new BigDecimal(orderMoney), 4, orderId, 9, integer);
 			
 		}
-		
-		this.updateAllColumnById(orderTaxi);
+		if(payType!=3){
+			this.updateAllColumnById(orderTaxi);
+		}
+
 		return resultUtil;
 	}
 	
@@ -1911,7 +1929,7 @@
 				OpenCity openCity = openCityService.openCity1(orderTaxi.getStartLon().toString(), orderTaxi.getStartLat().toString());
 				List<PushOrder> querys = pushOrderService.querys(null, 2, openCity.getId());//获取需要推送的次数
 				int time = 0;
-				for (int i = 1; i <= querys.size() + 5; i++) {
+				for (int i = 1; i <= querys.size() + 15; i++) {
 					int finalI = i;
 					PushOrder pushOrder = querys.stream().filter(s -> s.getType() == (finalI <= 3 ? finalI : 3)).findFirst().orElse(null);
 					time += pushOrder.getPushTime() * 1000;
@@ -1944,7 +1962,7 @@
 		//计算预计距离和剩余时间
 		String value = null;
 		if (null != orderTaxi.getDriverId()) {
-			value = (String) redisTemplate.opsForValue().get("DRIVER" + orderTaxi.getDriverId());
+			value = (String) redisTemplate.opsForValue().get("dache_DRIVER" + orderTaxi.getDriverId());
 			if (null == value || "".equals(value)) {
 				System.err.println("司机没有上传位置信息");
 				
@@ -2295,7 +2313,7 @@
 					OpenCity openCity = openCityService.openCity1(orderTaxi.getStartLon().toString(), orderTaxi.getStartLat().toString());
 					List<PushOrder> querys = pushOrderService.querys(null, 2, openCity.getId());//获取需要推送的次数
 					//整轮派单结束,若无司机接单,系统自动增加派单5轮,若增加5轮后任无司机接单,则系统结束派单,乘客端显示无司机接单、是否再次打车
-					for (int i = 1; i <= querys.size() + 5; i++) {
+					for (int i = 1; i <= querys.size() + 15; i++) {
 						int finalI = i;
 						PushOrder pushOrder = querys.stream().filter(s -> s.getType() == (finalI <= 3 ? finalI : 3)).findFirst().orElse(null);
 						System.out.println("pushOrder:" + pushOrder);
@@ -2322,12 +2340,12 @@
 							}
 						}
 						Thread.sleep(pushOrder.getPushTime() * 1000);//设置等待时间
-						OrderTaxi orderTaxi1 = OrderTaxiServiceImpl.this.selectById(orderTaxi.getId());
+						OrderPrivateCar orderTaxi1 = orderPrivateCarService.selectById(orderTaxi.getId());
 						Integer state = orderTaxi1.getState();
 						if (state != 1) {
 							break;
 						}
-						if (i == querys.size() + 5 && state == 1) {
+						if (i == querys.size() + 15 && state == 1) {
 							pushUtil.pushEndPush(1, orderTaxi.getUserId(), orderTaxi.getId(), 2);
 							orderIds.remove(orderTaxi.getId());
 						}
@@ -2462,7 +2480,7 @@
 		}
 		orderTaxi.setAbnormalIntro(abnormalIntro);
 		orderTaxi.setAbnormalImg(abnormalImg);
-		orderTaxi.setAbnormal(1);
+		orderTaxi.setAbnormal(2);
 		this.baseMapper.updateById(orderTaxi);
 	}
 	
@@ -2472,12 +2490,14 @@
 		UserInfo userInfo = userInfoService.selectById(orderTaxi.getUserId());
 		if (orderTaxi.getPromotionDriverId() != null) {
 			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(" + 2 + ", bizType) limit 1"));
+			TDriverPromotionActivity tDriverPromotionActivity = driverPromotionActivityService.selectOne(new EntityWrapper<TDriverPromotionActivity>().eq("districtCode", registAreaCode).le("startTime", new Date()).ge("endTime", new Date()).last("AND FIND_IN_SET(" + 2 + ", bizType) limit 1"));
 			if (tDriverPromotionActivity != null) {
 				Double payMoney = orderTaxi.getPayMoney();
 				BigDecimal bigDecimal = tDriverPromotionActivity.getCommissionRatio().divide(new BigDecimal(100), 2, RoundingMode.HALF_UP).multiply(new BigDecimal(payMoney)).setScale(2, RoundingMode.HALF_UP);
 				orderTaxi.setPromotionDriverId(userInfo.getBindDriverId());
 				orderTaxi.setPromotionMoney(bigDecimal);
+				orderTaxi.setPromotionActivityId(tDriverPromotionActivity.getId());
+				orderTaxi.setSuccessTime(new Date());
 				this.baseMapper.updateById(orderTaxi);
 			}
 		}
@@ -2491,4 +2511,29 @@
 			}
 		}
 	}
+
+	@Override
+	public List<Map<String, Object>> queryMyTripList(Integer uid, Integer pageNum, Integer size) throws Exception {
+		pageNum = (pageNum - 1) * size;
+		List<Map<String, Object>> maps = orderTaxiMapper.queryMyTripList(uid, pageNum, size);
+		for (Map<String, Object> map : maps) {
+			if (Integer.valueOf(String.valueOf(map.get("state"))) == 11) {
+				map.put("state", map.get("oldState"));
+			}
+		}
+		return maps;
+	}
+
+	@Override
+	public List<Map<String, Object>> queryMyTripListAll(Integer uid) throws Exception {
+
+		List<Map<String, Object>> maps = orderTaxiMapper.queryMyTripListAll(uid);
+		for (Map<String, Object> map : maps) {
+			if (Integer.valueOf(String.valueOf(map.get("state"))) == 11) {
+				map.put("state", map.get("oldState"));
+			}
+		}
+		return maps;
+	}
+
 }

--
Gitblit v1.7.1