From c9433fab340a766a99b2c01ca018609cac407cee Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期日, 24 八月 2025 15:17:29 +0800
Subject: [PATCH] 偏离单文件名+P1

---
 blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java |   27 +++++++++++++++++++++++----
 1 files changed, 23 insertions(+), 4 deletions(-)

diff --git a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java
index 5382be2..1deafdc 100644
--- a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java
+++ b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/controller/DispatchController.java
@@ -21,6 +21,7 @@
 import org.springblade.core.tool.utils.StringUtil;
 import org.springblade.mdm.flow.constants.FlowContants;
 import org.springblade.mdm.flow.entity.ApproveRecord;
+import org.springblade.mdm.flow.entity.TaskDispatch;
 import org.springblade.mdm.flow.excution.StartDispatcher;
 import org.springblade.mdm.flow.service.ApproveRecordService;
 import org.springblade.mdm.flow.service.FlowCommonService;
@@ -32,6 +33,7 @@
 import org.springblade.mdm.program.entity.ProcessProgRef;
 import org.springblade.mdm.program.service.NcNodeAutoCreateService;
 import org.springblade.mdm.program.service.ProcessProgRefService;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
@@ -70,16 +72,33 @@
 	@Operation(summary = "浠诲姟璁″垝(娲惧伐娴佺▼)", description = "鍚姩娲惧伐娴佺▼")
 	public R<Boolean> start(@RequestBody TaskAssignVO startVO) {
 		try {
-			long id= taskDispatchService.saveTask(startVO);
-			String instId = dispatcher.start(startVO);
-			taskDispatchService.updateSuccess(id,instId);
-			return R.data(true);
+			TaskDispatch dispatch = taskDispatchService.saveTask(startVO);
+			boolean isDup = taskDispatchService.checkIsDuplicate(startVO);
+			if (isDup) {
+				dispatch.setStatus(TaskDispatch.STATUS_DUP);
+				taskDispatchService.updateById(dispatch);
+				return R.fail("閲嶅娲惧伐");
+			}else {
+				try {
+					String instId = dispatcher.start(startVO);
+					dispatch.setStatus(TaskDispatch.STATUS_STARTED);
+					dispatch.setProcessInstanceId(instId);
+					taskDispatchService.updateById(dispatch);
+					return R.data(true);
+				}catch (Exception e) {
+					dispatch.setStatus(TaskDispatch.STATUS_EXCEPTION);
+					taskDispatchService.updateById(dispatch);
+					return R.fail("浠诲姟鍚姩寮傚父");
+				}
+			}
+
 		}catch(Exception e){
 			return R.fail(e.getMessage());
 		}
 
 	}
 
+
 	AbstractFlowCompleteService getActualService(String processInstanceId){
 		ProcessInstance inst = runtimeService.createProcessInstanceQuery().processInstanceId(processInstanceId).includeProcessVariables().singleResult();
 		if(inst.getProcessDefinitionKey().equals(FlowContants.TRY_PROCESS_KEY) || inst.getProcessDefinitionKey().equals(FlowContants.CURE_PROCESS_KEY)

--
Gitblit v1.9.3