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/GdWorkOrderServiceImpl.java |   26 ++++++++++++++++++++++++--
 1 files changed, 24 insertions(+), 2 deletions(-)

diff --git a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java
index 2e25613..15a88b8 100644
--- a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java
+++ b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import org.apache.commons.lang3.StringUtils;
 import org.springblade.core.mp.base.BaseServiceImpl;
 import org.springblade.core.secure.utils.AuthUtil;
@@ -13,8 +14,10 @@
 import org.sxkj.common.constant.WordOrderConstant;
 import org.sxkj.common.utils.GeomUtils;
 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;
 import org.sxkj.gd.workorder.enums.WorkOrderTypeEnum;
 import org.sxkj.gd.workorder.excel.GdWorkOrderExcel;
@@ -22,6 +25,7 @@
 import org.sxkj.gd.workorder.param.WorkOrderAddParam;
 import org.sxkj.gd.workorder.param.WorkOrderPageParam;
 import org.sxkj.gd.workorder.param.WorkOrderStatusParam;
+import org.sxkj.gd.workorder.service.IGdPatrolTaskService;
 import org.sxkj.gd.workorder.service.IGdWorkOrderFlowService;
 import org.sxkj.gd.workorder.service.IGdWorkOrderService;
 import org.sxkj.gd.workorder.vo.GdWorkOrderVO;
@@ -41,6 +45,8 @@
 
 	@Autowired
 	private IGdWorkOrderFlowService gdWorkOrderFlowService;
+	@Autowired
+	private IGdPatrolTaskService gdPatrolTaskService;
 
 	@Override
 	public GdWorkOrderEntity getWorkOrderDetail(GdWorkOrderEntity gdWorkOrder) {
@@ -94,7 +100,7 @@
 			// 更新操作
 			entity.setUpdateUser(AuthUtil.getUserId());
 			entity.setUpdateTime(now);
-			
+
 			// 状态转换:拒绝状态修改后自动转换为待处理状态
 			switch (entity.getWorkOrderStatus()) {
 				case "11": // 发布中_拒绝接单 → 发布中_接单中
@@ -103,6 +109,7 @@
 				case "24": // 响应中_拒绝取消 → 响应中_申请取消
 					entity.setWorkOrderStatus(WorkOrderStatusEnum.RESPONDING_APPLY_CANCEL.getCode());
 					break;
+				case "20": // 响应中_待拆分 → 响应中_申请修改
 				case "25": // 响应中_拒绝修改 → 响应中_申请修改
 					entity.setWorkOrderStatus(WorkOrderStatusEnum.RESPONDING_APPLY_MODIFY.getCode());
 					break;
@@ -157,7 +164,7 @@
 		if (currentStatus == null || !currentStatus.isAllowedOperation(operationType)) {
 			return false;
 		}
-
+		// 1接单,2拒接接单,3申请取消,4申请修改, 5同意取消  6不同意取消 7.同意修改 8.不同意修改 9.协商修改 10.同意修改
 		// 3. 确定新状态和流转名称
 		WorkOrderStatusEnum newStatusEnum;
 		switch (operationType) {
@@ -183,6 +190,12 @@
 			case 8: // 不同意修改
 				newStatusEnum = WorkOrderStatusEnum.RESPONDING_REJECT_MODIFY;
 				break;
+			case 9: // 协商修改 --> 协商修改
+				newStatusEnum = WorkOrderStatusEnum.EXECUTING_NEGOTIATE_MODIFY;
+				break;
+			case 10: // 同意协商修改 --> 待拆分
+				newStatusEnum = WorkOrderStatusEnum.RESPONDING_TO_BE_SPLIT;
+				break;
 			default: // 无效操作类型
 				return false;
 		}
@@ -191,6 +204,7 @@
 		Date now = new Date();
 		workOrder.setWorkOrderStatus(newStatusEnum.getCode());
 		workOrder.setUpdateUser(AuthUtil.getUserId());
+		workOrder.setGeom(null);
 		workOrder.setUpdateTime(now);
 		boolean updateResult = updateById(workOrder);
 
@@ -207,6 +221,14 @@
 			flowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
 			return gdWorkOrderFlowService.save(flowEntity);
 		}
+		// 6. 把待验收的都改为待签收状态
+		if (operationType == 10) {
+			boolean update = gdPatrolTaskService.update(Wrappers.<GdPatrolTaskEntity>lambdaUpdate()
+				.set(GdPatrolTaskEntity::getTaskStatus, PatrolTaskStatusEnum.PENDING_SIGNING.getValue())
+				.eq(GdPatrolTaskEntity::getWorkOrderId, workOrder.getId())
+				.eq(GdPatrolTaskEntity::getTaskStatus, PatrolTaskStatusEnum.PENDING_ACCEPTANCE.getValue())
+			);
+		}
 
 		return false;
 	}

--
Gitblit v1.9.3