|
|
@@ -2,6 +2,9 @@ package cn.iocoder.yudao.module.bpm.service.oa.universal;
|
|
|
|
|
|
import cn.hutool.core.collection.CollectionUtil;
|
|
|
import cn.hutool.core.util.IdUtil;
|
|
|
+import cn.hutool.core.util.StrUtil;
|
|
|
+import cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil;
|
|
|
+import cn.iocoder.yudao.framework.common.pojo.PageParam;
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
|
|
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
|
|
|
@@ -16,11 +19,16 @@ import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.task.BpmTaskReturnRe
|
|
|
import cn.iocoder.yudao.module.bpm.dal.dataobject.oa.universal.OaUniversalDO;
|
|
|
import cn.iocoder.yudao.module.bpm.dal.mysql.oa.universal.OaUniversalMapper;
|
|
|
import cn.iocoder.yudao.module.bpm.enums.DictDataConstants;
|
|
|
+import cn.iocoder.yudao.module.bpm.enums.ErrorCodeConstants;
|
|
|
+import cn.iocoder.yudao.module.bpm.framework.flowable.core.enums.BpmConstants;
|
|
|
import cn.iocoder.yudao.module.bpm.service.task.BpmTaskService;
|
|
|
import cn.iocoder.yudao.module.infra.api.file.FileApi;
|
|
|
import cn.iocoder.yudao.module.infra.api.file.dto.FileDTO;
|
|
|
+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 com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import org.apache.commons.lang3.StringUtils;
|
|
|
import org.flowable.engine.TaskService;
|
|
|
@@ -69,15 +77,18 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
@Resource
|
|
|
private AdminUserApi adminUserApi;
|
|
|
|
|
|
+ @Resource
|
|
|
+ private DeptApi deptApi;
|
|
|
+
|
|
|
@Override
|
|
|
- public Long commitOaUniversal(OaUniversalSaveReqVO createReqVO) {
|
|
|
+ public Long commitOaUniversal(OaUniversalSaveReqVO commitReqVO) {
|
|
|
// 登录人信息
|
|
|
Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
AdminUserRespDTO loginUser = adminUserApi.getUser(loginUserId);
|
|
|
Objects.requireNonNull(loginUser, "登录用户不能为空");
|
|
|
// TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- OaUniversalDO oaUniversal = BeanUtils.toBean(createReqVO, OaUniversalDO.class);
|
|
|
+ OaUniversalDO oaUniversal = BeanUtils.toBean(commitReqVO, OaUniversalDO.class);
|
|
|
if (StringUtils.isBlank(oaUniversal.getUniversalId())) {
|
|
|
// 创建单据uuid
|
|
|
String uuid = IdUtil.fastSimpleUUID();
|
|
|
@@ -99,10 +110,10 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
}
|
|
|
// 发起流程
|
|
|
Map<String, Object> processInstanceVariables = new HashMap<>();
|
|
|
- processInstanceVariables.put("auditPass", true);
|
|
|
+ processInstanceVariables.put("auditPass", "true");
|
|
|
// 添加审批人信息
|
|
|
Map<String, List<Long>> startUserSelectAssignees = new HashMap<>();
|
|
|
- List<Long> selectAssignees = createReqVO.getStartUserSelectAssignees();
|
|
|
+ List<Long> selectAssignees = commitReqVO.getStartUserSelectAssignees();
|
|
|
startUserSelectAssignees.put("approver", selectAssignees);
|
|
|
String processInstanceId = processInstanceApi
|
|
|
.createProcessInstance(loginUser.getId(),
|
|
|
@@ -118,25 +129,25 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
oaUniversalMapper.updateById(new OaUniversalDO()
|
|
|
.setId(oaUniversal.getId())
|
|
|
.setProcInstId(processInstanceId)
|
|
|
- .setAuditStatus(DictDataConstants.OA_AUDIT_STATUS_SUBMITTED)
|
|
|
+ .setAuditStatus(DictDataConstants.OA_AUDIT_STATUS_COMMITTED)
|
|
|
.setFinalAuditDate(LocalDateTime.now())
|
|
|
.setCurrentAuditEmployeeId(Long.valueOf(task.getAssignee()))
|
|
|
.setStartUserSelectAssignees(selectAssignees.stream().map(String::valueOf).collect(Collectors.joining(","))));
|
|
|
// 保存业务uuid到附件中
|
|
|
- saveFileList(createReqVO.getFileIdList(), oaUniversal.getUniversalId());
|
|
|
+ saveFileList(commitReqVO.getFileIdList(), oaUniversal.getUniversalId());
|
|
|
// TODO DP 发送提交成功站内信
|
|
|
return oaUniversal.getId();
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public Long stagingOaUniversal(OaUniversalSaveReqVO createReqVO) {
|
|
|
+ public Long stagingOaUniversal(OaUniversalSaveReqVO stagingReqVO) {
|
|
|
// 登录人信息
|
|
|
Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
AdminUserRespDTO loginUser = adminUserApi.getUser(loginUserId);
|
|
|
Objects.requireNonNull(loginUser, "登录用户不能为空");
|
|
|
// TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- OaUniversalDO oaUniversal = BeanUtils.toBean(createReqVO, OaUniversalDO.class);
|
|
|
+ OaUniversalDO oaUniversal = BeanUtils.toBean(stagingReqVO, OaUniversalDO.class);
|
|
|
if (StringUtils.isBlank(oaUniversal.getUniversalId())) {
|
|
|
// 创建单据uuid
|
|
|
String uuid = IdUtil.fastSimpleUUID();
|
|
|
@@ -158,21 +169,21 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
oaUniversalMapper.updateById(oaUniversal);
|
|
|
}
|
|
|
// 保存业务uuid到附件中
|
|
|
- saveFileList(createReqVO.getFileIdList(), oaUniversal.getUniversalId());
|
|
|
+ saveFileList(stagingReqVO.getFileIdList(), oaUniversal.getUniversalId());
|
|
|
|
|
|
return oaUniversal.getId();
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public Long agreeOaUniversal(BpmTaskApproveReqVO approveReqVO) {
|
|
|
+ public Long agreeOaUniversal(BpmTaskApproveReqVO agreeReqVO) {
|
|
|
// 登录人信息
|
|
|
Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
// TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- Task currentTask = bpmTaskService.getTask(approveReqVO.getId());
|
|
|
+ Task currentTask = bpmTaskService.getTask(agreeReqVO.getId());
|
|
|
// 审批同意
|
|
|
- approveReqVO.setReason("[同意]" + approveReqVO.getReason());
|
|
|
- bpmTaskService.approveTask(loginUserId, approveReqVO);
|
|
|
+ agreeReqVO.setReason("[同意]" + agreeReqVO.getReason());
|
|
|
+ bpmTaskService.approveTask(loginUserId, agreeReqVO);
|
|
|
|
|
|
Task nextTask = taskService.createTaskQuery().processInstanceId(currentTask.getProcessInstanceId()).singleResult();
|
|
|
if (nextTask != null) {
|
|
|
@@ -197,16 +208,16 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public Long disagreeOaUniversal(BpmTaskReturnReqVO returnReqVO) {
|
|
|
+ public Long disagreeOaUniversal(BpmTaskReturnReqVO disagreeReqVO) {
|
|
|
// 登录人信息
|
|
|
Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
// TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- Task currentTask = bpmTaskService.getTask(returnReqVO.getId());
|
|
|
+ Task currentTask = bpmTaskService.getTask(disagreeReqVO.getId());
|
|
|
|
|
|
- returnReqVO.setTargetTaskDefinitionKey("modifyApply");
|
|
|
- returnReqVO.setReason("[驳回]" + returnReqVO.getReason());
|
|
|
- bpmTaskService.returnTask(loginUserId, returnReqVO);
|
|
|
+ disagreeReqVO.setTargetTaskDefinitionKey("modifyApply");
|
|
|
+ disagreeReqVO.setReason("[驳回]" + disagreeReqVO.getReason());
|
|
|
+ bpmTaskService.returnTask(loginUserId, disagreeReqVO);
|
|
|
|
|
|
Task nextTask = taskService.createTaskQuery().processInstanceId(currentTask.getProcessInstanceId()).singleResult();
|
|
|
|
|
|
@@ -214,7 +225,7 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
LambdaUpdateWrapper<OaUniversalDO> updateWrapper = new LambdaUpdateWrapper<>();
|
|
|
updateWrapper.set(OaUniversalDO::getCurrentAuditEmployeeId, nextTask.getAssignee())
|
|
|
.set(OaUniversalDO::getFinalAuditDate, LocalDateTime.now())
|
|
|
- .set(OaUniversalDO::getAuditStatus, DictDataConstants.OA_AUDIT_STATUS_REJECTED);
|
|
|
+ .set(OaUniversalDO::getAuditStatus, DictDataConstants.OA_AUDIT_STATUS_RETURNED);
|
|
|
oaUniversalMapper.update(updateWrapper);
|
|
|
|
|
|
// 发送通知
|
|
|
@@ -223,17 +234,27 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public Long revocationOaUniversal(BpmTaskApproveReqVO approveReqVO) {
|
|
|
+ public Long revocationOaUniversal(BpmTaskApproveReqVO revocationReqVO) {
|
|
|
// 登录人信息
|
|
|
Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
// TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- Task currentTask = bpmTaskService.getTask(approveReqVO.getId());
|
|
|
+ Task currentTask = bpmTaskService.getTask(revocationReqVO.getId());
|
|
|
+ if (currentTask == null) {
|
|
|
+ throw ServiceExceptionUtil.exception(ErrorCodeConstants.TASK_NOT_EXISTS);
|
|
|
+ }
|
|
|
+ LambdaQueryWrapper<OaUniversalDO> lambdaQueryWrapper = new LambdaQueryWrapper<OaUniversalDO>()
|
|
|
+ .eq(OaUniversalDO::getProcInstId, currentTask.getProcessInstanceId());
|
|
|
+ OaUniversalDO oaUniversalDO = oaUniversalMapper.selectOne(lambdaQueryWrapper);
|
|
|
+ if (!DictDataConstants.OA_AUDIT_STATUS_COMMITTED.equals(oaUniversalDO.getAuditStatus())
|
|
|
+ || !Objects.equals(String.valueOf(loginUserId), oaUniversalDO.getCreator())) {
|
|
|
+ throw ServiceExceptionUtil.exception(ErrorCodeConstants.TASK_REVOCATION_NO_ALLOWED);
|
|
|
+ }
|
|
|
|
|
|
- BpmTaskReturnReqVO returnReqVO = BeanUtils.toBean(approveReqVO, BpmTaskReturnReqVO.class);
|
|
|
+ BpmTaskReturnReqVO returnReqVO = BeanUtils.toBean(revocationReqVO, BpmTaskReturnReqVO.class);
|
|
|
returnReqVO.setTargetTaskDefinitionKey("modifyApply");
|
|
|
returnReqVO.setReason("[撤回]" + returnReqVO.getReason());
|
|
|
- bpmTaskService.returnTask(loginUserId, returnReqVO);
|
|
|
+ bpmTaskService.revocationTask(loginUserId, returnReqVO);
|
|
|
|
|
|
Task nextTask = taskService.createTaskQuery().processInstanceId(currentTask.getProcessInstanceId()).singleResult();
|
|
|
|
|
|
@@ -241,7 +262,7 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
LambdaUpdateWrapper<OaUniversalDO> updateWrapper = new LambdaUpdateWrapper<>();
|
|
|
updateWrapper.set(OaUniversalDO::getCurrentAuditEmployeeId, nextTask.getAssignee())
|
|
|
.set(OaUniversalDO::getFinalAuditDate, LocalDateTime.now())
|
|
|
- .set(OaUniversalDO::getAuditStatus, DictDataConstants.OA_AUDIT_STATUS_REJECTED);
|
|
|
+ .set(OaUniversalDO::getAuditStatus, DictDataConstants.OA_AUDIT_STATUS_RECALLED);
|
|
|
oaUniversalMapper.update(updateWrapper);
|
|
|
|
|
|
// 发送通知
|
|
|
@@ -250,81 +271,83 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public Long completeFalseOaUniversal(Long userId, BpmTaskApproveReqVO reqVO) {
|
|
|
-
|
|
|
- Task currentTask = bpmTaskService.getTask(reqVO.getId());
|
|
|
+ public Long reCommitOaUniversal(OaUniversalSaveReqVO reCommitReqVO) {
|
|
|
+ // 登录人信息
|
|
|
+ Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
+ // TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- BpmTaskReturnReqVO reqVO2 = BeanUtils.toBean(reqVO, BpmTaskReturnReqVO.class);
|
|
|
- reqVO2.setTargetTaskDefinitionKey("modifyApply");
|
|
|
- bpmTaskService.returnTask(userId, reqVO2);
|
|
|
+ OaUniversalDO oaUniversalNew = BeanUtils.toBean(reCommitReqVO, OaUniversalDO.class);
|
|
|
+ OaUniversalDO oaUniversalOld = oaUniversalMapper.selectById(oaUniversalNew.getId());
|
|
|
+
|
|
|
+ Task currentTask = taskService.createTaskQuery().processInstanceId(oaUniversalOld.getProcInstId()).singleResult();
|
|
|
+ BpmTaskApproveReqVO approveReqVO = new BpmTaskApproveReqVO();
|
|
|
+ approveReqVO.setId(currentTask.getId())
|
|
|
+ .setReason("[再次提交]");
|
|
|
+ if (CollectionUtil.isNotEmpty(reCommitReqVO.getStartUserSelectAssignees())) {
|
|
|
+ // 添加审批人信息
|
|
|
+ Map<String, List<Long>> startUserSelectAssignees = new HashMap<>();
|
|
|
+ List<Long> selectAssignees = reCommitReqVO.getStartUserSelectAssignees();
|
|
|
+ startUserSelectAssignees.put("approver", selectAssignees);
|
|
|
+ taskService.setVariable(currentTask.getId(), BpmConstants.PROCESS_INSTANCE_VARIABLE_START_USER_SELECT_ASSIGNEES, startUserSelectAssignees);
|
|
|
+ }
|
|
|
+ taskService.setVariable(currentTask.getId(), "auditPass", "true");
|
|
|
+ // 再次提交,和审批通过逻辑相同
|
|
|
+ bpmTaskService.approveTask(loginUserId, approveReqVO);
|
|
|
|
|
|
Task nextTask = taskService.createTaskQuery().processInstanceId(currentTask.getProcessInstanceId()).singleResult();
|
|
|
+ oaUniversalNew.setAuditStatus(DictDataConstants.OA_AUDIT_STATUS_COMMITTED)
|
|
|
+ .setCurrentAuditEmployeeId(Long.valueOf(nextTask.getAssignee()))
|
|
|
+ .setFinalAuditDate(LocalDateTime.now());
|
|
|
+ oaUniversalMapper.updateById(oaUniversalNew);
|
|
|
|
|
|
- // 更新单据状态,当前处理人,最后处理时间
|
|
|
- LambdaUpdateWrapper<OaUniversalDO> updateWrapper = new LambdaUpdateWrapper<>();
|
|
|
- updateWrapper.set(OaUniversalDO::getCurrentAuditEmployeeId, nextTask.getAssignee())
|
|
|
- .set(OaUniversalDO::getFinalAuditDate, new Date())
|
|
|
- .set(OaUniversalDO::getAuditStatus, "0")
|
|
|
- .eq(OaUniversalDO::getProcInstId, currentTask.getProcessInstanceId());
|
|
|
- oaUniversalMapper.update(updateWrapper);
|
|
|
-
|
|
|
- // 发送通知
|
|
|
+ // 保存业务uuid到附件中
|
|
|
+ saveFileList(reCommitReqVO.getFileIdList(), oaUniversalOld.getUniversalId());
|
|
|
|
|
|
- // 返回
|
|
|
return 1L;
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public Long updateCompleteOaUniversal(Long userId, OaUniversalSaveReqVO createReqVO, BpmTaskApproveReqVO reqVO) {
|
|
|
- // 判断是否已经发起流程
|
|
|
- Boolean auditPass = true;
|
|
|
-
|
|
|
- OaUniversalDO oaUniversal = BeanUtils.toBean(createReqVO, OaUniversalDO.class);
|
|
|
-
|
|
|
- Task currentTask = taskService.createTaskQuery().processInstanceId(oaUniversal.getProcInstId()).singleResult();
|
|
|
-
|
|
|
- //审批通过
|
|
|
- bpmTaskService.approveTask(userId, reqVO);
|
|
|
+ public Long closeOaUniversal(OaUniversalSaveReqVO closeReqVO) {
|
|
|
+ // 登录人信息
|
|
|
+ Long loginUserId = SecurityFrameworkUtils.getLoginUserId();
|
|
|
+ // TODO DP 根据登录人查询出对应的员工信息
|
|
|
|
|
|
- // 提交
|
|
|
- if (auditPass) {
|
|
|
- Task nextTask = taskService.createTaskQuery().processInstanceId(currentTask.getProcessInstanceId()).singleResult();
|
|
|
+ OaUniversalDO oaUniversalNew = BeanUtils.toBean(closeReqVO, OaUniversalDO.class);
|
|
|
+ OaUniversalDO oaUniversalOld = oaUniversalMapper.selectById(oaUniversalNew.getId());
|
|
|
|
|
|
- oaUniversal.setAuditStatus("1");
|
|
|
- oaUniversal.setCurrentAuditEmployeeId(Long.valueOf(nextTask.getAssignee()));
|
|
|
- oaUniversal.setFinalAuditDate(LocalDateTime.now());
|
|
|
- oaUniversalMapper.updateById(oaUniversal);
|
|
|
-
|
|
|
- } else {
|
|
|
- OaUniversalDO oaUniversalClose = new OaUniversalDO();
|
|
|
- oaUniversalClose.setId(oaUniversal.getId());
|
|
|
- oaUniversalClose.setAuditStatus("4");
|
|
|
- oaUniversalClose.setCurrentAuditEmployeeId(null);
|
|
|
- oaUniversalClose.setFinalAuditDate(LocalDateTime.now());
|
|
|
- oaUniversalMapper.updateById(oaUniversalClose);
|
|
|
- }
|
|
|
-
|
|
|
- return oaUniversal.getId();
|
|
|
- }
|
|
|
+ Task currentTask = taskService.createTaskQuery().processInstanceId(oaUniversalOld.getProcInstId()).singleResult();
|
|
|
+ BpmTaskApproveReqVO approveReqVO = new BpmTaskApproveReqVO();
|
|
|
+ approveReqVO.setId(currentTask.getId())
|
|
|
+ .setReason("[关闭]");
|
|
|
+ taskService.setVariable(currentTask.getId(), "auditPass", "false");
|
|
|
+ // 关闭,使用审批通过的方法实现
|
|
|
+ bpmTaskService.approveTask(loginUserId, approveReqVO);
|
|
|
|
|
|
+ oaUniversalOld.setAuditStatus(DictDataConstants.OA_AUDIT_STATUS_CLOSED)
|
|
|
+ .setCurrentAuditEmployeeId(-1L)
|
|
|
+ .setFinalAuditDate(LocalDateTime.now());
|
|
|
+ oaUniversalMapper.updateById(oaUniversalOld);
|
|
|
|
|
|
- @Override
|
|
|
- public Long createOaUniversal(OaUniversalSaveReqVO createReqVO) {
|
|
|
- // 插入
|
|
|
- OaUniversalDO oaUniversal = BeanUtils.toBean(createReqVO, OaUniversalDO.class);
|
|
|
- oaUniversalMapper.insert(oaUniversal);
|
|
|
- // 返回
|
|
|
- return oaUniversal.getId();
|
|
|
+ return 1L;
|
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
- public void updateOaUniversal(OaUniversalSaveReqVO updateReqVO) {
|
|
|
- // 校验存在
|
|
|
- validateOaUniversalExists(updateReqVO.getId());
|
|
|
- // 更新
|
|
|
- OaUniversalDO updateObj = BeanUtils.toBean(updateReqVO, OaUniversalDO.class);
|
|
|
- oaUniversalMapper.updateById(updateObj);
|
|
|
- }
|
|
|
+ // @Override
|
|
|
+ // public Long createOaUniversal(OaUniversalSaveReqVO createReqVO) {
|
|
|
+ // // 插入
|
|
|
+ // OaUniversalDO oaUniversal = BeanUtils.toBean(createReqVO, OaUniversalDO.class);
|
|
|
+ // oaUniversalMapper.insert(oaUniversal);
|
|
|
+ // // 返回
|
|
|
+ // return oaUniversal.getId();
|
|
|
+ // }
|
|
|
+ //
|
|
|
+ // @Override
|
|
|
+ // public void updateOaUniversal(OaUniversalSaveReqVO updateReqVO) {
|
|
|
+ // // 校验存在
|
|
|
+ // validateOaUniversalExists(updateReqVO.getId());
|
|
|
+ // // 更新
|
|
|
+ // OaUniversalDO updateObj = BeanUtils.toBean(updateReqVO, OaUniversalDO.class);
|
|
|
+ // oaUniversalMapper.updateById(updateObj);
|
|
|
+ // }
|
|
|
|
|
|
@Override
|
|
|
public void deleteOaUniversal(Long id) {
|
|
|
@@ -353,19 +376,71 @@ public class OaUniversalServiceImpl implements OaUniversalService {
|
|
|
List<BpmTaskRespVO> auditRecordList = bpmTaskService.getAuditRecordListByProcessInstanceId(oaUniversalDO.getProcInstId());
|
|
|
oaUniversalRespVO.setAuditRecordList(auditRecordList);
|
|
|
|
|
|
+ // 审批人
|
|
|
+ String startUserSelectAssignees = oaUniversalDO.getStartUserSelectAssignees();
|
|
|
+ if (StrUtil.isNotEmpty(startUserSelectAssignees)) {
|
|
|
+ List<Long> userIdList = Arrays.stream(startUserSelectAssignees.split(","))
|
|
|
+ .map(Long::valueOf).collect(Collectors.toList());
|
|
|
+ List<AdminUserRespDTO> userList = adminUserApi.getUserList(userIdList);
|
|
|
+ List<AdminUserRespDTO> auditUserList = new ArrayList<>();
|
|
|
+ for (Long userId : userIdList) {
|
|
|
+ for (AdminUserRespDTO adminUserRespDTO : userList) {
|
|
|
+ if (Objects.equals(userId, adminUserRespDTO.getId())) {
|
|
|
+ auditUserList.add(adminUserRespDTO);
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ oaUniversalRespVO.setAuditUserList(auditUserList);
|
|
|
+ }
|
|
|
+
|
|
|
return oaUniversalRespVO;
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public PageResult<OaUniversalDO> getOaUniversalPage(OaUniversalPageReqVO pageReqVO) {
|
|
|
- return oaUniversalMapper.selectPage(pageReqVO);
|
|
|
+ public PageResult<OaUniversalRespVO> getOaUniversalPage(OaUniversalPageReqVO pageReqVO) {
|
|
|
+ PageResult<OaUniversalDO> oaUniversalDOPageResult = oaUniversalMapper.selectPage(pageReqVO);
|
|
|
+ PageResult<OaUniversalRespVO> oaUniversalRespVOPageResult = BeanUtils.toBean(oaUniversalDOPageResult, OaUniversalRespVO.class);
|
|
|
+
|
|
|
+ List<OaUniversalRespVO> oaUniversalRespVOList = oaUniversalRespVOPageResult.getList();
|
|
|
+ if (CollectionUtil.isNotEmpty(oaUniversalRespVOList)) {
|
|
|
+ List<Long> employeeIdList = oaUniversalRespVOList.stream().map(OaUniversalRespVO::getCurrentAuditEmployeeId).collect(Collectors.toList());
|
|
|
+ List<AdminUserRespDTO> employeeList = adminUserApi.getUserList(employeeIdList);
|
|
|
+ for (OaUniversalRespVO respVO : oaUniversalRespVOList) {
|
|
|
+ for (AdminUserRespDTO employee : employeeList) {
|
|
|
+ if (respVO.getCurrentAuditEmployeeId() == employee.getId()) {
|
|
|
+ respVO.setCurrentAuditEmployeeName(employee.getNickname());
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ List<Long> deptIdList = oaUniversalRespVOList.stream().map(OaUniversalRespVO::getDeptId).collect(Collectors.toList());
|
|
|
+ List<DeptRespDTO> deptList = deptApi.getDeptList(deptIdList);
|
|
|
+ for (OaUniversalRespVO respVO : oaUniversalRespVOList) {
|
|
|
+ for (DeptRespDTO dept : deptList) {
|
|
|
+ if (respVO.getDeptId() == dept.getId()) {
|
|
|
+ respVO.setDeptName(dept.getName());
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return oaUniversalRespVOPageResult;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public PageResult<OaUniversalRespVO> exportOaUniversalExcel(OaUniversalPageReqVO pageReqVO) {
|
|
|
+ pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
|
|
+ return getOaUniversalPage(pageReqVO);
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 保存业务uuid到附件中
|
|
|
*/
|
|
|
private void saveFileList(List<Long> fileIdList, String serviceId) {
|
|
|
- if (CollectionUtil.isNotEmpty(fileIdList)) {
|
|
|
+ if (CollectionUtil.isNotEmpty(fileIdList) && StrUtil.isNotEmpty(serviceId)) {
|
|
|
fileApi.updateFileBiz(fileIdList, serviceId);
|
|
|
}
|
|
|
}
|