From 92dc5972adbd94d47c0e6501ce4a7b51af09e3c3 Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Fri, 26 Jun 2026 22:37:57 +0800
Subject: [PATCH] refactor(workorder): 重构工单状态聚合逻辑-只处理撤回任务状态

---
 drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java |   19 ++++++++-----------
 1 files changed, 8 insertions(+), 11 deletions(-)

diff --git a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java
index 61bdade..36e1344 100644
--- a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java
+++ b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java
@@ -57,6 +57,7 @@
 import org.sxkj.gd.workorder.service.IGdTaskResultService;
 import org.sxkj.gd.workorder.service.IGdWorkOrderFlowService;
 import org.sxkj.gd.workorder.utils.GdPatrolReportWordUtil;
+import org.sxkj.gd.workorder.utils.WorkOrderStatusAggregator;
 import org.sxkj.gd.workorder.vo.GdPatrolTaskSimpleVO;
 import org.sxkj.gd.workorder.vo.GdPatrolTaskVO;
 import org.sxkj.gd.xingtu.JianXingtuApiService;
@@ -103,7 +104,7 @@
 	@Override
 	public IPage<GdPatrolTaskVO> selectGdPatrolTaskPage(IPage<GdPatrolTaskVO> page, GdPatrolTaskPageParam gdPatrolTask) {
 		List<Long> deptList = new ArrayList<>();
-		if (!AuthUtil.isAdministrator() || !AuthUtil.isAdmin()) {
+		if (!(AuthUtil.isAdministrator() || AuthUtil.isAdmin())) {
 			deptList = SysCache.getDeptChildIds(Long.valueOf(StringUtil.isBlank(AuthUtil.getDeptId()) ? "0" : AuthUtil.getDeptId()));
 		}
 		gdPatrolTask.setDeptList(deptList);
@@ -277,19 +278,15 @@
 			}
 		}
 		if (auditStatus == 3) {
-			// 撤回任务操作:查询同一个工单下的所有子任务
+			// 撤回任务操作:使用状态聚合工具类计算主任务状态
 			List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
 				.eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
 
-			// 检查是否所有子任务都已撤回
-			boolean allSubTasksWithdrawn = subTasks.stream()
-				.allMatch(item -> item.getTaskStatus().equals(PatrolTaskStatusEnum.WITHDRAWN.getValue()));
-
-			// 如果所有子任务都已撤回,则将工单状态更新为"接单响应_已取消"
-			if (allSubTasksWithdrawn) {
-				return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
-					WorkOrderStatusEnum.RESPONDING_CANCELED);
-			}
+			// 使用状态聚合工具类计算主任务状态
+			WorkOrderStatusEnum newWorkOrderStatus = WorkOrderStatusAggregator.aggregateWorkOrderStatus(subTasks);
+			
+			// 更新主任务状态
+			updateWorkOrderStatusAndFlow(task.getWorkOrderId(), newWorkOrderStatus);
 		}
 		// 7. 验收拒绝
 		if (auditStatus == 7) {

--
Gitblit v1.9.3