From f464fbe15658b634193a1f564af5d5e02be30cb1 Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Wed, 04 Feb 2026 21:54:41 +0800
Subject: [PATCH] 工单优化
---
drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java | 18 +++++++++++-------
1 files changed, 11 insertions(+), 7 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 fdcc12b..c0d9972 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
@@ -165,7 +165,7 @@
* @throws RuntimeException 当任务不存在、状态不允许转换或操作失败时抛出
*/
@Override
- // @Transactional(rollbackFor = Exception.class)
+ @Transactional(rollbackFor = Exception.class)
public boolean auditPatrolTask(GdPatrolTaskAuditParam auditParam) {
// 1. 获取巡查任务
GdPatrolTaskEntity task = getById(auditParam.getId());
@@ -231,14 +231,16 @@
// 检查是否所有子任务都审核成功(除了被撤回和验收拒绝的)
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);
- if (allSubTasksAudited) {
+ if (!allSubTasksAudited) {
// 执行工单状态更新逻辑
return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED);
@@ -272,15 +274,17 @@
// 检查是否所有子任务都验收通过(除了被撤回和验收拒绝的)
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);
+ // 判断是否有小于验收通过的任务
+ .anyMatch(status -> status.compareTo(PatrolTaskStatusEnum.ACCEPTANCE_PASSED.getValue()) < 0);
// 这里可以根据allSubTasksAudited的结果执行后续逻辑,比如更新工单状态等
- if (allSubTasksAudited) {
+ if (!allSubTasksAudited) {
// 1.验收通过,生成报告
asyncExportPatrolReport(task.getId());
// 2.执行工单状态更新逻辑
--
Gitblit v1.9.3