From 6b1f69d9a02b9ddfd86460db6cb07dcd8d20ba0a Mon Sep 17 00:00:00 2001 From: PoffyZhang <99775271@qq.com> Date: Fri, 31 Mar 2023 15:14:26 +0800 Subject: [PATCH] =?UTF-8?q?=E8=A7=92=E8=89=B2debug?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../impl/OrdinaryUserDataScopeProviderImpl.java | 2 +- .../impl/OrgAdminDataScopeProviderImpl.java | 2 +- .../impl/RegionAdminDataScopeProviderImpl.java | 2 +- .../pmapi/todocenter/manage/TodoCenterManage.java | 24 ++++++++++++++++++---- 4 files changed, 23 insertions(+), 7 deletions(-) diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrdinaryUserDataScopeProviderImpl.java b/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrdinaryUserDataScopeProviderImpl.java index 528a525..2cb1565 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrdinaryUserDataScopeProviderImpl.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrdinaryUserDataScopeProviderImpl.java @@ -22,7 +22,7 @@ import java.util.Optional; */ @Slf4j @RequiredArgsConstructor -@Component("ORDINARY_USER") +@Component("NORMAL_MEMBER") public class OrdinaryUserDataScopeProviderImpl implements DataScopeProvider { private final UserInfoHelper userInfoHelper; diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrgAdminDataScopeProviderImpl.java b/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrgAdminDataScopeProviderImpl.java index 8f36b97..03c2ea6 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrgAdminDataScopeProviderImpl.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/OrgAdminDataScopeProviderImpl.java @@ -21,7 +21,7 @@ import java.util.Optional; */ @Slf4j @RequiredArgsConstructor -@Component("ORG_ADMIN") +@Component("COMPANY_MANAGER") public class OrgAdminDataScopeProviderImpl implements DataScopeProvider { private final UserInfoHelper userInfoHelper; diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/RegionAdminDataScopeProviderImpl.java b/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/RegionAdminDataScopeProviderImpl.java index e70bde4..19b8b2b 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/RegionAdminDataScopeProviderImpl.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/datascope/provider/impl/RegionAdminDataScopeProviderImpl.java @@ -26,7 +26,7 @@ import java.util.stream.Collectors; */ @Slf4j @RequiredArgsConstructor -@Component("REGION_ADMIN") +@Component("REGION_MANAGER") public class RegionAdminDataScopeProviderImpl implements DataScopeProvider { private final RegionCacheHelper regionCacheHelper; diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java b/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java index 70e9470..fe906e6 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java @@ -505,16 +505,32 @@ public class TodoCenterManage { UserFullInfoDTO beforeUser = null; Boolean isAndOr = Boolean.FALSE; - //还有种情况是 会签 或签 并且在上个节点 - if(CollUtil.isNotEmpty(beforeAndOr)){ - for(ProgressNode n : beforeAndOr){ - if(n.getUserId().equals(user.getEmployeeCode())){ + + //如果上个会签没取到 还有种情况是 会签 或签 并且在上个节点 + if(CollUtil.isNotEmpty(beforeAndOr)) { + for (ProgressNode n : beforeAndOr) { + if (n.getUserId().equals(user.getEmployeeCode())) { + beforeProgressNode = n; //说明当前操作人 在上个会签或者或签节点 isAndOr = Boolean.TRUE; break; } } } + + //还有种情况是 会签 或签 并且在当前节点 并且已经通过 + if(!isAndOr && CollUtil.isNotEmpty(thisAndOr)){ + for(ProgressNode n : thisAndOr){ + if(n.getUserId().equals(user.getEmployeeCode()) && + Objects.nonNull(n.getFinishTime())){ + beforeProgressNode = n; + //说明当前操作人 在上个会签或者或签节点 + isAndOr = Boolean.TRUE; + break; + } + } + } + if(Objects.nonNull(beforeProgressNode)){ // 获取当前工作流任务前一个审核人信息 beforeUser = userInfoHelper.getUserFullInfoByEmployeeCode(beforeProgressNode.getUserId());