|
@@ -3,23 +3,27 @@ package cn.iocoder.yudao.module.bpm.controller.admin.task;
|
|
import cn.hutool.core.collection.CollUtil;
|
|
import cn.hutool.core.collection.CollUtil;
|
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
-import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.instance.BpmProcessInstanceCopyCreateReqVO;
|
|
|
|
-import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.instance.BpmProcessInstanceCopyMyPageReqVO;
|
|
|
|
-import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.instance.BpmProcessInstanceCopyPageItemRespVO;
|
|
|
|
-import cn.iocoder.yudao.module.bpm.convert.cc.BpmProcessInstanceCopyConvert;
|
|
|
|
|
|
+import cn.iocoder.yudao.framework.common.util.collection.MapUtils;
|
|
|
|
+import cn.iocoder.yudao.framework.common.util.date.DateUtils;
|
|
|
|
+import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
|
|
|
+import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.cc.BpmProcessInstanceCopyRespVO;
|
|
|
|
+import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.instance.BpmProcessInstanceCopyPageReqVO;
|
|
import cn.iocoder.yudao.module.bpm.dal.dataobject.cc.BpmProcessInstanceCopyDO;
|
|
import cn.iocoder.yudao.module.bpm.dal.dataobject.cc.BpmProcessInstanceCopyDO;
|
|
|
|
+import cn.iocoder.yudao.module.bpm.service.task.BpmProcessInstanceCopyService;
|
|
import cn.iocoder.yudao.module.bpm.service.task.BpmProcessInstanceService;
|
|
import cn.iocoder.yudao.module.bpm.service.task.BpmProcessInstanceService;
|
|
import cn.iocoder.yudao.module.bpm.service.task.BpmTaskService;
|
|
import cn.iocoder.yudao.module.bpm.service.task.BpmTaskService;
|
|
-import cn.iocoder.yudao.module.bpm.service.task.cc.BpmProcessInstanceCopyService;
|
|
|
|
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
|
|
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
|
|
import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
|
|
import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
import jakarta.annotation.Resource;
|
|
import jakarta.annotation.Resource;
|
|
import jakarta.validation.Valid;
|
|
import jakarta.validation.Valid;
|
|
|
|
+import org.flowable.engine.history.HistoricProcessInstance;
|
|
import org.springframework.security.access.prepost.PreAuthorize;
|
|
import org.springframework.security.access.prepost.PreAuthorize;
|
|
import org.springframework.validation.annotation.Validated;
|
|
import org.springframework.validation.annotation.Validated;
|
|
-import org.springframework.web.bind.annotation.*;
|
|
|
|
|
|
+import org.springframework.web.bind.annotation.GetMapping;
|
|
|
|
+import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
+import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
import java.util.Map;
|
|
import java.util.Map;
|
|
import java.util.stream.Stream;
|
|
import java.util.stream.Stream;
|
|
@@ -31,35 +35,27 @@ import static cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUti
|
|
|
|
|
|
@Tag(name = "管理后台 - 流程实例抄送")
|
|
@Tag(name = "管理后台 - 流程实例抄送")
|
|
@RestController
|
|
@RestController
|
|
-@RequestMapping("/bpm/process-instance/cc")
|
|
|
|
|
|
+@RequestMapping("/bpm/process-instance/copy")
|
|
@Validated
|
|
@Validated
|
|
public class BpmProcessInstanceCopyController {
|
|
public class BpmProcessInstanceCopyController {
|
|
|
|
|
|
@Resource
|
|
@Resource
|
|
private BpmProcessInstanceCopyService processInstanceCopyService;
|
|
private BpmProcessInstanceCopyService processInstanceCopyService;
|
|
@Resource
|
|
@Resource
|
|
- private BpmProcessInstanceService bpmProcessInstanceService;
|
|
|
|
-
|
|
|
|
- @Resource
|
|
|
|
- private AdminUserApi adminUserApi;
|
|
|
|
-
|
|
|
|
|
|
+ private BpmProcessInstanceService processInstanceService;
|
|
@Resource
|
|
@Resource
|
|
private BpmTaskService bpmTaskService;
|
|
private BpmTaskService bpmTaskService;
|
|
|
|
|
|
- @PostMapping("/create")
|
|
|
|
- @Operation(summary = "抄送流程")
|
|
|
|
- @PreAuthorize("@ss.hasPermission('bpm:process-instance-cc:create')")
|
|
|
|
- public CommonResult<Boolean> createProcessInstanceCopy(@Valid @RequestBody BpmProcessInstanceCopyCreateReqVO createReqVO) {
|
|
|
|
- processInstanceCopyService.createProcessInstanceCopy(getLoginUserId(), createReqVO);
|
|
|
|
- return success(true);
|
|
|
|
- }
|
|
|
|
|
|
+ @Resource
|
|
|
|
+ private AdminUserApi adminUserApi;
|
|
|
|
|
|
- @GetMapping("/my-page")
|
|
|
|
|
|
+ @GetMapping("/page")
|
|
@Operation(summary = "获得抄送流程分页列表")
|
|
@Operation(summary = "获得抄送流程分页列表")
|
|
@PreAuthorize("@ss.hasPermission('bpm:process-instance-cc:query')")
|
|
@PreAuthorize("@ss.hasPermission('bpm:process-instance-cc:query')")
|
|
- public CommonResult<PageResult<BpmProcessInstanceCopyPageItemRespVO>> getProcessInstanceCopyPage(
|
|
|
|
- @Valid BpmProcessInstanceCopyMyPageReqVO pageReqVO) {
|
|
|
|
- PageResult<BpmProcessInstanceCopyDO> pageResult = processInstanceCopyService.getMyProcessInstanceCopyPage(getLoginUserId(), pageReqVO);
|
|
|
|
|
|
+ public CommonResult<PageResult<BpmProcessInstanceCopyRespVO>> getProcessInstanceCopyPage(
|
|
|
|
+ @Valid BpmProcessInstanceCopyPageReqVO pageReqVO) {
|
|
|
|
+ PageResult<BpmProcessInstanceCopyDO> pageResult = processInstanceCopyService.getProcessInstanceCopyPage(
|
|
|
|
+ getLoginUserId(), pageReqVO);
|
|
if (CollUtil.isEmpty(pageResult.getList())) {
|
|
if (CollUtil.isEmpty(pageResult.getList())) {
|
|
return success(new PageResult<>(pageResult.getTotal()));
|
|
return success(new PageResult<>(pageResult.getTotal()));
|
|
}
|
|
}
|
|
@@ -67,11 +63,17 @@ public class BpmProcessInstanceCopyController {
|
|
// 拼接返回
|
|
// 拼接返回
|
|
Map<String, String> taskNameMap = bpmTaskService.getTaskNameByTaskIds(
|
|
Map<String, String> taskNameMap = bpmTaskService.getTaskNameByTaskIds(
|
|
convertSet(pageResult.getList(), BpmProcessInstanceCopyDO::getTaskId));
|
|
convertSet(pageResult.getList(), BpmProcessInstanceCopyDO::getTaskId));
|
|
- Map<String, String> processNameMap = bpmProcessInstanceService.getProcessInstanceNameMap(
|
|
|
|
|
|
+ Map<String, HistoricProcessInstance> processInstanceMap = processInstanceService.getHistoricProcessInstanceMap(
|
|
convertSet(pageResult.getList(), BpmProcessInstanceCopyDO::getProcessInstanceId));
|
|
convertSet(pageResult.getList(), BpmProcessInstanceCopyDO::getProcessInstanceId));
|
|
Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(convertListByFlatMap(pageResult.getList(),
|
|
Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(convertListByFlatMap(pageResult.getList(),
|
|
copy -> Stream.of(copy.getStartUserId(), Long.parseLong(copy.getCreator()))));
|
|
copy -> Stream.of(copy.getStartUserId(), Long.parseLong(copy.getCreator()))));
|
|
- return success(BpmProcessInstanceCopyConvert.INSTANCE.convertPage(pageResult, taskNameMap, processNameMap, userMap));
|
|
|
|
|
|
+ return success(BeanUtils.toBean(pageResult, BpmProcessInstanceCopyRespVO.class, copyVO -> {
|
|
|
|
+ MapUtils.findAndThen(userMap, Long.valueOf(copyVO.getCreator()), user -> copyVO.setCreatorName(user.getNickname()));
|
|
|
|
+ MapUtils.findAndThen(userMap, copyVO.getStartUserId(), user -> copyVO.setStartUserName(user.getNickname()));
|
|
|
|
+ MapUtils.findAndThen(taskNameMap, copyVO.getTaskId(), copyVO::setTaskName);
|
|
|
|
+ MapUtils.findAndThen(processInstanceMap, copyVO.getProcessInstanceId(),
|
|
|
|
+ processInstance -> copyVO.setProcessInstanceStartTime(DateUtils.of(processInstance.getStartTime())));
|
|
|
|
+ }));
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
}
|