From 2ba6d57e221fda12c8198444324cfa517dc3d5dc Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期三, 17 九月 2025 14:36:57 +0800 Subject: [PATCH] 将创建待办事项抽取为公共方法 --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java | 133 ------------------ ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java | 127 +----------------- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalTodoServiceImpl.java | 142 ++++++++++++++++++++ ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalTodoService.java | 11 + 4 files changed, 161 insertions(+), 252 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalTodoService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalTodoService.java index a30c303..5b7f46d 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalTodoService.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/OaApprovalTodoService.java @@ -1,6 +1,7 @@ package com.ruoyi.system.service; import com.baomidou.mybatisplus.extension.service.IService; +import com.ruoyi.system.model.OaApprovalFlowNode; import com.ruoyi.system.model.OaApprovalTodo; /** @@ -12,5 +13,13 @@ * @since 2025-09-15 */ public interface OaApprovalTodoService extends IService<OaApprovalTodo> { - + /** + * 根据流程节点与部门信息,创建对应审批待办 + * + * @param applicationId 申请主表ID + * @param applicationCode 申请单号 + * @param flowNode 当前流程节点配置 + * @param deptId 申请部门ID(用于上级部门审批场景) + */ + void createApprovalTodos(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId); } diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java index 7d16f94..7d928d4 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java @@ -1,9 +1,6 @@ package com.ruoyi.system.service.impl; -import cn.hutool.core.collection.CollUtil; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.ruoyi.common.core.domain.entity.SysDept; -import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.system.dto.asset.OaApprovalApplicationPurchaseDTO; import com.ruoyi.system.emums.ApprovalStatusEnum; @@ -12,7 +9,6 @@ import com.ruoyi.system.model.OaApprovalApplicationPurchaseItem; import com.ruoyi.system.model.OaApprovalApplications; import com.ruoyi.system.model.OaApprovalFlowNode; -import com.ruoyi.system.model.OaApprovalTodo; import com.ruoyi.system.service.ISysDeptService; import com.ruoyi.system.service.ISysUserService; import com.ruoyi.system.service.OaApprovalApplicationPurchaseItemService; @@ -21,17 +17,13 @@ import com.ruoyi.system.service.OaApprovalFlowNodeService; import com.ruoyi.system.service.OaApprovalTodoService; import lombok.RequiredArgsConstructor; -import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; import java.time.LocalDate; -import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; -import java.util.Arrays; import java.util.List; -import java.util.stream.Collectors; /** * <p> @@ -63,8 +55,8 @@ applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); - // 3.创建待办事项记录 - createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); + // 3. 创建待办事项记录(公共服务) + oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4.保存采购资产明细数据 List<OaApprovalApplicationPurchaseItem> items = buildOaApprovalApplicationPurchaseItems(dto, applications.getId()); @@ -93,127 +85,6 @@ return flowNodes.get(0); } - /** - * 创建待办数据 - */ - private void createApprovalTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) { - // 根据审批类型创建待办数据 - Integer approvalType = flowNode.getApprovalType(); - if (approvalType == null) { - throw new ServiceException("审批类型不能为空"); - } - - switch (approvalType) { - case 0: // 上级部门审批 - createUpperDeptTodo(applicationId, applicationCode, flowNode, deptId); - break; - case 1: // 指定部门审批 - createSpecifiedDeptTodo(applicationId, applicationCode, flowNode); - break; - case 2: // 指定人员审批 - createSpecifiedUserTodo(applicationId, applicationCode, flowNode); - break; - default: - throw new ServiceException("不支持的审批类型: " + approvalType); - } - } - /** - * 创建上级部门审批待办 - */ - private void createUpperDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) { - // 1. 获取申请部门信息 - if (deptId == null) { - throw new ServiceException("未填写申请部门信息"); - } - - SysDept currentDept = sysDeptService.selectDeptById(Long.valueOf(deptId)); - if (currentDept == null) { - throw new ServiceException("申请部门信息不存在"); - } - - // 2. 获取上级部门信息 - if (currentDept.getParentId() == null || currentDept.getParentId() == 0) { - throw new ServiceException("当前部门没有上级部门"); - } - - SysDept parentDept = sysDeptService.selectDeptById(currentDept.getParentId()); - if (parentDept == null) { - throw new ServiceException("上级部门信息不存在"); - } - - // 3. 查询所有关联了该上级部门的用户 - List<SysUser> users = sysUserService.selectListByDeptId(parentDept.getDeptId().toString()); - if (CollUtil.isEmpty(users)) { - throw new ServiceException("上级部门下没有找到用户"); - } - - // 4. 为每个用户创建待办数据 - createTodoItem(applicationId, applicationCode, flowNode, users); - } - - /** - * 创建指定部门审批待办 - */ - private void createSpecifiedDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) { - if (StringUtils.isBlank(flowNode.getApprovalIds())) { - throw new ServiceException("操作失败,审批流程配置异常"); - } - // 收集部门ID - List<String> deptIdList = Arrays.stream(flowNode.getApprovalIds().split(",")).collect(Collectors.toList()); - - // 查询所有关联了这些部门的用户 - List<SysUser> users = sysUserService.selectListByDeptIds(deptIdList); - if (CollUtil.isEmpty(users)) { - throw new ServiceException("指定部门下没有找到用户"); - } - - // 为每个用户创建待办数据 - createTodoItem(applicationId, applicationCode, flowNode, users); - } - - /** - * 创建指定人员审批待办 - */ - private void createSpecifiedUserTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) { - if (StringUtils.isBlank(flowNode.getApprovalIds())) { - throw new ServiceException("操作失败,审批流程配置异常"); - } - List<Integer> userIds = Arrays.stream(flowNode.getApprovalIds().split(",")) - .map(Integer::valueOf).collect(Collectors.toList()); - // 1. 查询用户信息 - List<SysUser> users = sysUserService.selectListByUserIds(userIds); - if (CollUtil.isEmpty(users)) { - throw new ServiceException("没有找到指定审批用户"); - } - //2. 创建待办数据 - createTodoItem(applicationId, applicationCode, flowNode, users); - } - - /** - * 创建待办数据项 - */ - private void createTodoItem(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, List<SysUser> userList) { - List<OaApprovalTodo> approvalTodoList = userList.stream().map(item -> { - OaApprovalTodo todo = new OaApprovalTodo(); - todo.setApplicationId(applicationId); - todo.setApplicationCode(applicationCode); - todo.setFlowNodeId(flowNode.getId()); - todo.setUserId(item.getUserId().intValue()); - todo.setUserName(item.getNickName()); - - // 设置部门信息 - if (item.getDeptId() != null) { - todo.setDeptId(Integer.valueOf(item.getDeptId())); - } - - todo.setSortOrder(flowNode.getSortOrder()); - todo.setStatus(0); // 0-待处理 - todo.setCreateTime(LocalDateTime.now()); - return todo; - }).collect(Collectors.toList()); - //批量保存 - oaApprovalTodoService.saveBatch(approvalTodoList); - } /** * 构建审批申请主表数据 */ diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java index 1e91e6b..a043153 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java @@ -63,8 +63,8 @@ applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); - // 3. 创建待办事项记录 - createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); + // 3. 创建待办事项记录(公共服务) + oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4. 保存资产入库申请明细数据 OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId()); @@ -85,8 +85,8 @@ applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); - // 3. 创建待办事项记录 - createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); + // 3. 创建待办事项记录(公共服务) + oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4. 保存资产入库申请明细数据 OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId()); @@ -107,8 +107,8 @@ applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); - // 3. 创建待办事项记录 - createApprovalTodo(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); + // 3. 创建待办事项记录(公共服务) + oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4. 保存资产入库申请明细数据 OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId()); @@ -400,119 +400,6 @@ return flowNodes.get(0); } - /** - * 创建待办数据 - */ - private void createApprovalTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) { - Integer approvalType = flowNode.getApprovalType(); - if (approvalType == null) { - throw new ServiceException("审批类型不能为空"); - } - - switch (approvalType) { - case 0: - createUpperDeptTodo(applicationId, applicationCode, flowNode, deptId); - break; - case 1: - createSpecifiedDeptTodo(applicationId, applicationCode, flowNode); - break; - case 2: - createSpecifiedUserTodo(applicationId, applicationCode, flowNode); - break; - default: - throw new ServiceException("不支持的审批类型: " + approvalType); - } - } - - /** - * 创建上级部门审批待办 - */ - private void createUpperDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) { - if (deptId == null) { - throw new ServiceException("未填写申请部门信息"); - } - - SysDept currentDept = sysDeptService.selectDeptById(Long.valueOf(deptId)); - if (currentDept == null) { - throw new ServiceException("申请部门信息不存在"); - } - - if (currentDept.getParentId() == null || currentDept.getParentId() == 0) { - throw new ServiceException("当前部门没有上级部门"); - } - - SysDept parentDept = sysDeptService.selectDeptById(currentDept.getParentId()); - if (parentDept == null) { - throw new ServiceException("上级部门信息不存在"); - } - - List<SysUser> users = sysUserService.selectListByDeptId(parentDept.getDeptId().toString()); - if (CollUtil.isEmpty(users)) { - throw new ServiceException("上级部门下没有找到用户"); - } - - createTodoItem(applicationId, applicationCode, flowNode, users); - } - - /** - * 创建指定部门审批待办 - */ - private void createSpecifiedDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) { - if (StringUtils.isBlank(flowNode.getApprovalIds())) { - throw new ServiceException("操作失败,审批流程配置异常"); - } - - List<String> deptIdList = Arrays.stream(flowNode.getApprovalIds().split(",")).collect(Collectors.toList()); - List<SysUser> users = sysUserService.selectListByDeptIds(deptIdList); - if (CollUtil.isEmpty(users)) { - throw new ServiceException("指定部门下没有找到用户"); - } - - createTodoItem(applicationId, applicationCode, flowNode, users); - } - - /** - * 创建指定人员审批待办 - */ - private void createSpecifiedUserTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) { - if (StringUtils.isBlank(flowNode.getApprovalIds())) { - throw new ServiceException("操作失败,审批流程配置异常"); - } - - List<Integer> userIds = Arrays.stream(flowNode.getApprovalIds().split(",")) - .map(Integer::valueOf).collect(Collectors.toList()); - List<SysUser> users = sysUserService.selectListByUserIds(userIds); - if (CollUtil.isEmpty(users)) { - throw new ServiceException("没有找到指定审批用户"); - } - - createTodoItem(applicationId, applicationCode, flowNode, users); - } - - /** - * 创建待办数据项 - */ - private void createTodoItem(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, List<SysUser> userList) { - List<OaApprovalTodo> approvalTodoList = userList.stream().map(item -> { - OaApprovalTodo todo = new OaApprovalTodo(); - todo.setApplicationId(applicationId); - todo.setApplicationCode(applicationCode); - todo.setFlowNodeId(flowNode.getId()); - todo.setUserId(item.getUserId().intValue()); - todo.setUserName(item.getNickName()); - - if (item.getDeptId() != null) { - todo.setDeptId(Integer.valueOf(item.getDeptId())); - } - - todo.setSortOrder(flowNode.getSortOrder()); - todo.setStatus(0); - todo.setCreateTime(LocalDateTime.now()); - return todo; - }).collect(Collectors.toList()); - - oaApprovalTodoService.saveBatch(approvalTodoList); - } /** * 构建审批申请主表数据 @@ -630,4 +517,4 @@ return prefix + sequenceStr; } -} \ No newline at end of file +} diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalTodoServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalTodoServiceImpl.java index 8b40616..503c9d6 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalTodoServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalTodoServiceImpl.java @@ -1,10 +1,25 @@ package com.ruoyi.system.service.impl; +import cn.hutool.core.collection.CollUtil; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.common.core.domain.entity.SysDept; +import com.ruoyi.common.core.domain.entity.SysUser; +import com.ruoyi.common.exception.ServiceException; import com.ruoyi.system.mapper.OaApprovalTodoMapper; +import com.ruoyi.system.model.OaApprovalFlowNode; import com.ruoyi.system.model.OaApprovalTodo; +import com.ruoyi.system.service.ISysDeptService; +import com.ruoyi.system.service.ISysUserService; import com.ruoyi.system.service.OaApprovalTodoService; +import lombok.RequiredArgsConstructor; +import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import java.time.LocalDateTime; +import java.util.Arrays; +import java.util.List; +import java.util.stream.Collectors; /** * <p> @@ -15,6 +30,133 @@ * @since 2025-09-15 */ @Service +@RequiredArgsConstructor public class OaApprovalTodoServiceImpl extends ServiceImpl<OaApprovalTodoMapper, OaApprovalTodo> implements OaApprovalTodoService { + private final ISysUserService sysUserService; + private final ISysDeptService sysDeptService; + + /** + * 创建审批待办(公共实现) + */ + @Override + @Transactional(rollbackFor = Exception.class) + public void createApprovalTodos(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) { + Integer approvalType = flowNode.getApprovalType(); + if (approvalType == null) { + throw new ServiceException("审批类型不能为空"); + } + + switch (approvalType) { + case 0: // 上级部门审批 + createUpperDeptTodo(applicationId, applicationCode, flowNode, deptId); + break; + case 1: // 指定部门审批 + createSpecifiedDeptTodo(applicationId, applicationCode, flowNode); + break; + case 2: // 指定人员审批 + createSpecifiedUserTodo(applicationId, applicationCode, flowNode); + break; + default: + throw new ServiceException("不支持的审批类型: " + approvalType); + } + } + + /** + * 创建上级部门审批待办 + */ + private void createUpperDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, Integer deptId) { + // 1. 获取申请部门信息 + if (deptId == null) { + throw new ServiceException("未填写申请部门信息"); + } + + SysDept currentDept = sysDeptService.selectDeptById(Long.valueOf(deptId)); + if (currentDept == null) { + throw new ServiceException("申请部门信息不存在"); + } + + // 2. 获取上级部门信息 + if (currentDept.getParentId() == null || currentDept.getParentId() == 0) { + throw new ServiceException("当前部门没有上级部门"); + } + + SysDept parentDept = sysDeptService.selectDeptById(currentDept.getParentId()); + if (parentDept == null) { + throw new ServiceException("上级部门信息不存在"); + } + + // 3. 查询所有关联了该上级部门的用户 + List<SysUser> users = sysUserService.selectListByDeptId(parentDept.getDeptId().toString()); + if (CollUtil.isEmpty(users)) { + throw new ServiceException("上级部门下没有找到用户"); + } + + // 4. 为每个用户创建待办数据 + createTodoItem(applicationId, applicationCode, flowNode, users); + } + + /** + * 创建指定部门审批待办 + */ + private void createSpecifiedDeptTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) { + if (StringUtils.isBlank(flowNode.getApprovalIds())) { + throw new ServiceException("操作失败,审批流程配置异常"); + } + // 收集部门ID + List<String> deptIdList = Arrays.stream(flowNode.getApprovalIds().split(",")).collect(Collectors.toList()); + + // 查询所有关联了这些部门的用户 + List<SysUser> users = sysUserService.selectListByDeptIds(deptIdList); + if (CollUtil.isEmpty(users)) { + throw new ServiceException("指定部门下没有找到用户"); + } + + // 为每个用户创建待办数据 + createTodoItem(applicationId, applicationCode, flowNode, users); + } + + /** + * 创建指定人员审批待办 + */ + private void createSpecifiedUserTodo(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode) { + if (StringUtils.isBlank(flowNode.getApprovalIds())) { + throw new ServiceException("操作失败,审批流程配置异常"); + } + List<Integer> userIds = Arrays.stream(flowNode.getApprovalIds().split(",")) + .map(Integer::valueOf).collect(Collectors.toList()); + // 1. 查询用户信息 + List<SysUser> users = sysUserService.selectListByUserIds(userIds); + if (CollUtil.isEmpty(users)) { + throw new ServiceException("没有找到指定审批用户"); + } + //2. 创建待办数据 + createTodoItem(applicationId, applicationCode, flowNode, users); + } + + /** + * 创建待办数据项 + */ + private void createTodoItem(Integer applicationId, String applicationCode, OaApprovalFlowNode flowNode, List<SysUser> userList) { + List<OaApprovalTodo> approvalTodoList = userList.stream().map(item -> { + OaApprovalTodo todo = new OaApprovalTodo(); + todo.setApplicationId(applicationId); + todo.setApplicationCode(applicationCode); + todo.setFlowNodeId(flowNode.getId()); + todo.setUserId(item.getUserId().intValue()); + todo.setUserName(item.getNickName()); + + // 设置部门信息 + if (item.getDeptId() != null) { + todo.setDeptId(Integer.valueOf(item.getDeptId())); + } + + todo.setSortOrder(flowNode.getSortOrder()); + todo.setStatus(0); // 0-待处理 + todo.setCreateTime(LocalDateTime.now()); + return todo; + }).collect(Collectors.toList()); + //批量保存 + this.saveBatch(approvalTodoList); + } } -- Gitblit v1.7.1