From 87ad1069a2e904945bb7d352a9dc1411f534a649 Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Thu, 05 Feb 2026 16:55:47 +0800
Subject: [PATCH] 工单审核通过接口优化

---
 drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java |   52 ++++++++++++++++++++++++++++++++--------------------
 1 files changed, 32 insertions(+), 20 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 c0d9972..691771b 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
@@ -67,6 +67,7 @@
 import java.io.File;
 import java.io.IOException;
 import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 巡查任务表 服务实现类
@@ -230,16 +231,7 @@
 				.eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
 
 			// 检查是否所有子任务都审核成功(除了被撤回和验收拒绝的)
- 			boolean allSubTasksAudited = subTasks.stream()
-				// 过滤掉当前任务本身
-				.filter(subTask -> !subTask.getId().equals(task.getId()))
-				.map(GdPatrolTaskEntity::getTaskStatus)
-				.filter(Objects::nonNull)
-				// 过滤掉撤回或验收拒绝的任务
-				.filter(status -> !status.equals(PatrolTaskStatusEnum.WITHDRAWN.getValue()) &&
-							   !status.equals(PatrolTaskStatusEnum.REJECTED_ACCEPTANCE.getValue()))
-				// 判断是否有小于待审核的任务
-				.anyMatch(status -> status.compareTo(PatrolTaskStatusEnum.PENDING_AUDIT.getValue()) < 0);
+			boolean allSubTasksAudited = isAllSubTasksAudited(subTasks, task, PatrolTaskStatusEnum.PENDING_AUDIT);
 			if (!allSubTasksAudited) {
 				// 执行工单状态更新逻辑
 				return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
@@ -273,16 +265,7 @@
 				.eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
 
 			// 检查是否所有子任务都验收通过(除了被撤回和验收拒绝的)
-			boolean allSubTasksAudited = subTasks.stream()
-				// 过滤掉当前任务本身
-				.filter(subTask -> !subTask.getId().equals(task.getId()))
-				.map(GdPatrolTaskEntity::getTaskStatus)
-				.filter(Objects::nonNull)
-				// 过滤掉撤回或验收拒绝的任务
-				.filter(status -> !status.equals(PatrolTaskStatusEnum.WITHDRAWN.getValue()) &&
-					!status.equals(PatrolTaskStatusEnum.REJECTED_ACCEPTANCE.getValue()))
-				// 判断是否有小于验收通过的任务
-				.anyMatch(status -> status.compareTo(PatrolTaskStatusEnum.ACCEPTANCE_PASSED.getValue()) < 0);
+			boolean allSubTasksAudited = isAllSubTasksAudited(subTasks, task, PatrolTaskStatusEnum.ACCEPTANCE_PASSED);
 			// 这里可以根据allSubTasksAudited的结果执行后续逻辑,比如更新工单状态等
 			if (!allSubTasksAudited) {
 				// 1.验收通过,生成报告
@@ -295,6 +278,35 @@
 		return b;
 	}
 
+	/**
+	 * @param subTasks
+	 * @param task
+	 * @param pendingAudit
+	 * @return
+	 */
+	private static boolean isAllSubTasksAudited(List<GdPatrolTaskEntity> subTasks, GdPatrolTaskEntity task, PatrolTaskStatusEnum pendingAudit) {
+		List<String> validStatusList = subTasks.stream()
+			// 过滤掉当前任务本身
+			.filter(subTask -> !subTask.getId().equals(task.getId()))
+			.map(GdPatrolTaskEntity::getTaskStatus)
+			.filter(Objects::nonNull)
+			// 过滤掉撤回或验收拒绝的任务
+			.filter(status -> !status.equals(PatrolTaskStatusEnum.WITHDRAWN.getValue()) &&
+				!status.equals(PatrolTaskStatusEnum.REJECTED_ACCEPTANCE.getValue()))
+			.collect(Collectors.toList());
+
+		// 如果过滤后没有有效任务,直接返回false
+		if (validStatusList.isEmpty()) {
+			return false;
+		}
+
+		// 判断是否有小于待审核的任务
+		boolean allSubTasksAudited = validStatusList.stream()
+			.anyMatch(status -> status.compareTo(pendingAudit.getValue()) < 0);
+		return allSubTasksAudited;
+
+	}
+
 
 	/**
 	 * 更新工单状态并保存流转记录

--
Gitblit v1.9.3