From 9828db9febf4ad5cb0b79a72eedca6922b466104 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期日, 27 七月 2025 13:54:52 +0800
Subject: [PATCH] 用户端修改  推广功能

---
 UserQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/crossCity/server/impl/OrderCrossCityServiceImpl.java |   42 ++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 40 insertions(+), 2 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 bb1de00..5eb8a64 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
@@ -192,6 +192,11 @@
 	
 	@Autowired
 	private IRegionService regionService;
+
+
+
+	@Autowired
+	private TDriverPromotionActivityService driverPromotionActivityService;
 	
 	
 	@Value("${callbackPath}")
@@ -1294,6 +1299,11 @@
 //            orderCrossCity.setTelX(map.get("telX"));
 //            orderCrossCity.setBindId(map.get("bindId"));
 //        }
+
+		// 是否推广订单
+		Integer promotion = isPromotion(uid);
+		orderCrossCity.setPromotion(promotion);
+
 		this.insert(orderCrossCity);
 		
 		if (driver.getState() == 2) {
@@ -1386,8 +1396,19 @@
 		
 		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"));
+			if(tDriverPromotionActivity!=null){
+				return 2;
+			}
+		}
+		return null;
+
+	}
 	/**
 	 * 获取订单
 	 *
@@ -2701,4 +2722,21 @@
 		orderCrossCity.setAbnormal(1);
 		this.baseMapper.updateById(orderCrossCity);
 	}
+
+	@Override
+	public void promotion(Integer orderId) {
+		OrderCrossCity orderCrossCity = this.baseMapper.selectById(orderId);
+		UserInfo userInfo = userInfoService.selectById(orderCrossCity.getUserId());
+		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"));
+			if(tDriverPromotionActivity!=null){
+				Double payMoney = orderCrossCity.getPayMoney();
+				BigDecimal bigDecimal = tDriverPromotionActivity.getCommissionRatio().divide(new BigDecimal(100), 2, RoundingMode.HALF_UP).multiply(new BigDecimal(payMoney)).setScale(2, RoundingMode.HALF_UP);
+				orderCrossCity.setPromotionDriverId(userInfo.getBindDriverId());
+				orderCrossCity.setPromotionMoney(bigDecimal);
+				this.baseMapper.updateById(orderCrossCity);
+			}
+		}
+	}
 }

--
Gitblit v1.7.1