|
@@ -1,21 +1,41 @@
|
|
|
package cn.iocoder.yudao.module.bpm.controller.admin.task;
|
|
|
|
|
|
+import cn.hutool.core.collection.CollUtil;
|
|
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
+import cn.iocoder.yudao.framework.common.util.number.NumberUtils;
|
|
|
import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.task.*;
|
|
|
+import cn.iocoder.yudao.module.bpm.convert.task.BpmTaskConvert;
|
|
|
+import cn.iocoder.yudao.module.bpm.dal.dataobject.definition.BpmFormDO;
|
|
|
+import cn.iocoder.yudao.module.bpm.service.definition.BpmFormService;
|
|
|
+import cn.iocoder.yudao.module.bpm.service.task.BpmProcessInstanceService;
|
|
|
import cn.iocoder.yudao.module.bpm.service.task.BpmTaskService;
|
|
|
+import cn.iocoder.yudao.module.system.api.dept.DeptApi;
|
|
|
+import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
|
|
+import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
|
|
|
+import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
|
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
|
import io.swagger.v3.oas.annotations.Parameter;
|
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
|
+import jakarta.annotation.Resource;
|
|
|
+import jakarta.validation.Valid;
|
|
|
+import org.flowable.bpmn.model.UserTask;
|
|
|
+import org.flowable.engine.history.HistoricProcessInstance;
|
|
|
+import org.flowable.engine.runtime.ProcessInstance;
|
|
|
+import org.flowable.task.api.Task;
|
|
|
+import org.flowable.task.api.history.HistoricTaskInstance;
|
|
|
import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
import org.springframework.validation.annotation.Validated;
|
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
|
|
-import javax.annotation.Resource;
|
|
|
-import javax.validation.Valid;
|
|
|
+import java.util.Collections;
|
|
|
import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.Set;
|
|
|
+import java.util.stream.Stream;
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
|
|
+import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.*;
|
|
|
import static cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils.getLoginUserId;
|
|
|
|
|
|
@Tag(name = "管理后台 - 流程任务实例")
|
|
@@ -26,19 +46,69 @@ public class BpmTaskController {
|
|
|
|
|
|
@Resource
|
|
|
private BpmTaskService taskService;
|
|
|
+ @Resource
|
|
|
+ private BpmProcessInstanceService processInstanceService;
|
|
|
+ @Resource
|
|
|
+ private BpmFormService formService;
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ private AdminUserApi adminUserApi;
|
|
|
+ @Resource
|
|
|
+ private DeptApi deptApi;
|
|
|
|
|
|
@GetMapping("todo-page")
|
|
|
@Operation(summary = "获取 Todo 待办任务分页")
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:query')")
|
|
|
- public CommonResult<PageResult<BpmTaskTodoPageItemRespVO>> getTodoTaskPage(@Valid BpmTaskTodoPageReqVO pageVO) {
|
|
|
- return success(taskService.getTodoTaskPage(getLoginUserId(), pageVO));
|
|
|
+ public CommonResult<PageResult<BpmTaskRespVO>> getTaskTodoPage(@Valid BpmTaskPageReqVO pageVO) {
|
|
|
+ PageResult<Task> pageResult = taskService.getTaskTodoPage(getLoginUserId(), pageVO);
|
|
|
+ if (CollUtil.isEmpty(pageResult.getList())) {
|
|
|
+ return success(PageResult.empty());
|
|
|
+ }
|
|
|
+
|
|
|
+ // 拼接数据
|
|
|
+ Map<String, ProcessInstance> processInstanceMap = processInstanceService.getProcessInstanceMap(
|
|
|
+ convertSet(pageResult.getList(), Task::getProcessInstanceId));
|
|
|
+ Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(
|
|
|
+ convertSet(processInstanceMap.values(), instance -> Long.valueOf(instance.getStartUserId())));
|
|
|
+ return success(BpmTaskConvert.INSTANCE.buildTodoTaskPage(pageResult, processInstanceMap, userMap));
|
|
|
}
|
|
|
|
|
|
@GetMapping("done-page")
|
|
|
@Operation(summary = "获取 Done 已办任务分页")
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:query')")
|
|
|
- public CommonResult<PageResult<BpmTaskDonePageItemRespVO>> getDoneTaskPage(@Valid BpmTaskDonePageReqVO pageVO) {
|
|
|
- return success(taskService.getDoneTaskPage(getLoginUserId(), pageVO));
|
|
|
+ public CommonResult<PageResult<BpmTaskRespVO>> getTaskDonePage(@Valid BpmTaskPageReqVO pageVO) {
|
|
|
+ PageResult<HistoricTaskInstance> pageResult = taskService.getTaskDonePage(getLoginUserId(), pageVO);
|
|
|
+ if (CollUtil.isEmpty(pageResult.getList())) {
|
|
|
+ return success(PageResult.empty());
|
|
|
+ }
|
|
|
+
|
|
|
+ // 拼接数据
|
|
|
+ Map<String, HistoricProcessInstance> processInstanceMap = processInstanceService.getHistoricProcessInstanceMap(
|
|
|
+ convertSet(pageResult.getList(), HistoricTaskInstance::getProcessInstanceId));
|
|
|
+ Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(
|
|
|
+ convertSet(processInstanceMap.values(), instance -> Long.valueOf(instance.getStartUserId())));
|
|
|
+ return success(BpmTaskConvert.INSTANCE.buildTaskPage(pageResult, processInstanceMap, userMap, null));
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping("manager-page")
|
|
|
+ @Operation(summary = "获取全部任务的分页", description = "用于【流程任务】菜单")
|
|
|
+ @PreAuthorize("@ss.hasPermission('bpm:task:mananger-query')")
|
|
|
+ public CommonResult<PageResult<BpmTaskRespVO>> getDoneTaskPage(@Valid BpmTaskPageReqVO pageVO) {
|
|
|
+ PageResult<HistoricTaskInstance> pageResult = taskService.getTaskPage(getLoginUserId(), pageVO);
|
|
|
+ if (CollUtil.isEmpty(pageResult.getList())) {
|
|
|
+ return success(PageResult.empty());
|
|
|
+ }
|
|
|
+
|
|
|
+ // 拼接数据
|
|
|
+ Map<String, HistoricProcessInstance> processInstanceMap = processInstanceService.getHistoricProcessInstanceMap(
|
|
|
+ convertSet(pageResult.getList(), HistoricTaskInstance::getProcessInstanceId));
|
|
|
+ // 获得 User 和 Dept Map
|
|
|
+ Set<Long> userIds = convertSet(processInstanceMap.values(), instance -> Long.valueOf(instance.getStartUserId()));
|
|
|
+ userIds.addAll(convertSet(pageResult.getList(), task -> NumberUtils.parseLong(task.getAssignee())));
|
|
|
+ Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(userIds);
|
|
|
+ Map<Long, DeptRespDTO> deptMap = deptApi.getDeptMap(
|
|
|
+ convertSet(userMap.values(), AdminUserRespDTO::getDeptId));
|
|
|
+ return success(BpmTaskConvert.INSTANCE.buildTaskPage(pageResult, processInstanceMap, userMap, deptMap));
|
|
|
}
|
|
|
|
|
|
@GetMapping("/list-by-process-instance-id")
|
|
@@ -47,7 +117,25 @@ public class BpmTaskController {
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:query')")
|
|
|
public CommonResult<List<BpmTaskRespVO>> getTaskListByProcessInstanceId(
|
|
|
@RequestParam("processInstanceId") String processInstanceId) {
|
|
|
- return success(taskService.getTaskListByProcessInstanceId(processInstanceId));
|
|
|
+ List<HistoricTaskInstance> taskList = taskService.getTaskListByProcessInstanceId(processInstanceId);
|
|
|
+ if (CollUtil.isEmpty(taskList)) {
|
|
|
+ return success(Collections.emptyList());
|
|
|
+ }
|
|
|
+
|
|
|
+ // 拼接数据
|
|
|
+ HistoricProcessInstance processInstance = processInstanceService.getHistoricProcessInstance(processInstanceId);
|
|
|
+ // 获得 User 和 Dept Map
|
|
|
+ Set<Long> userIds = convertSetByFlatMap(taskList, task ->
|
|
|
+ Stream.of(NumberUtils.parseLong(task.getAssignee()), NumberUtils.parseLong(task.getOwner())));
|
|
|
+ userIds.add(NumberUtils.parseLong(processInstance.getStartUserId()));
|
|
|
+ Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(userIds);
|
|
|
+ Map<Long, DeptRespDTO> deptMap = deptApi.getDeptMap(
|
|
|
+ convertSet(userMap.values(), AdminUserRespDTO::getDeptId));
|
|
|
+ // 获得 Form Map
|
|
|
+ Map<Long, BpmFormDO> formMap = formService.getFormMap(
|
|
|
+ convertSet(taskList, task -> NumberUtils.parseLong(task.getFormKey())));
|
|
|
+ return success(BpmTaskConvert.INSTANCE.buildTaskListByProcessInstanceId(taskList, processInstance,
|
|
|
+ formMap, userMap, deptMap));
|
|
|
}
|
|
|
|
|
|
@PutMapping("/approve")
|
|
@@ -66,20 +154,14 @@ public class BpmTaskController {
|
|
|
return success(true);
|
|
|
}
|
|
|
|
|
|
- @PutMapping("/update-assignee")
|
|
|
- @Operation(summary = "更新任务的负责人", description = "用于【流程详情】的【转派】按钮")
|
|
|
- @PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
- public CommonResult<Boolean> updateTaskAssignee(@Valid @RequestBody BpmTaskUpdateAssigneeReqVO reqVO) {
|
|
|
- taskService.updateTaskAssignee(getLoginUserId(), reqVO);
|
|
|
- return success(true);
|
|
|
- }
|
|
|
-
|
|
|
- @GetMapping("/return-list")
|
|
|
+ @GetMapping("/list-by-return")
|
|
|
@Operation(summary = "获取所有可回退的节点", description = "用于【流程详情】的【回退】按钮")
|
|
|
@Parameter(name = "taskId", description = "当前任务ID", required = true)
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
- public CommonResult<List<BpmTaskSimpleRespVO>> getReturnList(@RequestParam("taskId") String taskId) {
|
|
|
- return success(taskService.getReturnTaskList(taskId));
|
|
|
+ public CommonResult<List<BpmTaskRespVO>> getTaskListByReturn(@RequestParam("id") String id) {
|
|
|
+ List<UserTask> userTaskList = taskService.getUserTaskListByReturn(id);
|
|
|
+ return success(convertList(userTaskList, userTask -> // 只返回 id 和 name
|
|
|
+ new BpmTaskRespVO().setName(userTask.getName()).setTaskDefinitionKey(userTask.getId())));
|
|
|
}
|
|
|
|
|
|
@PutMapping("/return")
|
|
@@ -91,17 +173,25 @@ public class BpmTaskController {
|
|
|
}
|
|
|
|
|
|
@PutMapping("/delegate")
|
|
|
- @Operation(summary = "委派任务", description = "用于【流程详情】的【委派】按钮。和向前【加签】有点像,唯一区别是【委托】没有单独创立任务")
|
|
|
+ @Operation(summary = "委派任务", description = "用于【流程详情】的【委派】按钮")
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
public CommonResult<Boolean> delegateTask(@Valid @RequestBody BpmTaskDelegateReqVO reqVO) {
|
|
|
taskService.delegateTask(getLoginUserId(), reqVO);
|
|
|
return success(true);
|
|
|
}
|
|
|
|
|
|
+ @PutMapping("/transfer")
|
|
|
+ @Operation(summary = "转派任务", description = "用于【流程详情】的【转派】按钮")
|
|
|
+ @PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
+ public CommonResult<Boolean> transferTask(@Valid @RequestBody BpmTaskTransferReqVO reqVO) {
|
|
|
+ taskService.transferTask(getLoginUserId(), reqVO);
|
|
|
+ return success(true);
|
|
|
+ }
|
|
|
+
|
|
|
@PutMapping("/create-sign")
|
|
|
@Operation(summary = "加签", description = "before 前加签,after 后加签")
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
- public CommonResult<Boolean> createSignTask(@Valid @RequestBody BpmTaskAddSignReqVO reqVO) {
|
|
|
+ public CommonResult<Boolean> createSignTask(@Valid @RequestBody BpmTaskSignCreateReqVO reqVO) {
|
|
|
taskService.createSignTask(getLoginUserId(), reqVO);
|
|
|
return success(true);
|
|
|
}
|
|
@@ -109,17 +199,26 @@ public class BpmTaskController {
|
|
|
@DeleteMapping("/delete-sign")
|
|
|
@Operation(summary = "减签")
|
|
|
@PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
- public CommonResult<Boolean> deleteSignTask(@Valid @RequestBody BpmTaskSubSignReqVO reqVO) {
|
|
|
+ public CommonResult<Boolean> deleteSignTask(@Valid @RequestBody BpmTaskSignDeleteReqVO reqVO) {
|
|
|
taskService.deleteSignTask(getLoginUserId(), reqVO);
|
|
|
return success(true);
|
|
|
}
|
|
|
|
|
|
- @GetMapping("children-list")
|
|
|
- @Operation(summary = "获取能被减签的任务")
|
|
|
- @Parameter(name = "parentId", description = "父级任务 ID", required = true)
|
|
|
- @PreAuthorize("@ss.hasPermission('bpm:task:update')")
|
|
|
- public CommonResult<List<BpmTaskSubSignRespVO>> getChildrenTaskList(@RequestParam("parentId") String parentId) {
|
|
|
- return success(taskService.getChildrenTaskList(parentId));
|
|
|
+ @GetMapping("/list-by-parent-task-id")
|
|
|
+ @Operation(summary = "获得指定父级任务的子任务列表") // 目前用于,减签的时候,获得子任务列表
|
|
|
+ @Parameter(name = "parentTaskId", description = "父级任务编号", required = true)
|
|
|
+ @PreAuthorize("@ss.hasPermission('bpm:task:query')")
|
|
|
+ public CommonResult<List<BpmTaskRespVO>> getTaskListByParentTaskId(@RequestParam("parentTaskId") String parentTaskId) {
|
|
|
+ List<Task> taskList = taskService.getTaskListByParentTaskId(parentTaskId);
|
|
|
+ if (CollUtil.isEmpty(taskList)) {
|
|
|
+ return success(Collections.emptyList());
|
|
|
+ }
|
|
|
+ // 拼接数据
|
|
|
+ Map<Long, AdminUserRespDTO> userMap = adminUserApi.getUserMap(convertSetByFlatMap(taskList,
|
|
|
+ user -> Stream.of(NumberUtils.parseLong(user.getAssignee()), NumberUtils.parseLong(user.getOwner()))));
|
|
|
+ Map<Long, DeptRespDTO> deptMap = deptApi.getDeptMap(
|
|
|
+ convertSet(userMap.values(), AdminUserRespDTO::getDeptId));
|
|
|
+ return success(BpmTaskConvert.INSTANCE.buildTaskListByParentTaskId(taskList, userMap, deptMap));
|
|
|
}
|
|
|
|
|
|
}
|