From dc60071d490879633da257052fcbc24b2e71f3b2 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Wed, 21 Dec 2022 17:01:03 +0800
Subject: [PATCH] 延期申请工作流

---
 src/main/java/org/springblade/modules/applicationDelay/service/impl/ApplicationDelayServiceImpl.java |   65 ++++++++++++++++++++++++++++++++
 1 files changed, 65 insertions(+), 0 deletions(-)

diff --git a/src/main/java/org/springblade/modules/applicationDelay/service/impl/ApplicationDelayServiceImpl.java b/src/main/java/org/springblade/modules/applicationDelay/service/impl/ApplicationDelayServiceImpl.java
index 00fe242..30671eb 100644
--- a/src/main/java/org/springblade/modules/applicationDelay/service/impl/ApplicationDelayServiceImpl.java
+++ b/src/main/java/org/springblade/modules/applicationDelay/service/impl/ApplicationDelayServiceImpl.java
@@ -16,6 +16,20 @@
  */
 package org.springblade.modules.applicationDelay.service.impl;
 
+import lombok.AllArgsConstructor;
+import org.flowable.engine.TaskService;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.secure.utils.AuthUtil;
+import org.springblade.core.tool.support.Kv;
+import org.springblade.core.tool.utils.DateUtil;
+import org.springblade.core.tool.utils.Func;
+import org.springblade.core.tool.utils.StringUtil;
+import org.springblade.flow.business.service.IFlowService;
+import org.springblade.flow.core.constant.ProcessConstant;
+import org.springblade.flow.core.entity.BladeFlow;
+import org.springblade.flow.core.utils.FlowUtil;
+import org.springblade.flow.core.utils.TaskUtil;
+import org.springblade.flow.demo.leave.entity.ProcessLeave;
 import org.springblade.modules.applicationDelay.entity.ApplicationDelayEntity;
 import org.springblade.modules.applicationDelay.vo.ApplicationDelayVO;
 import org.springblade.modules.applicationDelay.mapper.ApplicationDelayMapper;
@@ -23,6 +37,9 @@
 import org.springblade.core.mp.base.BaseServiceImpl;
 import org.springframework.stereotype.Service;
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.Map;
 
 /**
  * 延期申请表 服务实现类
@@ -31,12 +48,60 @@
  * @since 2022-12-13
  */
 @Service
+@AllArgsConstructor
 public class ApplicationDelayServiceImpl extends BaseServiceImpl<ApplicationDelayMapper, ApplicationDelayEntity> implements IApplicationDelayService {
+	private final IFlowService flowService;
+	private final TaskService taskService;
 
 	@Override
 	public IPage<ApplicationDelayVO> selectApplicationDelayPage(IPage<ApplicationDelayVO> page, ApplicationDelayVO applicationDelay) {
 		return page.setRecords(baseMapper.selectApplicationDelayPage(page, applicationDelay));
 	}
 
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public Boolean startProcess(ApplicationDelayVO applicationDelayEntity) {
+		String businessTable = FlowUtil.getBusinessTable(ProcessConstant.DELAY_AUDIT);
+		if (Func.isEmpty(applicationDelayEntity.getId())) {
+			// 保存leave
+			save(applicationDelayEntity);
+			// 启动流程
+			Kv variables = Kv.create()
+				.set(ProcessConstant.TASK_VARIABLE_CREATE_USER, AuthUtil.getUserName());
+			BladeFlow flow = flowService.startProcessInstanceById(applicationDelayEntity.getProcessDefinitionId(), FlowUtil.getBusinessKey(businessTable, String.valueOf(applicationDelayEntity.getId())), variables);
+			if (Func.isNotEmpty(flow)) {
+				log.debug("流程已启动,流程ID:" + flow.getProcessInstanceId());
+				// 返回流程id写入leave
+				applicationDelayEntity.setProcessInstanceId(flow.getProcessInstanceId());
+				updateById(applicationDelayEntity);
+			} else {
+				throw new ServiceException("开启流程失败");
+			}
+		} else {
+
+			updateById(applicationDelayEntity);
+		}
+		return true;
+	}
+
+	@Override
+	public Boolean completeTask(BladeFlow flow) {
+		String taskId = flow.getTaskId();
+		String processInstanceId = flow.getProcessInstanceId();
+		String comment = Func.toStr(flow.getComment(), ProcessConstant.PASS_COMMENT);
+		// 增加评论
+		if (StringUtil.isNoneBlank(processInstanceId, comment)) {
+			taskService.addComment(taskId, processInstanceId, comment);
+		}
+		// 创建变量
+		Map<String, Object> variables = flow.getVariables();
+		if (variables == null) {
+			variables = Kv.create();
+		}
+		variables.put(ProcessConstant.PASS_KEY, flow.isPass());
+		// 完成任务
+		taskService.complete(taskId, variables);
+		return true;
+	}
 
 }

--
Gitblit v1.9.3