From 92480c7fd17a6bf89205ffcf4b78eef17988f0d5 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期五, 01 八月 2025 19:22:11 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java |  246 +++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 238 insertions(+), 8 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 49702bf..800a5a2 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
@@ -15,14 +15,13 @@
 import com.stylefeng.guns.modular.specialTrain.dao.OrderPrivateCarMapper;
 import com.stylefeng.guns.modular.specialTrain.model.OrderPrivateCar;
 import com.stylefeng.guns.modular.specialTrain.server.IOrderPrivateCarService;
-import com.stylefeng.guns.modular.system.dao.RegionMapper;
-import com.stylefeng.guns.modular.system.dao.SensitiveWordsMapper;
-import com.stylefeng.guns.modular.system.dao.SysIntegralMapper;
-import com.stylefeng.guns.modular.system.dao.UserActivityDiscount1Mapper;
+import com.stylefeng.guns.modular.system.dao.*;
 import com.stylefeng.guns.modular.system.model.*;
 import com.stylefeng.guns.modular.system.model.vo.UnPayOrderVO;
 import com.stylefeng.guns.modular.system.service.*;
 import com.stylefeng.guns.modular.system.util.*;
+import com.stylefeng.guns.modular.system.util.qianyuntong.OrderUtil;
+import com.stylefeng.guns.modular.system.util.qianyuntong.model.*;
 import com.stylefeng.guns.modular.system.warpper.*;
 import com.stylefeng.guns.modular.taxi.dao.OrderTaxiMapper;
 import com.stylefeng.guns.modular.taxi.model.OrderTaxi;
@@ -151,7 +150,7 @@
 	private IDriverServiceService driverServiceService;
 	
 	@Autowired
-	private GDFalconUtil gdFalconUtil;
+	private TAbnormalPayOrderMapper abnormalPayOrderMapper;
 	
 	@Autowired
 	private IOrderPrivateCarService orderPrivateCarService;
@@ -189,6 +188,9 @@
 	@Value("${callbackPath}")
 	private String callbackPath;
 	
+	
+	@Autowired
+	private TDriverPromotionActivityService driverPromotionActivityService;
 	
 	/**
 	 * 出租车下单操作
@@ -497,17 +499,71 @@
 					orderCancelService.saveData(orderPrivateCar1.getId(), 1, "无司机接单", "无司机接单", null, null, 2, 1, uid);
 					orderPrivateCar1.setState(10);
 					orderPrivateCarService.updateById(orderPrivateCar1);
+					
+					Driver driver1 = null;
+					Company company = null;
+					//中台修改订单状态
+					ModifyTravelItineraryRequest request = new ModifyTravelItineraryRequest();
+					request.setOrderId(orderPrivateCar1.getTravelId());
+					request.setStatus(orderPrivateCar1.getState());
+					if (null != orderPrivateCar1.getDriverId()) {
+						driver1 = driverService.selectById(orderPrivateCar1.getDriverId());
+						company = companyService.selectById(driver1.getCompanyId());
+						request.setDriverId(driver1.getEmpId().toString());
+						request.setSupplierShopId(company.getEnterCode());
+					}
+					if (2 == orderPrivateCar1.getPromotion()) {
+						Driver driver2 = driverService.selectById(orderPrivateCar1.getPromotionDriverId());
+						request.setPromoterId(driver2.getEmpId().toString());
+					}
+					OrderUtil.modifyTravelItinerary(request);
 				}
 				List<OrderTaxi> list1 = this.selectList(new EntityWrapper<OrderTaxi>().eq("type", 2).eq("crossCityOrderId", orderTaxi.getCrossCityOrderId()).eq("place", orderTaxi.getPlace()));
 				for (OrderTaxi orderTaxi1 : list1) {
 					orderCancelService.saveData(orderTaxi1.getId(), 2, "无司机接单", "无司机接单", null, null, 2, 1, uid);
 					orderTaxi1.setState(10);
 					this.updateById(orderTaxi1);
+					
+					Driver driver1 = null;
+					Company company = null;
+					//中台修改订单状态
+					ModifyTravelItineraryRequest request = new ModifyTravelItineraryRequest();
+					request.setOrderId(orderTaxi1.getTravelId());
+					request.setStatus(orderTaxi1.getState());
+					if (null != orderTaxi1.getDriverId()) {
+						driver1 = driverService.selectById(orderTaxi1.getDriverId());
+						company = companyService.selectById(driver1.getCompanyId());
+						request.setDriverId(driver1.getEmpId().toString());
+						request.setSupplierShopId(company.getEnterCode());
+					}
+					if (2 == orderTaxi1.getPromotion()) {
+						Driver driver2 = driverService.selectById(orderTaxi1.getPromotionDriverId());
+						request.setPromoterId(driver2.getEmpId().toString());
+					}
+					OrderUtil.modifyTravelItinerary(request);
 				}
 			} else {
 				integer = orderCancelService.saveData(id, 2, "无司机接单", "无司机接单", null, null, 2, 1, uid);
 				orderTaxi.setState(10);
 				this.updateById(orderTaxi);
+				
+				Driver driver1 = null;
+				Company company = null;
+				//中台修改订单状态
+				ModifyTravelItineraryRequest request = new ModifyTravelItineraryRequest();
+				request.setOrderId(orderTaxi.getTravelId());
+				request.setStatus(orderTaxi.getState());
+				if (null != orderTaxi.getDriverId()) {
+					driver1 = driverService.selectById(orderTaxi.getDriverId());
+					company = companyService.selectById(driver1.getCompanyId());
+					request.setDriverId(driver1.getEmpId().toString());
+					request.setSupplierShopId(company.getEnterCode());
+				}
+				if (2 == orderTaxi.getPromotion()) {
+					Driver driver2 = driverService.selectById(orderTaxi.getPromotionDriverId());
+					request.setPromoterId(driver2.getEmpId().toString());
+				}
+				OrderUtil.modifyTravelItinerary(request);
 			}
 		} else {
 			OpenCity openCity = openCityService.openCity1(orderTaxi.getStartLon().toString(), orderTaxi.getStartLat().toString());
@@ -524,6 +580,24 @@
 					this.updateById(orderTaxi);
 				}
 				this.deleteTask(id);//删除定时任务
+				
+				Driver driver1 = null;
+				Company company = null;
+				//中台修改订单状态
+				ModifyTravelItineraryRequest request = new ModifyTravelItineraryRequest();
+				request.setOrderId(orderTaxi.getTravelId());
+				request.setStatus(orderTaxi.getState());
+				if (null != orderTaxi.getDriverId()) {
+					driver1 = driverService.selectById(orderTaxi.getDriverId());
+					company = companyService.selectById(driver1.getCompanyId());
+					request.setDriverId(driver1.getEmpId().toString());
+					request.setSupplierShopId(company.getEnterCode());
+				}
+				if (2 == orderTaxi.getPromotion()) {
+					Driver driver2 = driverService.selectById(orderTaxi.getPromotionDriverId());
+					request.setPromoterId(driver2.getEmpId().toString());
+				}
+				OrderUtil.modifyTravelItinerary(request);
 				
 				new Thread(new Runnable() {
 					@Override
@@ -643,6 +717,24 @@
 				orderTaxi.setTelX("");
 				orderTaxi.setBindId("");
 				this.updateById(orderTaxi);
+				
+				Driver driver = null;
+				Company company = null;
+				//中台修改订单状态
+				ModifyTravelItineraryRequest request = new ModifyTravelItineraryRequest();
+				request.setOrderId(orderTaxi.getTravelId());
+				request.setStatus(orderTaxi.getState());
+				if (null != orderTaxi.getDriverId()) {
+					driver = driverService.selectById(orderTaxi.getDriverId());
+					company = companyService.selectById(driver.getCompanyId());
+					request.setDriverId(driver.getEmpId().toString());
+					request.setSupplierShopId(company.getEnterCode());
+				}
+				if (2 == orderTaxi.getPromotion()) {
+					Driver driver1 = driverService.selectById(orderTaxi.getPromotionDriverId());
+					request.setPromoterId(driver1.getEmpId().toString());
+				}
+				OrderUtil.modifyTravelItinerary(request);
 				
 				orderCancel.setState(2);
 				orderCancel.setPayType(3);
@@ -1344,7 +1436,7 @@
 	
 	@Override
 	@Transactional(propagation = Propagation.REQUIRES_NEW)
-	public ResultUtil payTaxiOrder1(Integer payType, Integer orderId, Integer objectId, Integer objectType, Integer type) throws Exception {
+	public ResultUtil payTaxiOrder1(Integer payType, Integer orderId, Integer objectId, Integer objectType, Integer type, String path, String ip) throws Exception {
 		OrderTaxi orderTaxi = this.selectById(orderId);
 		if (orderTaxi.getState() == 8 || orderTaxi.getState() == 9) {
 			return ResultUtil.error("订单已完成支付,不允许重复支付", "");
@@ -1515,8 +1607,57 @@
 			if (orderMoney == 0) {
 				return ResultUtil.error("请使用余额支付");
 			}
-			String app = type == 1 ? "APP" : "JSAPI";
-			resultUtil = payMoneyUtil.weixinpay("完成订单", "", orderId + "_2_" + UUIDUtil.getRandomCode(5), orderMoney.toString(), "/base/wxPayOrderTaxi", app, userInfo.getAppletsOpenId());
+//			String app = type == 1 ? "APP" : "JSAPI";
+//			resultUtil = payMoneyUtil.weixinpay("完成订单", "", orderId + "_2_" + UUIDUtil.getRandomCode(5), orderMoney.toString(), "/base/wxPayOrderTaxi", app, userInfo.getAppletsOpenId());
+			
+			Driver driver = driverService.selectById(orderTaxi.getDriverId());
+			if(null == orderTaxi.getIsCreated() || 0 == orderTaxi.getIsCreated()){
+				//调用中台创建订单及拉起支付接口
+				TradeOrderCreateData tradeOrderCreateData = new TradeOrderCreateData();
+				tradeOrderCreateData.setTreatShopId(driver.getEmpId().toString());
+				tradeOrderCreateData.setField1("{\"profitSharing\":\"1\",\"isPromote\":\"" + (orderTaxi.getPromotion() == 2 ? 1 : 0) + "\"}");
+				tradeOrderCreateData.setCharge(new BigDecimal(orderMoney));
+				tradeOrderCreateData.setOrderId(orderTaxi.getTravelId());
+				tradeOrderCreateData.setOrderNo("TA" + orderTaxi.getId());
+				tradeOrderCreateData.setCustomerId(userInfo.getOnconUUID());
+				tradeOrderCreateData.setPartnerPayId(orderTaxi.getTravelId());
+				tradeOrderCreateData.setTotalFee(Double.valueOf(orderMoney * 100).intValue() + "");
+				tradeOrderCreateData.setOrderDesc("完成订单");
+				tradeOrderCreateData.setRetUrl(path);
+				tradeOrderCreateData.setClientIp(ip);
+				
+				List<GoodsInfoRequest> goodsInfo = new ArrayList<>();
+				GoodsInfoRequest goodsInfoRequest = new GoodsInfoRequest();
+				goodsInfoRequest.setSubOpenId(userInfo.getAppletsOpenId());
+				goodsInfo.add(goodsInfoRequest);
+				tradeOrderCreateData.setGoodsInfo(goodsInfo);
+				TradeOrderCreate tradeOrderCreate = OrderUtil.tradeOrderCreate1(tradeOrderCreateData);
+				PayInfo payInfo = tradeOrderCreate.getPayInfo();
+				if(!"000000".equals(payInfo.getRetCode())){
+					return ResultUtil.error(payInfo.getRetMsg());
+				}
+				orderTaxi.setIsCreated(1);
+				resultUtil = ResultUtil.success(payInfo.getData().getRedirectUrl());
+			}else{
+				//拉起支付
+				TradePayOff1Data tradePayOff1Data = new TradePayOff1Data();
+				tradePayOff1Data.setPartnerPayId("PR" + orderTaxi.getId());
+				tradePayOff1Data.setTotalFee(Double.valueOf(orderMoney * 100).intValue() + "");
+				tradePayOff1Data.setRetUrl(path);
+				tradePayOff1Data.setClientIp(ip);
+				tradePayOff1Data.setOrderDesc("完成订单");
+				List<GoodsInfoRequest> goodsInfo = new ArrayList<>();
+				GoodsInfoRequest goodsInfoRequest = new GoodsInfoRequest();
+				goodsInfoRequest.setSubOpenId(userInfo.getAppletsOpenId());
+				goodsInfo.add(goodsInfoRequest);
+				tradePayOff1Data.setGoodsInfo(goodsInfo);
+				PayInfo payInfo = OrderUtil.tradePayOff1(tradePayOff1Data);
+				if(!"000000".equals(payInfo.getRetCode())){
+					return ResultUtil.error(payInfo.getRetMsg());
+				}
+				resultUtil = ResultUtil.success(payInfo.getData().getRedirectUrl());
+			}
+			
 			paymentRecordService.saveData(1, orderTaxi.getUserId(), 1, orderId, 2, 1, orderMoney, "", 1);//添加预支付数据
 		}
 		if (payType == 2) {//支付宝支付
@@ -1736,6 +1877,13 @@
 		}
 		if (Integer.valueOf(String.valueOf(map.get("state"))) == 11) {
 			map.put("state", map.get("oldState"));
+		}
+		
+		if (Integer.valueOf(String.valueOf(map.get("state"))) == 7 && (map.get("responsibilityType") == null || Integer.valueOf(String.valueOf(map.get("responsibilityType"))) < 4)) {
+			map.put("appealButton", 1);
+		}
+		if (map.get("abnormalIntro") != null) {
+			map.put("appealStatus", 1);
 		}
 		String driverId = (String) redisTemplate.opsForValue().get("DEVICE_" + map.get("driverId"));
 		map.put("device", ToolUtil.isNotEmpty(driverId) ? 2 : 1);
@@ -2076,6 +2224,24 @@
 			orderTaxi.setTelX("");
 			this.updateById(orderTaxi);
 			
+			Driver driver = null;
+			Company company = null;
+			//中台修改订单状态
+			ModifyTravelItineraryRequest request = new ModifyTravelItineraryRequest();
+			request.setOrderId(orderTaxi.getTravelId());
+			request.setStatus(orderTaxi.getState());
+			if (null != orderTaxi.getDriverId()) {
+				driver = driverService.selectById(orderTaxi.getDriverId());
+				company = companyService.selectById(driver.getCompanyId());
+				request.setDriverId(driver.getEmpId().toString());
+				request.setSupplierShopId(company.getEnterCode());
+			}
+			if (2 == orderTaxi.getPromotion()) {
+				Driver driver1 = driverService.selectById(orderTaxi.getPromotionDriverId());
+				request.setPromoterId(driver1.getEmpId().toString());
+			}
+			OrderUtil.modifyTravelItinerary(request);
+			
 			query.setState(2);
 			query.setCode(order_id);
 			paymentRecordService.updateById(query);
@@ -2287,4 +2453,68 @@
 		
 		return unPayOrderVOList;
 	}
+	
+	@Override
+	public void addAppeal(Integer uid, Integer orderId, String abnormalIntro, String abnormalImg) {
+		OrderTaxi orderTaxi = this.selectById(orderId);
+		if (orderTaxi.getState() != 7 || orderTaxi.getAbnormalIntro() != null) {
+			throw new RuntimeException("此订单无法申诉");
+		}
+		orderTaxi.setAbnormalIntro(abnormalIntro);
+		orderTaxi.setAbnormalImg(abnormalImg);
+		orderTaxi.setAbnormal(2);
+		this.baseMapper.updateById(orderTaxi);
+	}
+	
+	@Override
+	public void promotion(Integer orderId) {
+		OrderTaxi orderTaxi = this.baseMapper.selectById(orderId);
+		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"));
+			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());
+				this.baseMapper.updateById(orderTaxi);
+			}
+		}
+		// 是否异常订单
+		if (orderTaxi.getResponsibilityType() != null && orderTaxi.getResponsibilityType() > 2) {
+			TAbnormalPayOrder tAbnormalPayOrder = abnormalPayOrderMapper.selectList(new EntityWrapper<TAbnormalPayOrder>().eq("type", 2).eq("orderNum", orderTaxi.getOrderNum())).stream().findFirst().orElse(null);
+			if (tAbnormalPayOrder != null) {
+				tAbnormalPayOrder.setPayStatus(2);
+				tAbnormalPayOrder.setPayTime(new Date());
+				abnormalPayOrderMapper.updateById(tAbnormalPayOrder);
+			}
+		}
+	}
+
+	@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