mirror of
https://gitee.com/hhyykk/ipms-sjy.git
synced 2025-08-03 21:04:06 +08:00
bpm:code review 钉钉流程设计器
This commit is contained in:
@@ -340,7 +340,7 @@ public class BpmnModelUtils {
|
||||
return userTaskList;
|
||||
}
|
||||
|
||||
// ========== TODO 芋艿:这里得捉摸下; ==========
|
||||
// ========== TODO @jason:单独出一个 SimpleModelUtils;定位上,它是 BPMN 的精简模式 ==========
|
||||
|
||||
/**
|
||||
* 仿钉钉流程设计模型数据结构(json) 转换成 Bpmn Model (待完善)
|
||||
@@ -382,6 +382,7 @@ public class BpmnModelUtils {
|
||||
}
|
||||
BpmSimpleModelNodeType nodeType = BpmSimpleModelNodeType.valueOf(node.getType());
|
||||
Assert.notNull(nodeType, "模型节点类型不支持");
|
||||
// TODO @jason:建议是,addXXX 都改成 buildXXX,构建出一个什么;然后返回之后,让这个方法添加到自己的结果里;
|
||||
switch (nodeType) {
|
||||
case START_EVENT_NODE:
|
||||
case APPROVE_USER_NODE:
|
||||
@@ -488,9 +489,11 @@ public class BpmnModelUtils {
|
||||
ScriptTask scriptTask = new ScriptTask();
|
||||
scriptTask.setId(node.getId());
|
||||
scriptTask.setName(node.getName());
|
||||
// TODO @jason:建议使用 ServiceTask,通过 executionListeners 实现;
|
||||
scriptTask.setScriptFormat(ScriptingEngines.DEFAULT_SCRIPTING_LANGUAGE);
|
||||
scriptTask.setScript(BPMN_SIMPLE_COPY_EXECUTION_SCRIPT);
|
||||
// 添加自定义属性
|
||||
// TODO @jason:可以使用 ServiceTask 搞 ExtensionAttribute 么?
|
||||
addExtensionAttributes(node, scriptTask);
|
||||
mainProcess.addFlowElement(scriptTask);
|
||||
}
|
||||
|
@@ -53,7 +53,7 @@ public interface BpmModelService {
|
||||
* @param id 编号
|
||||
* @param xmlBytes BPMN XML bytes
|
||||
*/
|
||||
// TODO @芋艿:可能要关注下;
|
||||
// TODO @芋艿:感觉可以不修改这个方法,而是额外加一个方法;传入 id,bpmn,json;
|
||||
void saveModelBpmnXml(String id, byte[] xmlBytes);
|
||||
|
||||
/**
|
||||
|
@@ -26,6 +26,7 @@ import static cn.iocoder.yudao.module.bpm.enums.definition.BpmSimpleModelNodeTyp
|
||||
import static cn.iocoder.yudao.module.bpm.framework.flowable.core.enums.BpmnModelConstants.USER_TASK_CANDIDATE_PARAM;
|
||||
import static cn.iocoder.yudao.module.bpm.framework.flowable.core.enums.BpmnModelConstants.USER_TASK_CANDIDATE_STRATEGY;
|
||||
|
||||
// TODO @jason:这块可以讨论下,是不是合并成一个 BpmnModelServiceImpl
|
||||
/**
|
||||
* 仿钉钉流程设计 Service 实现类
|
||||
*
|
||||
|
@@ -44,9 +44,10 @@ public class BpmProcessInstanceCopyServiceImpl implements BpmProcessInstanceCopy
|
||||
@Lazy // 延迟加载,避免循环依赖
|
||||
private BpmProcessDefinitionService processDefinitionService;
|
||||
|
||||
// TODO @芋艿:这里多加了一个 name;
|
||||
@Override
|
||||
public void createProcessInstanceCopy(Collection<Long> userIds, String processInstanceId, String taskId, String taskName) {
|
||||
// 1.1 校验任务存在 暂时去掉这个校验. 因为任务可能仿钉钉快搭的抄送节点(ScriptTask)
|
||||
// 1.1 校验任务存在 暂时去掉这个校验. 因为任务可能仿钉钉快搭的抄送节点(ScriptTask) TODO jason:抄送节点,会没有来源的 taskId 么?
|
||||
// Task task = taskService.getTask(taskId);
|
||||
// if (ObjectUtil.isNull(task)) {
|
||||
// throw exception(ErrorCodeConstants.TASK_NOT_EXISTS);
|
||||
|
@@ -9,7 +9,7 @@ import org.springframework.stereotype.Service;
|
||||
import java.util.Set;
|
||||
|
||||
/**
|
||||
* 仿钉钉快搭各个节点 Service
|
||||
* 仿钉钉快搭各个节点 Service TODO @jason:注释要有空行哈;
|
||||
* @author jason
|
||||
*/
|
||||
@Service
|
||||
@@ -21,14 +21,16 @@ public class BpmSimpleNodeService {
|
||||
private BpmProcessInstanceCopyService processInstanceCopyService;
|
||||
|
||||
/**
|
||||
* 仿钉钉快搭抄送
|
||||
* 仿钉钉快搭抄送 TODO @jason:注释要有空行哈;
|
||||
* @param execution 执行的任务(ScriptTask)
|
||||
*/
|
||||
public Boolean copy(DelegateExecution execution) {
|
||||
// TODO @芋艿:可能要考虑,系统抄送,没有 taskId 的情况。
|
||||
Set<Long> userIds = taskCandidateInvoker.calculateUsers(execution);
|
||||
FlowElement currentFlowElement = execution.getCurrentFlowElement();
|
||||
processInstanceCopyService.createProcessInstanceCopy(userIds, execution.getProcessInstanceId(),
|
||||
currentFlowElement.getId(), currentFlowElement.getName());
|
||||
return Boolean.TRUE;
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user