| | |
| | | .set(ProjectProcess::getProcessInsId, processInsId) |
| | | .set(ProjectProcess::getDataLaunch, project.getCreateBy()) |
| | | .update(); |
| | | |
| | | return Result.ok("流程变更成功"); |
| | | } |
| | | |
| | |
| | | SysUser sysUser = SecurityUtils.getLoginUser().getUser(); |
| | | identityService.setAuthenticatedUserId(sysUser.getUserId().toString()); |
| | | variables.put(ProcessConstants.PROCESS_INITIATOR, sysUser.getUserId()); |
| | | |
| | | //测试容缺 |
| | | variables.put("miss",true); |
| | | // 将该项目的申请人(业主方)作为流程中某些环节的处理人 |
| | | variables.put(ProcessConstants.DATA_LAUNCH, createBy); |
| | | variables.put(ProcessConstants.DATA_LAUNCH, "dept:" + createBy); |
| | | ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefId, projectId + "", variables); |
| | | return processInstance.getId(); |
| | | } |
| | |
| | | // 未开始的任务,其关联的用户组这些都可以从UserTask中拿到,因为本身未开始的任务是没有task的,所以这里直接查 |
| | | if (StringUtils.isNotBlank(userTask.getAssignee())) { |
| | | vo.setHandlerType(HandlerTypeEnum.USER); |
| | | // 处理变量表达式 |
| | | if (userTask.getAssignee().contains(ProcessConstants.DATA_LAUNCH)) { |
| | | this.varReview(vo, projectId, processInsId); |
| | | } else { |
| | | SysUser sysUser = sysUserService.selectUserById(Long.parseLong(userTask.getAssignee())); |
| | | if (Objects.nonNull(sysUser)) { |
| | | handlerIds.add(sysUser.getUserId()); |
| | | handlerNames.add(sysUser.getNickName()); |
| | | if (Objects.nonNull(sysUser.getDept())) { |
| | | handlerUnitIds.add(sysUser.getDept().getDeptId()); |
| | | handlerUnitNames.add(sysUser.getDept().getDeptName()); |
| | | } |
| | | SysUser sysUser = sysUserService.selectUserById(Long.parseLong(userTask.getAssignee())); |
| | | if (Objects.nonNull(sysUser)) { |
| | | handlerIds.add(sysUser.getUserId()); |
| | | handlerNames.add(sysUser.getNickName()); |
| | | if (Objects.nonNull(sysUser.getDept())) { |
| | | handlerUnitIds.add(sysUser.getDept().getDeptId()); |
| | | handlerUnitNames.add(sysUser.getDept().getDeptName()); |
| | | } |
| | | } |
| | | |
| | | } else if (CollectionUtil.isNotEmpty(userTask.getCandidateGroups())) { |
| | | List<String> groupIds = userTask.getCandidateGroups(); |
| | | for (String groupId : groupIds) { |
| | | if (groupId.startsWith("dept")) { // 部门的id是加了前缀的如:dept:1 |
| | | // 处理变量表达式,DATA_LAUNCH只可能是部门不会是角色,因为代表的是业主部门 |
| | | if (groupId.contains(ProcessConstants.DATA_LAUNCH)) { |
| | | vo.setHandlerType(HandlerTypeEnum.DEPT); |
| | | this.varYzReview(vo, projectId, processInsId, HandlerTypeEnum.DEPT); |
| | | } |
| | | else if (groupId.startsWith("dept")) { // 部门的id是加了前缀的如:dept:1 |
| | | vo.setHandlerType(HandlerTypeEnum.DEPT); |
| | | String[] split = groupId.split(":"); |
| | | if (split.length > 1) { |
| | |
| | | if (Objects.nonNull(dept)) { |
| | | handlerUnitIds.add(dept.getDeptId()); |
| | | handlerUnitNames.add(dept.getDeptName()); |
| | | |
| | | } |
| | | } |
| | | } else { |
| | |
| | | // 流程处理人信息 |
| | | List<IdentityLink> identityLinksForTask = taskService.getIdentityLinksForTask(task.getId()); |
| | | for (IdentityLinkInfo identityLink : identityLinksForTask) { |
| | | // if (StringUtils.isBlank(((IdentityLinkEntityImpl)identityLink).getId())) { |
| | | // continue; |
| | | // } |
| | | // 绑定的是用户,查出用户姓名、部门 |
| | | if (StringUtils.isNotBlank(identityLink.getUserId())) { |
| | | // 处理变量表达式 |
| | | if (identityLink.getUserId().contains(ProcessConstants.DATA_LAUNCH)) { |
| | | this.varReview(taskVO, projectId, task.getProcessInstanceId()); |
| | | continue; |
| | | } |
| | | // 处理变量表达式,运行中的任务无需再处理表达式了,flowable已经自动根据变量设置了 |
| | | // if (identityLink.getUserId().contains(ProcessConstants.DATA_LAUNCH)) { |
| | | // this.varReview(taskVO, projectId, task.getProcessInstanceId()); |
| | | // continue; |
| | | // } |
| | | taskVO.setHandlerType(HandlerTypeEnum.USER); |
| | | SysUser sysUser = sysUserService.selectUserById(Long.parseLong(identityLink.getUserId())); |
| | | if (Objects.nonNull(sysUser)) { |
| | |
| | | List<HistoricTaskInstance> hisTaskList = historyService.createHistoricTaskInstanceQuery() |
| | | .processInstanceId(processInsId) |
| | | .finished() |
| | | .includeIdentityLinks() |
| | | .list(); |
| | | hisTaskList = this.distinctHisTask(hisTaskList); |
| | | if (CollectionUtils.isEmpty(hisTaskList)) { |
| | | return 0L; |
| | | } |
| | |
| | | List<String> hisTaskKeys = hisTaskList.stream().map(HistoricTaskInstance::getTaskDefinitionKey).distinct().collect(Collectors.toList()); |
| | | Map<String, HistoricTaskInstance> hisTaskMap = hisTaskList.stream().collect(Collectors.toMap(HistoricTaskInstance::getTaskDefinitionKey, his -> his)); |
| | | // 查出时间正常的任务key |
| | | List<ProcessCoding> taskList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | List<ProcessCoding> codeList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | .eq(ProcessCoding::getProcessInsId, processInsId) |
| | | .in(ProcessCoding::getTaskDefKey, hisTaskKeys) |
| | | .list(); |
| | | Map<String, ProcessCoding> codingMap = taskList.stream().collect(Collectors.toMap(ProcessCoding::getTaskDefKey, pro -> pro)); |
| | | List<HistoricTaskInstance> finishedTaskList = new ArrayList<>(); |
| | | // 判断 |
| | | for (String key : hisTaskMap.keySet()) { |
| | | ProcessCoding processCoding = codingMap.get(key); |
| | | List<ProcessCoding> targetProcessCodings = codeList.stream().filter(code -> key.equals(code.getTaskDefKey())).collect(Collectors.toList()); |
| | | // 如果已完成的任务没从数据库查找出来,说明该任务没配置赋码等时间,直接设置为按时完成 |
| | | if (Objects.isNull(processCoding)) { |
| | | if (CollectionUtils.isEmpty(targetProcessCodings)) { |
| | | finishedTaskList.add(hisTaskMap.get(key)); |
| | | } else if (ProcessOverTimeConstants.NORMAL.equals(processCoding.getOvertimeStatus()) || StringUtils.isBlank(processCoding.getOvertimeStatus())) { |
| | | finishedTaskList.add(hisTaskMap.get(key)); |
| | | } else { |
| | | // 按照时间降序排列 |
| | | targetProcessCodings.sort(Comparator.comparing(ProcessCoding::getGmtCreate).reversed()); |
| | | ProcessCoding latestProjectProcess = targetProcessCodings.get(0); |
| | | if (ProcessOverTimeConstants.NORMAL.equals(latestProjectProcess.getOvertimeStatus()) || StringUtils.isBlank(latestProjectProcess.getOvertimeStatus())) { |
| | | finishedTaskList.add(hisTaskMap.get(key)); |
| | | } |
| | | } |
| | | } |
| | | return Long.valueOf(finishedTaskList.size()); |
| | |
| | | } |
| | | |
| | | List<String> hisTaskKeys = hisTaskList.stream().map(HistoricTaskInstance::getTaskDefinitionKey).distinct().collect(Collectors.toList()); |
| | | Map<String, HistoricTaskInstance> hisTaskMap = hisTaskList.stream().collect(Collectors.toMap(HistoricTaskInstance::getTaskDefinitionKey, his -> his)); |
| | | Map<String, HistoricTaskInstance> hisTaskMap = this.distinctHisTask(hisTaskList).stream().collect(Collectors.toMap(HistoricTaskInstance::getTaskDefinitionKey, his -> his)); |
| | | // 查出时间正常的任务key |
| | | List<ProcessCoding> taskList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | List<ProcessCoding> codeList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | .eq(ProcessCoding::getProcessInsId, processInsId) |
| | | .in(ProcessCoding::getTaskDefKey, hisTaskKeys) |
| | | .list(); |
| | | Map<String, ProcessCoding> codingMap = taskList.stream().collect(Collectors.toMap(ProcessCoding::getTaskDefKey, pro -> pro)); |
| | | List<HistoricTaskInstance> finishedTaskList = new ArrayList<>(); |
| | | // 判断 |
| | | for (String key : hisTaskMap.keySet()) { |
| | | ProcessCoding processCoding = codingMap.get(key); |
| | | List<ProcessCoding> targetProcessCodings = codeList.stream().filter(code -> key.equals(code.getTaskDefKey())).collect(Collectors.toList()); |
| | | // 如果已完成的任务没从数据库查找出来,说明该任务没配置赋码等时间,直接设置为按时完成 |
| | | if (Objects.isNull(processCoding)) { |
| | | if (CollectionUtils.isEmpty(targetProcessCodings)) { |
| | | finishedTaskList.add(hisTaskMap.get(key)); |
| | | } else if (ProcessOverTimeConstants.NORMAL.equals(processCoding.getOvertimeStatus()) || StringUtils.isBlank(processCoding.getOvertimeStatus())) { |
| | | finishedTaskList.add(hisTaskMap.get(key)); |
| | | } else { |
| | | // 按照时间降序排列 |
| | | targetProcessCodings.sort(Comparator.comparing(ProcessCoding::getGmtCreate).reversed()); |
| | | ProcessCoding latestProjectProcess = targetProcessCodings.get(0); |
| | | if (ProcessOverTimeConstants.NORMAL.equals(latestProjectProcess.getOvertimeStatus()) || StringUtils.isBlank(latestProjectProcess.getOvertimeStatus())) { |
| | | finishedTaskList.add(hisTaskMap.get(key)); |
| | | } |
| | | } |
| | | } |
| | | |
| | |
| | | return vos; |
| | | } |
| | | |
| | | /** |
| | | * 根据任务key去重历史任务,相同情况下取最新的一条 |
| | | * |
| | | * @param hisTaskList |
| | | * @return |
| | | */ |
| | | private List<HistoricTaskInstance> distinctHisTask(List<HistoricTaskInstance> hisTaskList) { |
| | | Map<String, HistoricTaskInstance> uniqueTasks = new HashMap<>(); |
| | | for (HistoricTaskInstance task : hisTaskList) { |
| | | String taskDefinitionKey = task.getTaskDefinitionKey(); |
| | | HistoricTaskInstance existingTask = uniqueTasks.get(taskDefinitionKey); |
| | | |
| | | // 如果任务key重复(可能被驳回过,重新提交导致key重复),取最近的一条 |
| | | if (existingTask == null || task.getCreateTime().after(existingTask.getCreateTime())) { |
| | | uniqueTasks.put(taskDefinitionKey, task); |
| | | } |
| | | } |
| | | // 最终去重后的任务列表 |
| | | return new ArrayList<>(uniqueTasks.values()); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 统计超时的任务数 |
| | |
| | | List<String> taskKeys = taskList.stream().map(Task::getTaskDefinitionKey).distinct().collect(Collectors.toList()); |
| | | Map<String, Task> taskMap = taskList.stream().collect(Collectors.toMap(Task::getTaskDefinitionKey, his -> his)); |
| | | // 查出数据库的任务key |
| | | List<ProcessCoding> databaseTaskList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | List<ProcessCoding> codeList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | .eq(ProcessCoding::getProcessInsId, processInsId) |
| | | .in(ProcessCoding::getTaskDefKey, taskKeys) |
| | | .list(); |
| | | Map<String, ProcessCoding> codingMap = databaseTaskList.stream().collect(Collectors.toMap(ProcessCoding::getTaskDefKey, pro -> pro)); |
| | | List<Task> tList = new ArrayList<>(); |
| | | // 判断 |
| | | for (String key : taskMap.keySet()) { |
| | | ProcessCoding processCoding = codingMap.get(key); |
| | | // 如果运行中的任务没从数据库查找出来,说明该任务没配置赋码等时间,不算超时 |
| | | if (Objects.nonNull(processCoding) && ProcessOverTimeConstants.OVERTIME.equals(processCoding.getOvertimeStatus())) { |
| | | List<ProcessCoding> targetProcessCodings = codeList.stream().filter(code -> key.equals(code.getTaskDefKey())).collect(Collectors.toList()); |
| | | // 如果已完成的任务没从数据库查找出来,说明该任务没配置赋码等时间,直接设置为按时完成 |
| | | if (CollectionUtils.isEmpty(targetProcessCodings)) { |
| | | tList.add(taskMap.get(key)); |
| | | } else { |
| | | // 按照时间降序排列 |
| | | targetProcessCodings.sort(Comparator.comparing(ProcessCoding::getGmtCreate).reversed()); |
| | | ProcessCoding latestProjectProcess = targetProcessCodings.get(0); |
| | | if (Objects.nonNull(latestProjectProcess) && ProcessOverTimeConstants.OVERTIME.equals(latestProjectProcess.getOvertimeStatus())) { |
| | | tList.add(taskMap.get(key)); |
| | | } |
| | | } |
| | | } |
| | | |
| | | return Long.valueOf(taskList.size()); |
| | | } |
| | | |
| | |
| | | List<String> taskKeys = taskList.stream().map(Task::getTaskDefinitionKey).distinct().collect(Collectors.toList()); |
| | | Map<String, Task> taskMap = taskList.stream().collect(Collectors.toMap(Task::getTaskDefinitionKey, his -> his)); |
| | | // 查出数据库的任务key |
| | | List<ProcessCoding> databaseTaskList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | List<ProcessCoding> codeList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | .eq(ProcessCoding::getProcessInsId, processInsId) |
| | | .in(ProcessCoding::getTaskDefKey, taskKeys) |
| | | .list(); |
| | | Map<String, ProcessCoding> codingMap = databaseTaskList.stream().collect(Collectors.toMap(ProcessCoding::getTaskDefKey, pro -> pro)); |
| | | List<Task> tList = new ArrayList<>(); |
| | | // 判断 |
| | | for (String key : taskMap.keySet()) { |
| | | ProcessCoding processCoding = codingMap.get(key); |
| | | // 如果运行中的任务没从数据库查找出来,说明该任务没配置赋码等时间,不算超时 |
| | | if (Objects.nonNull(processCoding) && ProcessOverTimeConstants.OVERTIME.equals(processCoding.getOvertimeStatus())) { |
| | | List<ProcessCoding> targetProcessCodings = codeList.stream().filter(code -> key.equals(code.getTaskDefKey())).collect(Collectors.toList()); |
| | | // 如果已完成的任务没从数据库查找出来,说明该任务没配置赋码等时间,直接设置为按时完成 |
| | | if (CollectionUtils.isEmpty(targetProcessCodings)) { |
| | | tList.add(taskMap.get(key)); |
| | | } else { |
| | | // 按照时间降序排列 |
| | | targetProcessCodings.sort(Comparator.comparing(ProcessCoding::getGmtCreate).reversed()); |
| | | ProcessCoding latestProjectProcess = targetProcessCodings.get(0); |
| | | if (Objects.nonNull(latestProjectProcess) && ProcessOverTimeConstants.OVERTIME.equals(latestProjectProcess.getOvertimeStatus())) { |
| | | tList.add(taskMap.get(key)); |
| | | } |
| | | } |
| | | } |
| | | |
| | |
| | | List<String> taskKeys = taskList.stream().map(Task::getTaskDefinitionKey).distinct().collect(Collectors.toList()); |
| | | Map<String, Task> taskMap = taskList.stream().collect(Collectors.toMap(Task::getTaskDefinitionKey, his -> his)); |
| | | // 查出数据库的任务key |
| | | List<ProcessCoding> databaseTaskList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | List<ProcessCoding> codeList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | .eq(ProcessCoding::getProcessInsId, processInsId) |
| | | .in(ProcessCoding::getTaskDefKey, taskKeys) |
| | | .list(); |
| | | Map<String, ProcessCoding> codingMap = databaseTaskList.stream().collect(Collectors.toMap(ProcessCoding::getTaskDefKey, pro -> pro)); |
| | | List<Task> tList = new ArrayList<>(); |
| | | // 判断 |
| | | for (String key : taskMap.keySet()) { |
| | | ProcessCoding processCoding = codingMap.get(key); |
| | | // 如果运行中的任务没从数据库查找出来,说明该任务没配置赋码等时间,不算即将超时 |
| | | if (Objects.nonNull(processCoding) && ProcessOverTimeConstants.WILLOVERTIME.equals(processCoding.getOvertimeStatus())) { |
| | | List<ProcessCoding> targetProcessCodings = codeList.stream().filter(code -> key.equals(code.getTaskDefKey())).collect(Collectors.toList()); |
| | | // 如果已完成的任务没从数据库查找出来,说明该任务没配置赋码等时间,直接设置为按时完成 |
| | | if (CollectionUtils.isEmpty(targetProcessCodings)) { |
| | | tList.add(taskMap.get(key)); |
| | | } else { |
| | | // 按照时间降序排列 |
| | | targetProcessCodings.sort(Comparator.comparing(ProcessCoding::getGmtCreate).reversed()); |
| | | ProcessCoding latestProjectProcess = targetProcessCodings.get(0); |
| | | if (Objects.nonNull(latestProjectProcess) && ProcessOverTimeConstants.WILLOVERTIME.equals(latestProjectProcess.getOvertimeStatus())) { |
| | | tList.add(taskMap.get(key)); |
| | | } |
| | | } |
| | | } |
| | | return Long.valueOf(tList.size()); |
| | |
| | | List<String> taskKeys = taskList.stream().map(Task::getTaskDefinitionKey).distinct().collect(Collectors.toList()); |
| | | Map<String, Task> taskMap = taskList.stream().collect(Collectors.toMap(Task::getTaskDefinitionKey, his -> his)); |
| | | // 查出数据库的任务key |
| | | List<ProcessCoding> databaseTaskList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | List<ProcessCoding> codeList = new LambdaQueryChainWrapper<>(processCodingService.getBaseMapper()) |
| | | .eq(ProcessCoding::getProcessInsId, processInsId) |
| | | .in(ProcessCoding::getTaskDefKey, taskKeys) |
| | | .list(); |
| | | Map<String, ProcessCoding> codingMap = databaseTaskList.stream().collect(Collectors.toMap(ProcessCoding::getTaskDefKey, pro -> pro)); |
| | | List<Task> tList = new ArrayList<>(); |
| | | // 判断 |
| | | for (String key : taskMap.keySet()) { |
| | | ProcessCoding processCoding = codingMap.get(key); |
| | | // 如果运行中的任务没从数据库查找出来,说明该任务没配置赋码等时间,不算即将超时 |
| | | if (Objects.nonNull(processCoding) && ProcessOverTimeConstants.WILLOVERTIME.equals(processCoding.getOvertimeStatus())) { |
| | | List<ProcessCoding> targetProcessCodings = codeList.stream().filter(code -> key.equals(code.getTaskDefKey())).collect(Collectors.toList()); |
| | | // 如果已完成的任务没从数据库查找出来,说明该任务没配置赋码等时间,直接设置为按时完成 |
| | | if (CollectionUtils.isEmpty(targetProcessCodings)) { |
| | | tList.add(taskMap.get(key)); |
| | | } else { |
| | | // 按照时间降序排列 |
| | | targetProcessCodings.sort(Comparator.comparing(ProcessCoding::getGmtCreate).reversed()); |
| | | ProcessCoding latestProjectProcess = targetProcessCodings.get(0); |
| | | if (Objects.nonNull(latestProjectProcess) && ProcessOverTimeConstants.WILLOVERTIME.equals(latestProjectProcess.getOvertimeStatus())) { |
| | | tList.add(taskMap.get(key)); |
| | | } |
| | | } |
| | | } |
| | | |
| | |
| | | // 未开始的任务,其关联的用户组这些都可以从UserTask中拿到,因为本身未开始的任务是没有task的,所以这里直接查 |
| | | if (StringUtils.isNotBlank(userTask.getAssignee())) { |
| | | vo.setHandlerType(HandlerTypeEnum.USER); |
| | | |
| | | // 处理变量表达式 |
| | | if (userTask.getAssignee().contains(ProcessConstants.DATA_LAUNCH)) { |
| | | this.varReview(vo, projectId, processInsId); |
| | | vos.add(vo); |
| | | continue; |
| | | } |
| | | SysUser sysUser = sysUserService.selectUserById(Long.parseLong(userTask.getAssignee())); |
| | | if (Objects.nonNull(sysUser)) { |
| | | vo.getHandlerId().add(sysUser.getUserId()); |
| | |
| | | } else if (CollectionUtil.isNotEmpty(userTask.getCandidateGroups())) { |
| | | List<String> groupIds = userTask.getCandidateGroups(); |
| | | for (String groupId : groupIds) { |
| | | if (groupId.startsWith("dept")) { // 部门的id是加了前缀的如:dept:1 |
| | | // 处理变量表达式,DATA_LAUNCH只可能是部门不会是角色,因为代表的是业主部门 |
| | | if (groupId.contains(ProcessConstants.DATA_LAUNCH)) { |
| | | vo.setHandlerType(HandlerTypeEnum.DEPT); |
| | | this.varYzReview(vo, projectId, processInsId, HandlerTypeEnum.DEPT); |
| | | } |
| | | else if (groupId.startsWith("dept")) { // 部门的id是加了前缀的如:dept:1 |
| | | vo.setHandlerType(HandlerTypeEnum.DEPT); |
| | | String[] split = groupId.split(":"); |
| | | if (split.length > 1) { |
| | |
| | | } |
| | | |
| | | /** |
| | | * 处理流程变量的处理人回显 |
| | | * 处理流程变量-业主单位 |
| | | * |
| | | * @param vo |
| | | */ |
| | | private void varReview(CustomerTaskVO vo, Long projectId, String processInsId) { |
| | | private void varYzReview(CustomerTaskVO vo, Long projectId, String processInsId, HandlerTypeEnum type) { |
| | | ProjectProcess projectProcess = new LambdaQueryChainWrapper<>(projectProcessMapper) |
| | | .eq(ProjectProcess::getProjectId, projectId) |
| | | .eq(ProjectProcess::getProcessInsId, processInsId) |
| | |
| | | if (Objects.isNull(projectProcess)) { |
| | | throw new RuntimeException("该流程未绑定项目"); |
| | | } |
| | | SysUser user = sysUserService.selectUserById(projectProcess.getDataLaunch()); |
| | | if (Objects.nonNull(user) && Objects.nonNull(user.getDept())) { |
| | | vo.getHandlerName().add(user.getDept().getDeptName()); |
| | | vo.getHandlerId().add(user.getDept().getDeptId()); |
| | | if (HandlerTypeEnum.USER.equals(type) || HandlerTypeEnum.FIX_USER.equals(type)) { |
| | | SysUser user = sysUserService.selectUserById(projectProcess.getDataLaunch()); |
| | | if (Objects.nonNull(user) && Objects.nonNull(user.getDept())) { |
| | | vo.getHandlerName().add(user.getNickName()); |
| | | vo.getHandlerId().add(user.getUserId()); |
| | | } |
| | | } else if (HandlerTypeEnum.DEPT.equals(type)) { |
| | | SysDept dept = deptService.selectDeptById(projectProcess.getDataLaunch()); |
| | | if (Objects.nonNull(dept)) { |
| | | vo.getHandlerUnitId().add(dept.getDeptId()); |
| | | vo.getHandlerUnitName().add(dept.getDeptName()); |
| | | } |
| | | } else if (HandlerTypeEnum.ROLE.equals(type)) { |
| | | SysRole role = sysRoleService.selectRoleById(projectProcess.getDataLaunch()); |
| | | if (Objects.nonNull(role)) { |
| | | vo.getHandlerUnitId().add(role.getRoleId()); |
| | | vo.getHandlerUnitName().add(role.getRoleName()); |
| | | } |
| | | } |
| | | |
| | | this.distinctVo(vo); |
| | | } |
| | | |