From bcc36efe5fd3264625bb884e50c2f353fb052b61 Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Sat, 31 Jan 2026 16:38:46 +0800
Subject: [PATCH] 工单流程优化

---
 drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java |  663 +++++++++++++++++++++++++++---------------------------
 1 files changed, 329 insertions(+), 334 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 ffa9c08..f60f467 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,8 @@
 import java.io.IOException;
 import java.util.Date;
 import java.util.List;
+import java.util.stream.Collectors;
+import java.util.stream.Stream;
 
 /**
  * 巡查任务表 服务实现类
@@ -94,287 +96,304 @@
 	private JianXingtuApiService jianXingtuApiService;
 	@Autowired
 	private IGdManageDeviceService gdManageDeviceService;
-    @Override
-    public IPage<GdPatrolTaskVO> selectGdPatrolTaskPage(IPage<GdPatrolTaskVO> page, GdPatrolTaskPageParam gdPatrolTask) {
+
+	@Override
+	public IPage<GdPatrolTaskVO> selectGdPatrolTaskPage(IPage<GdPatrolTaskVO> page, GdPatrolTaskPageParam gdPatrolTask) {
 		List<Long> deptList = SysCache.getDeptChildIds(Long.valueOf(AuthUtil.getDeptId()));
 		gdPatrolTask.setDeptList(deptList);
-        return page.setRecords(baseMapper.selectGdPatrolTaskPage(page, gdPatrolTask));
-    }
+		List<GdPatrolTaskVO> gdPatrolTaskVOS = baseMapper.selectGdPatrolTaskPage(page, gdPatrolTask);
+		return page.setRecords(gdPatrolTaskVOS);
+	}
 
 
-    @Override
-    public List<GdPatrolTaskExcel> exportGdPatrolTask(Wrapper<GdPatrolTaskEntity> queryWrapper) {
-        List<GdPatrolTaskExcel> gdPatrolTaskList = baseMapper.exportGdPatrolTask(queryWrapper);
-        // gdPatrolTaskList.forEach(gdPatrolTask -> {
-        //	gdPatrolTask.setTypeName(DictCache.getValue(DictEnum.YES_NO, GdPatrolTask.getType()));
-        //});
-        return gdPatrolTaskList;
-    }
+	@Override
+	public List<GdPatrolTaskExcel> exportGdPatrolTask(Wrapper<GdPatrolTaskEntity> queryWrapper) {
+		List<GdPatrolTaskExcel> gdPatrolTaskList = baseMapper.exportGdPatrolTask(queryWrapper);
+		// gdPatrolTaskList.forEach(gdPatrolTask -> {
+		//	gdPatrolTask.setTypeName(DictCache.getValue(DictEnum.YES_NO, GdPatrolTask.getType()));
+		//});
+		return gdPatrolTaskList;
+	}
 
-    @Override
-    @Transactional(rollbackFor = Exception.class)
-    public boolean savePatrolTask(List<GdPatrolTaskEntity> taskEntityList) {
-        // 更新流程节点
-        for (GdPatrolTaskEntity gdPatrolTaskEntity : taskEntityList) {
-            // 生成巡查任务编号
-            if (StringUtils.isBlank(gdPatrolTaskEntity.getTaskNo())) {
-                // 使用时间戳生成唯一巡查任务编号
-                String timestamp = OrderNumUtils.initOrderNum(WordOrderConstant.PATROL_TASK_KEY);
-                gdPatrolTaskEntity.setTaskNo(WordOrderConstant.PATROL_TASK_PREFIX + timestamp);
-            }
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public boolean savePatrolTask(List<GdPatrolTaskEntity> taskEntityList) {
+		// 更新流程节点
+		for (GdPatrolTaskEntity gdPatrolTaskEntity : taskEntityList) {
+			// 生成巡查任务编号
+			if (StringUtils.isBlank(gdPatrolTaskEntity.getTaskNo())) {
+				// 使用时间戳生成唯一巡查任务编号
+				String timestamp = OrderNumUtils.initOrderNum(WordOrderConstant.PATROL_TASK_KEY);
+				gdPatrolTaskEntity.setTaskNo(WordOrderConstant.PATROL_TASK_PREFIX + timestamp);
+			}
 
-            // 设置初始状态为待签收(对应流程图:等待接单)
-            gdPatrolTaskEntity.setTaskStatus(PatrolTaskStatusEnum.PENDING_SIGNING.getValue());
+			// 设置初始状态为待签收(对应流程图:等待接单)
+			gdPatrolTaskEntity.setTaskStatus(PatrolTaskStatusEnum.PENDING_SIGNING.getValue());
 
-            // 保存巡逻任务
-            boolean save = save(gdPatrolTaskEntity);
-            if (!save) {
-                // 任务保存失败,抛出异常触发回滚
-                throw new RuntimeException("保存巡逻任务失败:" + gdPatrolTaskEntity.toString());
-            }
+			// 保存巡逻任务
+			boolean save = save(gdPatrolTaskEntity);
+			if (!save) {
+				// 任务保存失败,抛出异常触发回滚
+				throw new RuntimeException("保存巡逻任务失败:" + gdPatrolTaskEntity.toString());
+			}
 
-            // 保存流转记录(发布任务,等待接单)
-            GdWorkOrderFlowEntity gdWorkOrderFlowEntity = new GdWorkOrderFlowEntity();
-            gdWorkOrderFlowEntity.setCreateUser(AuthUtil.getUserId());
-            gdWorkOrderFlowEntity.setWorkOrderId(gdPatrolTaskEntity.getId());
-            gdWorkOrderFlowEntity.setFlowName(PatrolTaskStatusEnum.PENDING_SIGNING.getStageDesc());
-            gdWorkOrderFlowEntity.setFlowDesc(AuthUtil.getUserName() + " " + DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 发布任务,等待接单");
-            gdWorkOrderFlowEntity.setOperator(AuthUtil.getNickName());
-            gdWorkOrderFlowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
-            gdWorkOrderFlowEntity.setAreaCode(gdPatrolTaskEntity.getAreaCode());
-            gdWorkOrderFlowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
-            boolean save1 = gdWorkOrderFlowService.save(gdWorkOrderFlowEntity);
-            if (!save1) {
-                // 流转记录保存失败,抛出异常触发回滚
-                throw new RuntimeException("保存流转记录失败:" + gdWorkOrderFlowEntity.toString());
-            }
-        }
-
-        // 所有任务和流转记录都保存成功
-        return true;
-    }
-
-    /**
-     * 审核巡查任务
-     *
-     * @param auditParam 审核参数,包含任务ID、审核状态和拒绝原因
-     * @return 是否审核成功
-     * @throws RuntimeException 当任务不存在、状态不允许转换或操作失败时抛出
-     */
-    @Override
-    @Transactional(rollbackFor = Exception.class)
-    public boolean auditPatrolTask(GdPatrolTaskAuditParam auditParam) {
-        // 1. 获取巡查任务
-        GdPatrolTaskEntity task = getById(auditParam.getId());
-        if (task == null) {
-            throw new RuntimeException("巡查任务不存在");
-        }
-
-        // 2. 状态权限校验
-        PatrolTaskStatusEnum currentStatus = PatrolTaskStatusEnum.getByValue(task.getTaskStatus());
-        Integer auditStatus = auditParam.getAuditStatus();
-        if (currentStatus == null || !currentStatus.isAllowedTransition(auditStatus)) {
-            throw new RuntimeException("当前任务状态无法进行该操作");
-        }
-        // 1.同意签收、2.拒绝签收 、3.撤回任务 、4.同意审核、 5.拒绝审核、 6.验收通过、 7.验收拒绝
-        // 3. 确定新状态和流转名称
-        PatrolTaskStatusEnum newStatusEnum;
-        switch (auditStatus) {
-            case 1: // 接单
-                newStatusEnum = PatrolTaskStatusEnum.PENDING_AUDIT;
-                break;
-            case 2: // 拒接接单
-                newStatusEnum = PatrolTaskStatusEnum.REJECTED_SIGNING;
-                break;
-            case 3: // 撤回任务
-                newStatusEnum = PatrolTaskStatusEnum.WITHDRAWN;
-                break;
-            case 4: // 同意审核
-                newStatusEnum = PatrolTaskStatusEnum.AUDIT_PASSED;
-                break;
-            case 5: // 拒绝审核
-                newStatusEnum = PatrolTaskStatusEnum.AUDIT_REJECTED;
-                break;
-            case 6: // 验收通过
-                newStatusEnum = PatrolTaskStatusEnum.ACCEPTANCE_PASSED;
-                break;
-            case 7: // 验收拒绝
-                newStatusEnum = PatrolTaskStatusEnum.REJECTED_ACCEPTANCE;
-				break;
-            default: // 无效操作类型
-                return false;
-        }
-
-        // 4. 更新任务状态
-        Date now = new Date();
-        task.setTaskStatus(newStatusEnum.getValue());
-        task.setUpdateUser(AuthUtil.getUserId());
-        task.setUpdateTime(now);
-		task.setRejectReason(auditParam.getRejectReason());
-        boolean updateResult = updateById(task);
-        if (!updateResult) {
-            throw new RuntimeException("更新任务状态失败");
-        }
-
-        // 5. 保存流转记录
-        boolean b = saveWorkOrderFlow(task.getId(), newStatusEnum, auditParam.getRejectReason(), task.getAreaCode());
-        // 6. 判断是否审核成功,如果是,需要判断是否整个订单的子任务都审核成功了,除了被撤回和验收拒绝的
-        if (auditStatus == 4) {
-			//将审核后的任务信息推送到星图
-			pushXingtuFlyTask(auditParam.getId());
-            // 查询同一个工单下的所有子任务
-            List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
-                    .eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
-
-            // 检查是否所有子任务都审核成功(除了被撤回和验收拒绝的)
-            boolean allSubTasksAudited = checkAllSubTasksStatus(subTasks, PatrolTaskStatusEnum.AUDIT_PASSED);
-            // 示例:如果所有子任务都审核成功,可以更新工单状态为已完成
-            if (allSubTasksAudited) {
-                // 执行工单状态更新逻辑
-                return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
-                    WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED);
-            }
-        }
-        // 7. 验收拒绝
-        if (auditStatus == 7) {
-            return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
-                WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED);
-        }
-        // 8. 验收通过
-        if (auditStatus == 6) {
-            // 查询同一个工单下的所有子任务
-            List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
-                    .eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
-
-            // 检查是否所有子任务都验收通过(除了被撤回和验收拒绝的)
-            boolean allSubTasksAudited = checkAllSubTasksStatus(subTasks, PatrolTaskStatusEnum.ACCEPTANCE_PASSED);
-            // 这里可以根据allSubTasksAudited的结果执行后续逻辑,比如更新工单状态等
-            if (allSubTasksAudited) {
-				// 1.验收通过,生成报告
-				asyncExportPatrolReport(task.getId());
-                // 2.执行工单状态更新逻辑
-                return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
-                    WorkOrderStatusEnum.ACCEPTED_TO_BE_SETTLED);
-            }
-        }
-        return b;
-    }
-
-
-    /**
-     * 检查是否所有子任务都达到指定状态(除了被撤回和验收拒绝的)
-     *
-     * @param subTasks 子任务列表
-     * @param targetStatus 目标状态枚举
-     * @return 是否所有子任务都达到指定状态
-     */
-    private boolean checkAllSubTasksStatus(List<GdPatrolTaskEntity> subTasks, PatrolTaskStatusEnum targetStatus) {
-        for (GdPatrolTaskEntity subTask : subTasks) {
-            String taskStatus = subTask.getTaskStatus();
-            PatrolTaskStatusEnum statusEnum = PatrolTaskStatusEnum.getByValue(taskStatus);
-
-            // 如果任务状态不是目标状态,且不是被撤回和验收拒绝的,则返回false
-            if (statusEnum != targetStatus &&
-                    statusEnum != PatrolTaskStatusEnum.WITHDRAWN &&
-                    statusEnum != PatrolTaskStatusEnum.REJECTED_ACCEPTANCE) {
-                return false;
-            }
-        }
-        return true;
-    }
-
-    /**
-     * 更新工单状态并保存流转记录
-     *
-     * @param workOrderId 工单ID
-     * @param newStatus 新的工单状态枚举
-     * @return 是否更新成功
-     */
-    private boolean updateWorkOrderStatusAndFlow(Long workOrderId, WorkOrderStatusEnum newStatus) {
-        // 1. 更新工单状态
-        GdWorkOrderEntity gdWorkOrderEntity = new GdWorkOrderEntity();
-        gdWorkOrderEntity.setId(workOrderId);
-        gdWorkOrderEntity.setWorkOrderStatus(newStatus.getCode());
-        Integer updateResult = baseMapper.updateWorkOrderById(gdWorkOrderEntity);
-        if (updateResult <= 0) {
-            return false;
-        }
-
-        // 2. 保存流转记录
-        GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
-        flowEntity.setCreateUser(AuthUtil.getUserId());
-        flowEntity.setWorkOrderId(workOrderId);
-        flowEntity.setFlowName(newStatus.getStageDesc());
-        flowEntity.setFlowDesc(newStatus.getDesc());
-        flowEntity.setOperator(AuthUtil.getNickName());
-        flowEntity.setType(WorkOrderTypeEnum.WORK_ORDER_TASK.getValue());
-        flowEntity.setFlowStatus(newStatus.getMaxCode());
-        flowEntity.setWorkStatus(newStatus.getCode());
-        flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
-        return gdWorkOrderFlowService.save(flowEntity);
-    }
-
-    @Override
-    @Transactional(rollbackFor = Exception.class)
-	public boolean republishPatrolTask(GdPatrolTaskEntity taskEntity) {
-        if (taskEntity == null || taskEntity.getId() == null) {
-            throw new RuntimeException("任务信息或ID不能为空");
+			// 保存流转记录(发布任务,等待接单)
+			GdWorkOrderFlowEntity gdWorkOrderFlowEntity = new GdWorkOrderFlowEntity();
+			gdWorkOrderFlowEntity.setCreateUser(AuthUtil.getUserId());
+			gdWorkOrderFlowEntity.setWorkOrderId(gdPatrolTaskEntity.getId());
+			gdWorkOrderFlowEntity.setFlowName(PatrolTaskStatusEnum.PENDING_SIGNING.getStageDesc());
+			gdWorkOrderFlowEntity.setFlowDesc(PatrolTaskStatusEnum.PENDING_SIGNING.getStageDesc());
+			gdWorkOrderFlowEntity.setOperator(AuthUtil.getNickName());
+			gdWorkOrderFlowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
+			gdWorkOrderFlowEntity.setAreaCode(gdPatrolTaskEntity.getAreaCode());
+			gdWorkOrderFlowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+			boolean save1 = gdWorkOrderFlowService.save(gdWorkOrderFlowEntity);
+			if (!save1) {
+				// 流转记录保存失败,抛出异常触发回滚
+				throw new RuntimeException("保存流转记录失败:" + gdWorkOrderFlowEntity.toString());
+			}
 		}
 
-        // 1. 验证任务是否存在
-        GdPatrolTaskEntity existingTask = getById(taskEntity.getId());
-        taskEntity.setId(existingTask.getId());
-        if (existingTask == null) {
-            throw new RuntimeException("巡查任务不存在");
-        }
+		// 所有任务和流转记录都保存成功
+		return true;
+	}
 
-        // 2. 先确定枚举状态:根据当前状态确定新的枚举状态
-        PatrolTaskStatusEnum targetStatus;
-        String currentStatus = existingTask.getTaskStatus();
-        // 1.发布中_拒绝接单 、 4.响应中_审核驳回
-        switch (currentStatus) {
-            case "1": // 发布中_拒绝接单 → 发布中_接单中
-                targetStatus = PatrolTaskStatusEnum.PENDING_SIGNING;
-                break;
-            case "4": // 响应中_审核驳回 → 响应中_待审核
-                targetStatus = PatrolTaskStatusEnum.PENDING_AUDIT;
-                break;
-            default:
-                // 其他状态,保持原有状态
-                targetStatus = PatrolTaskStatusEnum.getByValue(currentStatus);
-                // 如果无法获取枚举,使用待签收作为默认状态
-                if (targetStatus == null) {
-                    targetStatus = PatrolTaskStatusEnum.PENDING_SIGNING;
-                }
-                break;
-        }
+	/**
+	 * 审核巡查任务
+	 *
+	 * @param auditParam 审核参数,包含任务ID、审核状态和拒绝原因
+	 * @return 是否审核成功
+	 * @throws RuntimeException 当任务不存在、状态不允许转换或操作失败时抛出
+	 */
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public boolean auditPatrolTask(GdPatrolTaskAuditParam auditParam) {
+		// 1. 获取巡查任务
+		GdPatrolTaskEntity task = getById(auditParam.getId());
+		if (task == null) {
+			throw new RuntimeException("巡查任务不存在");
+		}
 
-        // 3. 设置任务状态:使用枚举设置任务状态
-        taskEntity.setTaskStatus(targetStatus.getValue());
+		// 2. 状态权限校验
+		PatrolTaskStatusEnum currentStatus = PatrolTaskStatusEnum.getByValue(task.getTaskStatus());
+		Integer auditStatus = auditParam.getAuditStatus();
+		if (currentStatus == null || !currentStatus.isAllowedTransition(auditStatus)) {
+			throw new RuntimeException("当前任务状态无法进行该操作");
+		}
+		// 1.同意签收、2.拒绝签收 、3.撤回任务 、4.同意审核、 5.拒绝审核、 6.验收通过、 7.验收拒绝
+		// 3. 确定新状态和流转名称
+		PatrolTaskStatusEnum newStatusEnum;
+		switch (auditStatus) {
+			case 1: // 接单
+				newStatusEnum = PatrolTaskStatusEnum.PENDING_AUDIT;
+				break;
+			case 2: // 拒接接单
+				newStatusEnum = PatrolTaskStatusEnum.REJECTED_SIGNING;
+				break;
+			case 3: // 撤回任务
+				newStatusEnum = PatrolTaskStatusEnum.WITHDRAWN;
+				break;
+			case 4: // 同意审核
+				newStatusEnum = PatrolTaskStatusEnum.AUDIT_PASSED;
+				break;
+			case 5: // 拒绝审核
+				newStatusEnum = PatrolTaskStatusEnum.AUDIT_REJECTED;
+				break;
+			case 6: // 验收通过
+				newStatusEnum = PatrolTaskStatusEnum.ACCEPTANCE_PASSED;
+				break;
+			case 7: // 验收拒绝
+				newStatusEnum = PatrolTaskStatusEnum.REJECTED_ACCEPTANCE;
+				break;
+			default: // 无效操作类型
+				return false;
+		}
 
-        // 4. 更新任务信息:合并传入的任务信息
-        taskEntity.setUpdateUser(AuthUtil.getUserId());
-        taskEntity.setUpdateTime(new Date());
+		// 4. 更新任务状态
+		Date now = new Date();
+		task.setTaskStatus(newStatusEnum.getValue());
+		task.setUpdateUser(AuthUtil.getUserId());
+		task.setUpdateTime(now);
+		task.setRejectReason(auditParam.getRejectReason());
+		boolean updateResult = updateById(task);
+		if (!updateResult) {
+			throw new RuntimeException("更新任务状态失败");
+		}
 
-        // 5. 更新数据库
-        boolean updateResult = updateById(taskEntity);
-        if (!updateResult) {
-            throw new RuntimeException("更新任务信息失败");
-        }
+		// 5. 保存流转记录
+		boolean b = saveWorkOrderFlow(task.getId(), newStatusEnum, auditParam.getRejectReason(), task.getAreaCode());
+		// 6. 判断是否审核成功,如果是,需要判断是否整个订单的子任务都审核成功了,除了被撤回和验收拒绝的
+		if (auditStatus == 4) {
+			// 将审核后的任务信息推送到星图
+			pushXingtuFlyTask(auditParam.getId());
+			// 查询同一个工单下的所有子任务
+			List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
+				.eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
 
-        // 6. 保存流转记录:使用枚举设置flowName
-        GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
-        flowEntity.setCreateUser(AuthUtil.getUserId());
-        flowEntity.setWorkOrderId(taskEntity.getId());
-        flowEntity.setFlowName(targetStatus.getDesc());
-        flowEntity.setFlowDesc(AuthUtil.getNickName() + " " + DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 更新了任务信息,状态转换为:" + targetStatus.getDesc());
-        flowEntity.setOperator(AuthUtil.getNickName());
-        flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
-        flowEntity.setAreaCode(existingTask.getAreaCode());
-        flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+			// 检查是否所有子任务都审核成功(除了被撤回和验收拒绝的)
+			boolean allSubTasksAudited = checkAllSubTasksStatus(subTasks, PatrolTaskStatusEnum.AUDIT_PASSED);
+			// 示例:如果所有子任务都审核成功,可以更新工单状态为已完成
+			if (allSubTasksAudited) {
+				// 执行工单状态更新逻辑
+				return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
+					WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED);
+			}
+		}
+		if (auditStatus == 3) {
+			// 查询同一个工单下的所有子任务
+			List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
+				.eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
 
-        return gdWorkOrderFlowService.save(flowEntity);
-    }
+			boolean allSubTasksWithdrawn = subTasks.stream()
+				.allMatch(item -> item.getTaskStatus().equals(PatrolTaskStatusEnum.WITHDRAWN.getValue()));
+
+			// 示例:如果所有子任务都审核成功,可以更新工单状态为已完成
+			if (allSubTasksWithdrawn) {
+				// 执行工单状态更新逻辑
+				return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
+					WorkOrderStatusEnum.RESPONDING_CANCELED);
+			}
+		}
+		// 7. 验收拒绝
+		if (auditStatus == 7) {
+			return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
+				WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED);
+		}
+		// 8. 验收通过
+		if (auditStatus == 6) {
+			// 查询同一个工单下的所有子任务
+			List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
+				.eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
+
+			// 检查是否所有子任务都验收通过(除了被撤回和验收拒绝的)
+			boolean allSubTasksAudited = checkAllSubTasksStatus(subTasks, PatrolTaskStatusEnum.ACCEPTANCE_PASSED);
+			// 这里可以根据allSubTasksAudited的结果执行后续逻辑,比如更新工单状态等
+			if (allSubTasksAudited) {
+				// 1.验收通过,生成报告
+				asyncExportPatrolReport(task.getId());
+				// 2.执行工单状态更新逻辑
+				return updateWorkOrderStatusAndFlow(task.getWorkOrderId(),
+					WorkOrderStatusEnum.ACCEPTED_TO_BE_SETTLED);
+			}
+		}
+		return b;
+	}
+
+
+	/**
+	 * 检查是否所有子任务都达到指定状态(除了被撤回和验收拒绝的)
+	 *
+	 * @param subTasks     子任务列表
+	 * @param targetStatus 目标状态枚举
+	 * @return 是否所有子任务都达到指定状态
+	 */
+	private boolean checkAllSubTasksStatus(List<GdPatrolTaskEntity> subTasks, PatrolTaskStatusEnum targetStatus) {
+		for (GdPatrolTaskEntity subTask : subTasks) {
+			String taskStatus = subTask.getTaskStatus();
+			PatrolTaskStatusEnum statusEnum = PatrolTaskStatusEnum.getByValue(taskStatus);
+
+			// 如果任务状态不是目标状态,且不是被撤回和验收拒绝的,则返回false
+			if (statusEnum != targetStatus &&
+				statusEnum != PatrolTaskStatusEnum.WITHDRAWN &&
+				statusEnum != PatrolTaskStatusEnum.REJECTED_ACCEPTANCE) {
+				return false;
+			}
+		}
+		return true;
+	}
+
+	/**
+	 * 更新工单状态并保存流转记录
+	 *
+	 * @param workOrderId 工单ID
+	 * @param newStatus   新的工单状态枚举
+	 * @return 是否更新成功
+	 */
+	private boolean updateWorkOrderStatusAndFlow(Long workOrderId, WorkOrderStatusEnum newStatus) {
+		// 1. 更新工单状态
+		GdWorkOrderEntity gdWorkOrderEntity = new GdWorkOrderEntity();
+		gdWorkOrderEntity.setId(workOrderId);
+		gdWorkOrderEntity.setWorkOrderStatus(newStatus.getCode());
+		Integer updateResult = baseMapper.updateWorkOrderById(gdWorkOrderEntity);
+		if (updateResult <= 0) {
+			return false;
+		}
+
+		// 2. 保存流转记录
+		GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
+		flowEntity.setCreateUser(AuthUtil.getUserId());
+		flowEntity.setWorkOrderId(workOrderId);
+		flowEntity.setFlowName(newStatus.getStageDesc());
+		flowEntity.setFlowDesc(newStatus.getDesc());
+		flowEntity.setOperator(AuthUtil.getNickName());
+		flowEntity.setType(WorkOrderTypeEnum.WORK_ORDER_TASK.getValue());
+		flowEntity.setFlowStatus(newStatus.getMaxCode());
+		flowEntity.setWorkStatus(newStatus.getCode());
+		flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+		return gdWorkOrderFlowService.save(flowEntity);
+	}
+
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public boolean republishPatrolTask(GdPatrolTaskEntity taskEntity) {
+		if (taskEntity == null || taskEntity.getId() == null) {
+			throw new RuntimeException("任务信息或ID不能为空");
+		}
+
+		// 1. 验证任务是否存在
+		GdPatrolTaskEntity existingTask = getById(taskEntity.getId());
+		taskEntity.setId(existingTask.getId());
+		if (existingTask == null) {
+			throw new RuntimeException("巡查任务不存在");
+		}
+
+		// 2. 先确定枚举状态:根据当前状态确定新的枚举状态
+		PatrolTaskStatusEnum targetStatus;
+		String currentStatus = existingTask.getTaskStatus();
+		// 1.发布中_拒绝接单 、 4.响应中_审核驳回
+		switch (currentStatus) {
+			case "1": // 发布中_拒绝接单 → 发布中_接单中
+				targetStatus = PatrolTaskStatusEnum.PENDING_SIGNING;
+				break;
+			case "4": // 响应中_审核驳回 → 响应中_待审核
+				targetStatus = PatrolTaskStatusEnum.PENDING_AUDIT;
+				break;
+			default:
+				// 其他状态,保持原有状态
+				targetStatus = PatrolTaskStatusEnum.getByValue(currentStatus);
+				// 如果无法获取枚举,使用待签收作为默认状态
+				if (targetStatus == null) {
+					targetStatus = PatrolTaskStatusEnum.PENDING_SIGNING;
+				}
+				break;
+		}
+
+		// 3. 设置任务状态:使用枚举设置任务状态
+		taskEntity.setTaskStatus(targetStatus.getValue());
+
+		// 4. 更新任务信息:合并传入的任务信息
+		taskEntity.setUpdateUser(AuthUtil.getUserId());
+		taskEntity.setUpdateTime(new Date());
+
+		// 5. 更新数据库
+		boolean updateResult = updateById(taskEntity);
+		if (!updateResult) {
+			throw new RuntimeException("更新任务信息失败");
+		}
+
+		// 6. 保存流转记录:使用枚举设置flowName
+		GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
+		flowEntity.setCreateUser(AuthUtil.getUserId());
+		flowEntity.setWorkOrderId(taskEntity.getId());
+		flowEntity.setFlowName(targetStatus.getDesc());
+		flowEntity.setFlowDesc(AuthUtil.getNickName() + " " + DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 更新了任务信息,状态转换为:" + targetStatus.getDesc());
+		flowEntity.setOperator(AuthUtil.getNickName());
+		flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
+		flowEntity.setAreaCode(existingTask.getAreaCode());
+		flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+
+		return gdWorkOrderFlowService.save(flowEntity);
+	}
 
 	@Override
 	public boolean exportPatrolReport(Long patrolTaskId) {
@@ -413,78 +432,53 @@
 		}
 	}
 
-    /**
-     * 检查拒绝原因是否必填
-     *
-     * @param newStatus     新状态
-     * @param rejectReason  拒绝原因
-     * @throws RuntimeException 当需要拒绝原因但未提供时抛出
-     */
-    // private void checkRejectReason(PatrolTaskStatusEnum newStatus, String rejectReason) {
-    // 	// 拒绝类状态需要填写拒绝原因
-    // 	if ((newStatus == PatrolTaskStatusEnum.REJECTED_SIGNING ||
-    // 	     newStatus == PatrolTaskStatusEnum.AUDIT_REJECTED ||
-    // 	     newStatus == PatrolTaskStatusEnum.REJECTED_ACCEPTANCE) &&
-    // 	    (rejectReason == null || rejectReason.trim().isEmpty())) {
-    // 		throw new RuntimeException("拒绝操作时必须填写拒绝原因");
-    // 	}
-    // }
+	/**
+	 * 检查拒绝原因是否必填
+	 *
+	 * @param newStatus     新状态
+	 * @param rejectReason  拒绝原因
+	 * @throws RuntimeException 当需要拒绝原因但未提供时抛出
+	 */
+	// private void checkRejectReason(PatrolTaskStatusEnum newStatus, String rejectReason) {
+	// 	// 拒绝类状态需要填写拒绝原因
+	// 	if ((newStatus == PatrolTaskStatusEnum.REJECTED_SIGNING ||
+	// 	     newStatus == PatrolTaskStatusEnum.AUDIT_REJECTED ||
+	// 	     newStatus == PatrolTaskStatusEnum.REJECTED_ACCEPTANCE) &&
+	// 	    (rejectReason == null || rejectReason.trim().isEmpty())) {
+	// 		throw new RuntimeException("拒绝操作时必须填写拒绝原因");
+	// 	}
+	// }
 
-    /**
-     * 保存工单流转记录
-     *
-     * @param workOrderId  工单ID
-     * @param newStatus    新状态
-     * @param rejectReason 拒绝原因
-     * @param areaCode     区域编码
-     * @return 是否保存成功
-     * @throws RuntimeException 当保存失败时抛出
-     */
-    private boolean saveWorkOrderFlow(Long workOrderId, PatrolTaskStatusEnum newStatus,
-                                      String rejectReason, String areaCode) {
-        GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
-        flowEntity.setCreateUser(AuthUtil.getUserId());
-        flowEntity.setWorkOrderId(workOrderId);
-        flowEntity.setFlowName(newStatus.getStageDesc());
+	/**
+	 * 保存工单流转记录
+	 *
+	 * @param workOrderId  工单ID
+	 * @param newStatus    新状态
+	 * @param rejectReason 拒绝原因
+	 * @param areaCode     区域编码
+	 * @return 是否保存成功
+	 * @throws RuntimeException 当保存失败时抛出
+	 */
+	private boolean saveWorkOrderFlow(Long workOrderId, PatrolTaskStatusEnum newStatus,
+									  String rejectReason, String areaCode) {
+		GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
+		flowEntity.setCreateUser(AuthUtil.getUserId());
+		flowEntity.setWorkOrderId(workOrderId);
+		flowEntity.setFlowName(newStatus.getStageDesc());
+		flowEntity.setFlowDesc(newStatus.getStageDesc());
+		flowEntity.setOperator(AuthUtil.getNickName());
+		flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
+		flowEntity.setAreaCode(areaCode);
+		flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
 
-        // 构建流转描述
-        String flowDesc = buildFlowDesc(newStatus, rejectReason);
-        flowEntity.setFlowDesc(flowDesc);
+		boolean saveResult = gdWorkOrderFlowService.save(flowEntity);
+		if (!saveResult) {
+			throw new RuntimeException("保存流转记录失败");
+		}
+		return true;
+	}
 
-        flowEntity.setOperator(AuthUtil.getNickName());
-        flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
-        flowEntity.setAreaCode(areaCode);
-        flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
 
-        boolean saveResult = gdWorkOrderFlowService.save(flowEntity);
-        if (!saveResult) {
-            throw new RuntimeException("保存流转记录失败");
-        }
-        return true;
-    }
-
-    /**
-     * 构建流转描述
-     *
-     * @param newStatus    新状态
-     * @param rejectReason 拒绝原因
-     * @return 流转描述
-     */
-    private String buildFlowDesc(PatrolTaskStatusEnum newStatus, String rejectReason) {
-        String baseDesc = String.format("%s %s ",
-                AuthUtil.getNickName(),
-                DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
-
-        // 拒绝类状态需要添加拒绝原因
-        if (newStatus == PatrolTaskStatusEnum.REJECTED_SIGNING ||
-            newStatus == PatrolTaskStatusEnum.AUDIT_REJECTED ||
-            newStatus == PatrolTaskStatusEnum.REJECTED_ACCEPTANCE) {
-            return String.format("%s%s:%s", baseDesc, newStatus.getDesc(), rejectReason);
-        }
-
-        // 其他状态直接使用枚举描述
-        return baseDesc + newStatus.getDesc();
-    }
 
 	private String getDeptName(Long deptId) {
 		if (deptId == null) {
@@ -606,6 +600,7 @@
 
 	/**
 	 * 构建巡察任务推送的巡察任务信息
+	 *
 	 * @param gdPatrolTaskVO
 	 * @return
 	 */
@@ -619,7 +614,7 @@
 		if (StringUtil.isNotBlank(gdPatrolTaskVO.getPatrolTaskType())) {
 			param.setInspectionType(gdPatrolTaskVO.getPatrolTaskType());
 		}
-		if ((gdPatrolTaskVO.getId()!=null)) {
+		if ((gdPatrolTaskVO.getId() != null)) {
 			param.setPatrolTaskld(String.valueOf(gdPatrolTaskVO.getId()));
 		}
 		param.setTimingType("单次执行");

--
Gitblit v1.9.3