From 48c703eebe54947ca7232d68b2851d5da57b578f Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Tue, 20 Jan 2026 21:42:20 +0800
Subject: [PATCH] 工单调整
---
drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java | 355 +++++++++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 272 insertions(+), 83 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 c333f90..45d26f7 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
@@ -16,13 +16,16 @@
*/
package org.sxkj.gd.workorder.service.impl;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import org.apache.commons.lang3.StringUtils;
import org.springblade.core.secure.utils.AuthUtil;
+import org.springblade.core.tool.utils.BeanUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.sxkj.common.constant.WordOrderConstant;
import org.sxkj.common.utils.OrderNumUtils;
import org.sxkj.gd.workorder.entity.GdPatrolTaskEntity;
+import org.sxkj.gd.workorder.entity.GdWorkOrderEntity;
import org.sxkj.gd.workorder.entity.GdWorkOrderFlowEntity;
import org.sxkj.gd.workorder.enums.PatrolTaskStatusEnum;
import org.sxkj.gd.workorder.enums.WorkOrderStatusEnum;
@@ -30,6 +33,7 @@
import org.sxkj.gd.workorder.param.GdPatrolTaskAuditParam;
import org.sxkj.gd.workorder.param.GdPatrolTaskPageParam;
import org.sxkj.gd.workorder.service.IGdWorkOrderFlowService;
+import org.sxkj.gd.workorder.service.IGdWorkOrderService;
import org.sxkj.gd.workorder.vo.GdPatrolTaskVO;
import org.sxkj.gd.workorder.excel.GdPatrolTaskExcel;
import org.sxkj.gd.workorder.mapper.GdPatrolTaskMapper;
@@ -53,6 +57,9 @@
@Autowired
private IGdWorkOrderFlowService gdWorkOrderFlowService;
+
+ @Autowired
+ private IGdWorkOrderService gdWorkOrderService;
@Override
public IPage<GdPatrolTaskVO> selectGdPatrolTaskPage(IPage<GdPatrolTaskVO> page, GdPatrolTaskPageParam gdPatrolTask, List<Long> deptIdList) {
@@ -80,6 +87,10 @@
String timestamp = OrderNumUtils.initOrderNum(WordOrderConstant.PATROL_TASK_KEY);
gdPatrolTaskEntity.setTaskNo(WordOrderConstant.PATROL_TASK_PREFIX + timestamp);
}
+
+ // 设置初始状态为待签收(对应流程图:等待接单)
+ gdPatrolTaskEntity.setTaskStatus(PatrolTaskStatusEnum.PENDING_SIGNING.getValue());
+
// 保存巡逻任务
boolean save = save(gdPatrolTaskEntity);
if (!save) {
@@ -87,12 +98,12 @@
throw new RuntimeException("保存巡逻任务失败:" + gdPatrolTaskEntity.toString());
}
- // 保存流转记录
+ // 保存流转记录(发布任务,等待接单)
GdWorkOrderFlowEntity gdWorkOrderFlowEntity = new GdWorkOrderFlowEntity();
gdWorkOrderFlowEntity.setCreateUser(AuthUtil.getUserId());
gdWorkOrderFlowEntity.setWorkOrderId(gdPatrolTaskEntity.getId());
- gdWorkOrderFlowEntity.setFlowName(PatrolTaskStatusEnum.PENDING_SIGNING.getDesc());
- gdWorkOrderFlowEntity.setFlowDesc(AuthUtil.getUserName() + " " + org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
+ gdWorkOrderFlowEntity.setFlowName("任务发布");
+ gdWorkOrderFlowEntity.setFlowDesc(AuthUtil.getUserName() + " " + org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 发布任务,等待接单");
gdWorkOrderFlowEntity.setOperator(AuthUtil.getUserName());
gdWorkOrderFlowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
gdWorkOrderFlowEntity.setAreaCode(gdPatrolTaskEntity.getAreaCode());
@@ -108,118 +119,296 @@
return true;
}
+ /**
+ * 审核巡查任务
+ *
+ * @param auditParam 审核参数,包含任务ID、审核状态和拒绝原因
+ * @return 是否审核成功
+ * @throws RuntimeException 当任务不存在、状态不允许转换或操作失败时抛出
+ */
@Override
@Transactional(rollbackFor = Exception.class)
public boolean auditPatrolTask(GdPatrolTaskAuditParam auditParam) {
- Long id = auditParam.getId();
- String auditStatus = auditParam.getAuditStatus();
- String rejectReason = auditParam.getRejectReason();
// 1. 获取巡查任务
- GdPatrolTaskEntity task = getById(id);
+ GdPatrolTaskEntity task = getById(auditParam.getId());
if (task == null) {
throw new RuntimeException("巡查任务不存在");
}
- // 2. 检查任务状态是否为待审核
- if (!PatrolTaskStatusEnum.PENDING_AUDIT.getValue().equals(task.getTaskStatus().toString())) {
- throw new RuntimeException("任务当前状态无法审核");
+ // 2. 状态权限校验
+ PatrolTaskStatusEnum currentStatus = PatrolTaskStatusEnum.getByValue(task.getTaskStatus());
+ Integer auditStatus = auditParam.getAuditStatus();
+ if (currentStatus == null || !currentStatus.isAllowedTransition(auditStatus)) {
+ throw new RuntimeException("当前任务状态无法进行该操作");
}
-
- // 3. 如果审核拒绝,检查拒绝原因是否为空
- if (PatrolTaskStatusEnum.REJECTED_SIGNING.getValue().equals(auditStatus) && (rejectReason == null || rejectReason.trim().isEmpty())) {
- throw new RuntimeException("拒绝签收时必须填写拒绝原因");
- }
-
- // 4. 检查其他需要拒绝原因的状态
- if ((PatrolTaskStatusEnum.AUDIT_REJECTED.getValue().equals(auditStatus) || PatrolTaskStatusEnum.REJECTED_ACCEPTANCE.getValue().equals(auditStatus)) && (rejectReason == null || rejectReason.trim().isEmpty())) {
- 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. 更新任务状态
- task.setTaskStatus(auditStatus);
+ Date now = new Date();
+ task.setTaskStatus(newStatusEnum.getValue());
+ task.setUpdateUser(AuthUtil.getUserId());
+ task.setUpdateTime(now);
boolean updateResult = updateById(task);
if (!updateResult) {
throw new RuntimeException("更新任务状态失败");
}
// 5. 保存流转记录
- GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
- flowEntity.setCreateUser(AuthUtil.getUserId());
- flowEntity.setWorkOrderId(id);
+ boolean b = saveWorkOrderFlow(task.getId(), newStatusEnum, auditParam.getRejectReason(), task.getAreaCode());
+ // 6. 判断是否审核成功,如果是,需要判断是否整个订单的子任务都审核成功了,除了被撤回和验收拒绝的
+ if (auditStatus == 4) {
+ // 查询同一个工单下的所有子任务
+ List<GdPatrolTaskEntity> subTasks = list(Wrappers.<GdPatrolTaskEntity>lambdaQuery()
+ .eq(GdPatrolTaskEntity::getWorkOrderId, task.getWorkOrderId()));
- // 设置流转名称和描述
- String[] flowInfo = buildFlowInfo(auditStatus, rejectReason);
- String flowName = flowInfo[0];
- String flowDesc = AuthUtil.getUserName() + " " + org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + flowInfo[1];
-
- flowEntity.setFlowName(flowName);
- flowEntity.setFlowDesc(flowDesc);
- flowEntity.setOperator(AuthUtil.getUserName());
- flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
- flowEntity.setAreaCode(task.getAreaCode());
- flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
-
- boolean saveFlowResult = gdWorkOrderFlowService.save(flowEntity);
- if (!saveFlowResult) {
- throw new RuntimeException("保存流转记录失败");
+ // 检查是否所有子任务都审核成功(除了被撤回和验收拒绝的)
+ boolean allSubTasksAudited = checkAllSubTasksAudited(subTasks);
+ // 这里可以根据allSubTasksAudited的结果执行后续逻辑,比如更新工单状态等
+ // 示例:如果所有子任务都审核成功,可以更新工单状态为已完成
+ if (allSubTasksAudited) {
+ // 执行工单状态更新逻辑
+ // 注意:需要注入工单相关的Service才能执行更新
+ GdWorkOrderEntity gdWorkOrderEntity = new GdWorkOrderEntity();
+ gdWorkOrderEntity.setId(task.getWorkOrderId());
+ gdWorkOrderEntity.setWorkOrderStatus(WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED.getCode());
+ boolean b1 = gdWorkOrderService.updateById(gdWorkOrderEntity);
+ if (b1) {
+ // 6. 保存流转记录:使用枚举设置flowName
+ GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
+ flowEntity.setCreateUser(AuthUtil.getUserId());
+ flowEntity.setWorkOrderId(task.getWorkOrderId());
+ flowEntity.setFlowName(WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED.getDesc());
+ flowEntity.setFlowDesc(AuthUtil.getUserName() + " " + org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 更新了任务信息,状态转换为:" + WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED.getDesc());
+ flowEntity.setOperator(AuthUtil.getUserName());
+ flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
+ flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+ return gdWorkOrderFlowService.save(flowEntity);
+ }
+ }
}
+ // 7. 验收拒绝
+ if (auditStatus == 7) {
+ GdWorkOrderEntity gdWorkOrderEntity = new GdWorkOrderEntity();
+ gdWorkOrderEntity.setId(task.getWorkOrderId());
+ gdWorkOrderEntity.setWorkOrderStatus(WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED.getCode());
+ boolean b1 = gdWorkOrderService.updateById(gdWorkOrderEntity);
+ if (b1) {
+ // 6. 保存流转记录:使用枚举设置flowName
+ GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
+ flowEntity.setCreateUser(AuthUtil.getUserId());
+ flowEntity.setWorkOrderId(task.getWorkOrderId());
+ flowEntity.setFlowName(WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED.getDesc());
+ flowEntity.setFlowDesc(AuthUtil.getUserName() + " " + org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 更新了任务信息,状态转换为:" + WorkOrderStatusEnum.EXECUTING_TO_BE_COMPLETED.getDesc());
+ flowEntity.setOperator(AuthUtil.getUserName());
+ flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
+ flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+ return gdWorkOrderFlowService.save(flowEntity);
+ }
+ }
+ return b;
+ }
+
+ /**
+ * 检查是否所有子任务都审核成功(除了被撤回和验收拒绝的)
+ *
+ * @param subTasks 子任务列表
+ * @return 是否所有子任务都审核成功
+ */
+ private boolean checkAllSubTasksAudited(List<GdPatrolTaskEntity> subTasks) {
+ for (GdPatrolTaskEntity subTask : subTasks) {
+ String taskStatus = subTask.getTaskStatus();
+ PatrolTaskStatusEnum statusEnum = PatrolTaskStatusEnum.getByValue(taskStatus);
+
+ // 如果任务状态不是审核成功状态,且不是被撤回和验收拒绝的,则返回false
+ if (!isTaskAuditSuccess(statusEnum) &&
+ statusEnum != PatrolTaskStatusEnum.WITHDRAWN &&
+ statusEnum != PatrolTaskStatusEnum.REJECTED_ACCEPTANCE) {
+ return false;
+ }
+ }
return true;
}
/**
- * 构建流转信息
- * @param status 状态值
- * @param rejectReason 拒绝原因
- * @return 包含流转名称和描述的数组 [flowName, flowDescSuffix]
+ * 判断单个任务是否审核成功
+ *
+ * @param statusEnum 任务状态枚举
+ * @return 是否审核成功
*/
- private String[] buildFlowInfo(String status, String rejectReason) {
- String flowName;
- String flowDescSuffix;
+ private boolean isTaskAuditSuccess(PatrolTaskStatusEnum statusEnum) {
+ // 审核成功的任务状态包括:审核通过
+ return statusEnum == PatrolTaskStatusEnum.AUDIT_PASSED ;
+ }
- switch (status) {
- case "0":
- flowName = PatrolTaskStatusEnum.PENDING_SIGNING.getDesc();
- flowDescSuffix = " 待签收";
+ @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 "1":
- flowName = PatrolTaskStatusEnum.REJECTED_SIGNING.getDesc();
- flowDescSuffix = " 拒绝签收:" + rejectReason;
- break;
- case "2":
- flowName = PatrolTaskStatusEnum.WITHDRAWN.getDesc();
- flowDescSuffix = " 已撤回";
- break;
- case "3":
- flowName = PatrolTaskStatusEnum.PENDING_AUDIT.getDesc();
- flowDescSuffix = " 待审核";
- break;
- case "4":
- flowName = PatrolTaskStatusEnum.AUDIT_REJECTED.getDesc();
- flowDescSuffix = " 审核驳回:" + rejectReason;
- break;
- case "5":
- flowName = PatrolTaskStatusEnum.AUDIT_PASSED.getDesc();
- flowDescSuffix = " 审核通过";
- break;
- case "6":
- flowName = PatrolTaskStatusEnum.PENDING_ACCEPTANCE.getDesc();
- flowDescSuffix = " 待验收";
- break;
- case "7":
- flowName = PatrolTaskStatusEnum.REJECTED_ACCEPTANCE.getDesc();
- flowDescSuffix = " 拒绝验收:" + rejectReason;
- break;
- case "8":
- flowName = PatrolTaskStatusEnum.ACCEPTANCE_PASSED.getDesc();
- flowDescSuffix = " 验收通过";
+ case "4": // 响应中_审核驳回 → 响应中_待审核
+ targetStatus = PatrolTaskStatusEnum.PENDING_AUDIT;
break;
default:
- flowName = "未知状态";
- flowDescSuffix = " 未知状态";
+ // 其他状态,保持原有状态
+ targetStatus = PatrolTaskStatusEnum.getByValue(currentStatus);
+ // 如果无法获取枚举,使用待签收作为默认状态
+ if (targetStatus == null) {
+ targetStatus = PatrolTaskStatusEnum.PENDING_SIGNING;
+ }
break;
}
- return new String[]{flowName, flowDescSuffix};
+ // 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.getUserName() + " " + org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " 更新了任务信息,状态转换为:" + targetStatus.getDesc());
+ flowEntity.setOperator(AuthUtil.getUserName());
+ flowEntity.setType(WorkOrderTypeEnum.PATROL_TASK.getValue());
+ flowEntity.setAreaCode(existingTask.getAreaCode());
+ flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+
+ return gdWorkOrderFlowService.save(flowEntity);
}
+
+
+ /**
+ * 检查拒绝原因是否必填
+ *
+ * @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.getDesc());
+
+ // 构建流转描述
+ String flowDesc = buildFlowDesc(newStatus, rejectReason);
+ flowEntity.setFlowDesc(flowDesc);
+
+ flowEntity.setOperator(AuthUtil.getUserName());
+ 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 = AuthUtil.getUserName() + " " +
+ org.springblade.core.tool.utils.DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss") + " ";
+
+ switch (newStatus) {
+ case REJECTED_SIGNING:
+ return baseDesc + "拒绝签收:" + rejectReason;
+ case PENDING_AUDIT:
+ return baseDesc + "待审核";
+ case AUDIT_REJECTED:
+ return baseDesc + "审核驳回:" + rejectReason;
+ case AUDIT_PASSED:
+ return baseDesc + "审核通过";
+ case REJECTED_ACCEPTANCE:
+ return baseDesc + "拒绝验收:" + rejectReason;
+ case ACCEPTANCE_PASSED:
+ return baseDesc + "验收通过";
+ default:
+ return baseDesc + newStatus.getDesc();
+ }
+ }
+
+
}
--
Gitblit v1.9.3