From 23b688e436a89845e92d861adb5875e625e90d9f Mon Sep 17 00:00:00 2001
From: zxl <763096477@qq.com>
Date: 星期五, 14 三月 2025 11:43:18 +0800
Subject: [PATCH] Merge branch 'dev'

---
 flowable/src/main/java/com/ycl/service/common/TaskCommonService.java |   11 +++++++++--
 1 files changed, 9 insertions(+), 2 deletions(-)

diff --git a/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java b/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java
index b5b0797..a789590 100644
--- a/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java
+++ b/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java
@@ -11,6 +11,7 @@
 import com.ycl.domain.vo.FormDetailVO;
 import com.ycl.flow.FindNextNodeUtil;
 import com.ycl.service.ISysFormService;
+import com.ycl.system.service.ISysDeptService;
 import com.ycl.system.service.ISysDictDataService;
 import com.ycl.system.service.ISysDictTypeService;
 import com.ycl.system.service.ISysUserService;
@@ -47,6 +48,7 @@
     private final TaskService taskService;
     private final HistoryService historyService;
     private final ISysUserService sysUserService;
+    private final ISysDeptService deptService;
     private final ISysDictTypeService sysDictDService;
 
     /**
@@ -182,6 +184,7 @@
                         formDetailVO.setCanWait(this.checkHasExeProperty(currentElement.getExtensionElements().get("properties"), ProcessConstants.EXTENSION_PROPERTY_CAN_WAIT_TEXT));
                         formDetailVO.setUserTask((UserTask) incomingFlow.getSourceFlowElement());
                         defKeys.add(formDetailVO);
+                        continue;
                     } else {
                         beforeNodeInfo(incomingFlow.getSourceFlowElement(), defKeys);
                     }
@@ -199,6 +202,7 @@
                         formDetailVO.setCanWait(this.checkHasExeProperty(currentElement.getExtensionElements().get("properties"), ProcessConstants.EXTENSION_PROPERTY_CAN_WAIT_TEXT));
                         formDetailVO.setUserTask((UserTask) incomingFlow.getSourceFlowElement());
                         defKeys.add(formDetailVO);
+                        continue;
                     } else {
                         beforeNodeInfo(incomingFlow.getSourceFlowElement(), defKeys);
                     }
@@ -319,14 +323,17 @@
      * @return
      */
     public List<String> getCurrentUserGroups() {
-        String deptId = "dept:" + SecurityUtils.getLoginUser().getDeptId();
         List<String> roleIds;
         if (CollectionUtils.isEmpty(SecurityUtils.getLoginUser().getUser().getRoles())) {
             roleIds = new ArrayList<>(1);
         } else {
             roleIds = SecurityUtils.getLoginUser().getUser().getRoles().stream().map(role -> role.getRoleId() + "").collect(Collectors.toList());
         }
-        roleIds.add(deptId);
+        if (Objects.nonNull(SecurityUtils.getLoginUser().getDeptId())) {
+            List<Long> deptIds = deptService.getChildIds(SecurityUtils.getLoginUser().getDeptId());
+            List<String> deptIdList = deptIds.stream().map(id -> "dept:" + id).collect(Collectors.toList());
+            roleIds.addAll(deptIdList);
+        }
         return roleIds;
     }
 

--
Gitblit v1.8.0