Commit 3a0247e9 authored by jiuping's avatar jiuping

部门负责人发起流程找上级人审批

(cherry picked from commit bc7217ae)
parent 9dc9f2d6
...@@ -7,7 +7,6 @@ import cn.iocoder.yudao.module.system.api.dept.DeptApi; ...@@ -7,7 +7,6 @@ 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.dept.dto.DeptRespDTO;
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 lombok.extern.slf4j.Slf4j;
import org.flowable.engine.delegate.DelegateExecution; import org.flowable.engine.delegate.DelegateExecution;
import org.flowable.engine.runtime.ProcessInstance; import org.flowable.engine.runtime.ProcessInstance;
import org.springframework.context.annotation.Lazy; import org.springframework.context.annotation.Lazy;
...@@ -25,7 +24,6 @@ import static java.util.Collections.emptySet; ...@@ -25,7 +24,6 @@ import static java.util.Collections.emptySet;
* *
* @author 捷道源码 * @author 捷道源码
*/ */
@Slf4j
public abstract class BpmTaskAssignLeaderAbstractScript implements BpmTaskAssignScript { public abstract class BpmTaskAssignLeaderAbstractScript implements BpmTaskAssignScript {
@Resource @Resource
...@@ -41,38 +39,40 @@ public abstract class BpmTaskAssignLeaderAbstractScript implements BpmTaskAssign ...@@ -41,38 +39,40 @@ public abstract class BpmTaskAssignLeaderAbstractScript implements BpmTaskAssign
// 获得发起人 // 获得发起人
ProcessInstance processInstance = bpmProcessInstanceService.getProcessInstance(execution.getProcessInstanceId()); ProcessInstance processInstance = bpmProcessInstanceService.getProcessInstance(execution.getProcessInstanceId());
Long startUserId = NumberUtils.parseLong(processInstance.getStartUserId()); Long startUserId = NumberUtils.parseLong(processInstance.getStartUserId());
log.error("111:{}", startUserId);
// 获得对应 leve 的部门 // 获得对应 leve 的部门
DeptRespDTO dept = null; DeptRespDTO dept = null;
for (int i = 0; i < level; i++) { for (int i = 0; i < level; i++) {
// 获得 level 对应的部门 // 获得 level 对应的部门
if (dept == null) { if (dept == null) {
dept = getStartUserDept(startUserId); dept = getStartUserDept(startUserId);
log.error("222:{}", dept);
if (dept == null) { // 找不到发起人的部门,所以无法使用该规则 if (dept == null) { // 找不到发起人的部门,所以无法使用该规则
return emptySet(); return emptySet();
} else {
if (dept.getLeaderUserId().equals(startUserId)) {
DeptRespDTO parentDept = deptApi.getDept(dept.getParentId());
if (parentDept != null) { // 找不到父级部门,所以只好结束寻找。原因是:例如说,级别比较高的人,所在部门层级比较少
dept = parentDept;
} else {
return emptySet();
}
}
} }
} else { } else {
log.error("333:{}", dept.getParentId());
DeptRespDTO parentDept = deptApi.getDept(dept.getParentId()); DeptRespDTO parentDept = deptApi.getDept(dept.getParentId());
if (parentDept == null) { // 找不到父级部门,所以只好结束寻找。原因是:例如说,级别比较高的人,所在部门层级比较少 if (parentDept == null) { // 找不到父级部门,所以只好结束寻找。原因是:例如说,级别比较高的人,所在部门层级比较少
break; break;
} }
dept = parentDept; dept = parentDept;
log.error("444:{}", parentDept);
} }
} }
return dept.getLeaderUserId() != null ? asSet(dept.getLeaderUserId()) : emptySet(); return dept.getLeaderUserId() != null ? asSet(dept.getLeaderUserId()) : emptySet();
} }
private DeptRespDTO getStartUserDept(Long startUserId) { private DeptRespDTO getStartUserDept(Long startUserId) {
log.error("555:{}", startUserId);
AdminUserRespDTO startUser = adminUserApi.getUser(startUserId); AdminUserRespDTO startUser = adminUserApi.getUser(startUserId);
if (startUser.getDeptId() == null) { // 找不到部门,所以无法使用该规则 if (startUser.getDeptId() == null) { // 找不到部门,所以无法使用该规则
return null; return null;
} }
log.error("6666:{}", startUser.getDeptId());
return deptApi.getDept(startUser.getDeptId()); return deptApi.getDept(startUser.getDeptId());
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment