|
@@ -2,17 +2,18 @@ package cn.iocoder.yudao.module.bpm.convert.definition;
|
|
|
|
|
|
import cn.hutool.core.util.ArrayUtil;
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
-import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
|
|
|
import cn.iocoder.yudao.framework.common.util.date.DateUtils;
|
|
|
import cn.iocoder.yudao.framework.common.util.json.JsonUtils;
|
|
|
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
|
|
+import cn.iocoder.yudao.module.bpm.controller.admin.base.user.UserSimpleBaseVO;
|
|
|
+import cn.iocoder.yudao.module.bpm.controller.admin.definition.vo.model.BpmModelMetaInfoVO;
|
|
|
import cn.iocoder.yudao.module.bpm.controller.admin.definition.vo.model.BpmModelRespVO;
|
|
|
import cn.iocoder.yudao.module.bpm.controller.admin.definition.vo.model.BpmModelSaveReqVO;
|
|
|
import cn.iocoder.yudao.module.bpm.controller.admin.definition.vo.process.BpmProcessDefinitionRespVO;
|
|
|
import cn.iocoder.yudao.module.bpm.dal.dataobject.definition.BpmCategoryDO;
|
|
|
import cn.iocoder.yudao.module.bpm.dal.dataobject.definition.BpmFormDO;
|
|
|
import cn.iocoder.yudao.module.bpm.framework.flowable.core.util.BpmnModelUtils;
|
|
|
-import cn.iocoder.yudao.module.bpm.controller.admin.definition.vo.model.BpmModelMetaInfoVO;
|
|
|
+import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
|
|
|
import org.flowable.common.engine.impl.db.SuspensionState;
|
|
|
import org.flowable.engine.repository.Deployment;
|
|
|
import org.flowable.engine.repository.Model;
|
|
@@ -23,6 +24,8 @@ import org.mapstruct.factory.Mappers;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
|
|
|
|
+import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertList;
|
|
|
+
|
|
|
/**
|
|
|
* 流程模型 Convert
|
|
|
*
|
|
@@ -36,14 +39,16 @@ public interface BpmModelConvert {
|
|
|
default PageResult<BpmModelRespVO> buildModelPage(PageResult<Model> pageResult,
|
|
|
Map<Long, BpmFormDO> formMap,
|
|
|
Map<String, BpmCategoryDO> categoryMap, Map<String, Deployment> deploymentMap,
|
|
|
- Map<String, ProcessDefinition> processDefinitionMap) {
|
|
|
- List<BpmModelRespVO> list = CollectionUtils.convertList(pageResult.getList(), model -> {
|
|
|
+ Map<String, ProcessDefinition> processDefinitionMap,
|
|
|
+ Map<Long, AdminUserRespDTO> userMap) {
|
|
|
+ List<BpmModelRespVO> list = convertList(pageResult.getList(), model -> {
|
|
|
BpmModelMetaInfoVO metaInfo = buildMetaInfo(model);
|
|
|
BpmFormDO form = metaInfo != null ? formMap.get(metaInfo.getFormId()) : null;
|
|
|
BpmCategoryDO category = categoryMap.get(model.getCategory());
|
|
|
Deployment deployment = model.getDeploymentId() != null ? deploymentMap.get(model.getDeploymentId()) : null;
|
|
|
ProcessDefinition processDefinition = model.getDeploymentId() != null ? processDefinitionMap.get(model.getDeploymentId()) : null;
|
|
|
- return buildModel0(model, metaInfo, form, category, deployment, processDefinition);
|
|
|
+ List<AdminUserRespDTO> startUsers = metaInfo != null ? convertList(metaInfo.getStartUserIds(), userMap::get) : null;
|
|
|
+ return buildModel0(model, metaInfo, form, category, deployment, processDefinition, startUsers);
|
|
|
});
|
|
|
return new PageResult<>(list, pageResult.getTotal());
|
|
|
}
|
|
@@ -51,7 +56,7 @@ public interface BpmModelConvert {
|
|
|
default BpmModelRespVO buildModel(Model model,
|
|
|
byte[] bpmnBytes) {
|
|
|
BpmModelMetaInfoVO metaInfo = buildMetaInfo(model);
|
|
|
- BpmModelRespVO modelVO = buildModel0(model, metaInfo, null, null, null, null);
|
|
|
+ BpmModelRespVO modelVO = buildModel0(model, metaInfo, null, null, null, null, null);
|
|
|
if (ArrayUtil.isNotEmpty(bpmnBytes)) {
|
|
|
modelVO.setBpmnXml(BpmnModelUtils.getBpmnXml(bpmnBytes));
|
|
|
}
|
|
@@ -60,7 +65,8 @@ public interface BpmModelConvert {
|
|
|
|
|
|
default BpmModelRespVO buildModel0(Model model,
|
|
|
BpmModelMetaInfoVO metaInfo, BpmFormDO form, BpmCategoryDO category,
|
|
|
- Deployment deployment, ProcessDefinition processDefinition) {
|
|
|
+ Deployment deployment, ProcessDefinition processDefinition,
|
|
|
+ List<AdminUserRespDTO> startUsers) {
|
|
|
BpmModelRespVO modelRespVO = new BpmModelRespVO().setId(model.getId()).setName(model.getName())
|
|
|
.setKey(model.getKey()).setCategory(model.getCategory())
|
|
|
.setCreateTime(DateUtils.of(model.getCreateTime()));
|
|
@@ -82,6 +88,8 @@ public interface BpmModelConvert {
|
|
|
modelRespVO.getProcessDefinition().setDeploymentTime(DateUtils.of(deployment.getDeploymentTime()));
|
|
|
}
|
|
|
}
|
|
|
+ // User
|
|
|
+ modelRespVO.setStartUsers(BeanUtils.toBean(startUsers, UserSimpleBaseVO.class));
|
|
|
return modelRespVO;
|
|
|
}
|
|
|
|