From 7bbdeb81fe1a4f147b17085783e28d3c53d6d867 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期四, 14 八月 2025 18:36:34 +0800
Subject: [PATCH] 修改bug

---
 ManagementQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TDriverPromotionActivityController.java |   40 +++++++++++++++++++++++++++++++++++++++-
 1 files changed, 39 insertions(+), 1 deletions(-)

diff --git a/ManagementQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TDriverPromotionActivityController.java b/ManagementQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TDriverPromotionActivityController.java
index 68ad9b0..c4e710f 100644
--- a/ManagementQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TDriverPromotionActivityController.java
+++ b/ManagementQYTTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/specialTrain/TDriverPromotionActivityController.java
@@ -1,6 +1,7 @@
 package com.stylefeng.guns.modular.system.controller.specialTrain;
 
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.baomidou.mybatisplus.mapper.Wrapper;
 import com.rabbitmq.client.LongString;
 import com.stylefeng.guns.core.base.controller.BaseController;
 import com.stylefeng.guns.core.beetl.ShiroExtUtil;
@@ -29,6 +30,7 @@
 import java.text.ParseException;
 import java.text.SimpleDateFormat;
 import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 控制器
@@ -300,10 +302,33 @@
         tDriverPromotionActivity.setProvinceCode(province);
         tDriverPromotionActivity.setCityCode(city);
         tDriverPromotionActivity.setDistrictCode(area);
+        Wrapper<TDriverPromotionActivity> eq = new EntityWrapper<TDriverPromotionActivity>().eq("provinceCode", province).eq("cityCode", city);
+        if(area!=null && !area.equals("")){
+            eq.eq("districtCode", area);
+        }
         String s = time.split(" - ")[0] + " 00:00:00";
         String s1 = time.split(" - ")[1] + " 23:59:59";
         tDriverPromotionActivity.setStartTime(simpleDateFormat.parse(s));
         tDriverPromotionActivity.setEndTime(simpleDateFormat.parse(s1));
+        List<TDriverPromotionActivity> tDriverPromotionActivities = tDriverPromotionActivityService.selectList(eq);
+        for (TDriverPromotionActivity driverPromotionActivity : tDriverPromotionActivities) {
+            // 判断时间是否有交集
+            if (isTimeOverlap(driverPromotionActivity, tDriverPromotionActivity)) {
+                return "602"; // 时间冲突
+            }
+
+        }
+
+
+
+        List<TRegion> code = tRegionService.selectList(new EntityWrapper<TRegion>().in("code", Arrays.asList(province, city, area)));
+
+        tDriverPromotionActivity.setProvince(code.stream().filter(e->e.getCode().equals( province)).collect(Collectors.toList()).get(0).getName());
+        tDriverPromotionActivity.setCity(code.stream().filter(e->e.getCode().equals( city)).collect(Collectors.toList()).get(0).getName());
+        if(area!=null && !"".equals(area)){
+            tDriverPromotionActivity.setDistrict(code.stream().filter(e->e.getCode().equals(area)).collect(Collectors.toList()).get(0).getName());
+        }
+
         tDriverPromotionActivity.setCommissionRatio(BigDecimal.valueOf(commissionRatio));
         tDriverPromotionActivity.setBindingDays(bindingDays);
         tDriverPromotionActivity.setActivityDesc(ToolUtil.cleanXSS(content));
@@ -313,7 +338,13 @@
         tDriverPromotionActivityService.insert(tDriverPromotionActivity);
         return SUCCESS_TIP;
     }
-
+    // 更完整的时间交集判断方法
+    private boolean isTimeOverlap(TDriverPromotionActivity existing, TDriverPromotionActivity newActivity) {
+        // 两个时间段有交集的条件:
+        // existing的开始时间 <= newActivity的结束时间 且 existing的结束时间 >= newActivity的开始时间
+        return existing.getStartTime().getTime() <= newActivity.getEndTime().getTime() &&
+                existing.getEndTime().getTime() >= newActivity.getStartTime().getTime();
+    }
     /**
      * 删除
      */
@@ -356,6 +387,13 @@
         tDriverPromotionActivity.setProvinceCode(province);
         tDriverPromotionActivity.setCityCode(city);
         tDriverPromotionActivity.setDistrictCode(area);
+        List<TRegion> code = tRegionService.selectList(new EntityWrapper<TRegion>().in("code", Arrays.asList(province, city, area)));
+
+        tDriverPromotionActivity.setProvince(code.stream().filter(e->e.getCode().equals( province)).collect(Collectors.toList()).get(0).getName());
+        tDriverPromotionActivity.setCity(code.stream().filter(e->e.getCode().equals( city)).collect(Collectors.toList()).get(0).getName());
+        if(area!=null && !"".equals(area)){
+            tDriverPromotionActivity.setDistrict(code.stream().filter(e->e.getCode().equals(area)).collect(Collectors.toList()).get(0).getName());
+        }
         String s = time.split(" - ")[0] + " 00:00:00";
         String s1 = time.split(" - ")[1] + " 23:59:59";
         tDriverPromotionActivity.setStartTime(simpleDateFormat.parse(s));

--
Gitblit v1.7.1