From 6e2ffa951a5a08366e001a6bdec958eba9abcf99 Mon Sep 17 00:00:00 2001
From: rain <1679827795@qq.com>
Date: Mon, 19 Jan 2026 15:15:28 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdPatrolTaskServiceImpl.java |  157 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 157 insertions(+), 0 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 8daf5c8..e6e6846 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,7 +16,15 @@
  */
 package org.sxkj.gd.workorder.service.impl;
 
+import org.springblade.core.secure.utils.AuthUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
 import org.sxkj.gd.workorder.entity.GdPatrolTaskEntity;
+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.service.IGdWorkOrderFlowService;
 import org.sxkj.gd.workorder.vo.GdPatrolTaskVO;
 import org.sxkj.gd.workorder.excel.GdPatrolTaskExcel;
 import org.sxkj.gd.workorder.mapper.GdPatrolTaskMapper;
@@ -25,6 +33,8 @@
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import org.springblade.core.mp.base.BaseServiceImpl;
+
+import java.util.Date;
 import java.util.List;
 
 /**
@@ -35,6 +45,9 @@
  */
 @Service
 public class GdPatrolTaskServiceImpl extends BaseServiceImpl<GdPatrolTaskMapper, GdPatrolTaskEntity> implements IGdPatrolTaskService {
+
+	@Autowired
+	private IGdWorkOrderFlowService gdWorkOrderFlowService;
 
 	@Override
 	public IPage<GdPatrolTaskVO> selectGdPatrolTaskPage(IPage<GdPatrolTaskVO> page, GdPatrolTaskVO gdPatrolTask) {
@@ -51,4 +64,148 @@
 		return gdPatrolTaskList;
 	}
 
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public boolean savePatrolTask(List<GdPatrolTaskEntity> taskEntityList) {
+		// 更新流程节点
+		for (GdPatrolTaskEntity gdPatrolTaskEntity : taskEntityList) {
+			// 保存巡逻任务
+			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.getDesc());
+			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());
+			gdWorkOrderFlowEntity.setCreateDept(Long.valueOf(AuthUtil.getDeptId()));
+			boolean save1 = gdWorkOrderFlowService.save(gdWorkOrderFlowEntity);
+			if (!save1) {
+				// 流转记录保存失败,抛出异常触发回滚
+				throw new RuntimeException("保存流转记录失败:" + gdWorkOrderFlowEntity.toString());
+			}
+		}
+
+		// 所有任务和流转记录都保存成功
+		return true;
+	}
+
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public boolean auditPatrolTask(Long id, String auditStatus, String rejectReason) {
+		// 1. 获取巡查任务
+		GdPatrolTaskEntity task = getById(id);
+		if (task == null) {
+			throw new RuntimeException("巡查任务不存在");
+		}
+
+		// 2. 检查任务状态是否为待审核
+		if (!PatrolTaskStatusEnum.PENDING_AUDIT.getValue().equals(task.getTaskStatus().toString())) {
+			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("审核驳回或拒绝验收时必须填写拒绝原因");
+		}
+
+		// 4. 更新任务状态
+		task.setTaskStatus(Byte.valueOf(auditStatus));
+		boolean updateResult = updateById(task);
+		if (!updateResult) {
+			throw new RuntimeException("更新任务状态失败");
+		}
+
+		// 5. 保存流转记录
+		GdWorkOrderFlowEntity flowEntity = new GdWorkOrderFlowEntity();
+		flowEntity.setCreateUser(AuthUtil.getUserId());
+		flowEntity.setWorkOrderId(id);
+
+		// 设置流转名称和描述
+		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("保存流转记录失败");
+		}
+
+		return true;
+	}
+
+	/**
+	 * 构建流转信息
+	 * @param status 状态值
+	 * @param rejectReason 拒绝原因
+	 * @return 包含流转名称和描述的数组 [flowName, flowDescSuffix]
+	 */
+	private String[] buildFlowInfo(String status, String rejectReason) {
+		String flowName;
+		String flowDescSuffix;
+
+		switch (status) {
+			case "0":
+				flowName = PatrolTaskStatusEnum.PENDING_SIGNING.getDesc();
+				flowDescSuffix = " 待签收";
+				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 = " 验收通过";
+				break;
+			default:
+				flowName = "未知状态";
+				flowDescSuffix = " 未知状态";
+				break;
+		}
+
+		return new String[]{flowName, flowDescSuffix};
+	}
 }

--
Gitblit v1.9.3