multi-admin/src/main/java/com/gkhy/exam/admin/controller/system/SysDeptController.java
@@ -81,7 +81,7 @@ @ApiOperation(value = "获取部门列表树状") public CommonResult treeList(SysDept dept) { List<SysDept> treeSelects = deptService.selectDeptTreeList(dept); List<TreeSelect> treeSelects = deptService.selectDeptTreeList(dept); return CommonResult.success(treeSelects); } multi-system/src/main/java/com/gkhy/exam/system/domain/vo/SysDeptSaveDTOReq.java
@@ -17,6 +17,7 @@ /** 父部门ID */ @ApiModelProperty("主要负责部门ID无就传0") @NotNull(message = "父部门ID不能为空") private Long parentId; /** 祖级列表 */ @@ -51,7 +52,7 @@ @NotBlank(message = "是否智能分配不能为空") private String responsType; @ApiModelProperty("负责部门id") private List<Long> childDeptIds; // @ApiModelProperty("负责部门id") // private List<Long> childDeptIds; } multi-system/src/main/java/com/gkhy/exam/system/mapper/SysDeptMapper.java
@@ -63,6 +63,14 @@ public List<SysDept> selectChildrenDeptById(Long deptId); /** * 过滤掉本身和子级部门 * @param deptId * @return */ List<SysDept> getParentInfo(Long deptId); /** * 根据ID查询所有子部门(正常状态) * * @param deptId 部门ID multi-system/src/main/java/com/gkhy/exam/system/service/ISysDeptService.java
@@ -36,7 +36,10 @@ * @param dept 部门信息 * @return 部门树信息集合 */ public List<SysDept> selectDeptTreeList(SysDept dept); public List<TreeSelect> selectDeptTreeList(SysDept dept); List<SysDept> getParentInfo(Long deptId); /** * 构建前端所需要树结构 multi-system/src/main/java/com/gkhy/exam/system/service/impl/StandardizedTemplateServiceImpl.java
@@ -173,7 +173,7 @@ //部门 SysDept sysDept = new SysDept(); sysDept.setCompanyId(companyId.longValue()); List<SysDept> treeSelects = iSysDeptService.selectDeptTreeList(sysDept); List<TreeSelect> treeSelects = iSysDeptService.selectDeptTreeList(sysDept); //公司概况 List<CompanySummary> companySummaries = companySummaryMapper.selectCompanySummaryList(companyId); multi-system/src/main/java/com/gkhy/exam/system/service/impl/SysDeptServiceImpl.java
@@ -119,56 +119,30 @@ * @return 部门树信息集合 */ @Override public List<SysDept> selectDeptTreeList(SysDept dept) public List<TreeSelect> selectDeptTreeList(SysDept dept) { List<SysDept> depts = SpringUtils.getAopProxy(this).getOutDeptList(dept); List<SysDeptManage> allManage = deptMapper.getAllManage(dept.getCompanyId()); // 构建父部门到子部门的映射 Map<Long, List<Long>> parentToChildrenMap = new HashMap<>(); for (SysDeptManage responsibility : allManage) { parentToChildrenMap.computeIfAbsent(responsibility.getDeptId(), k -> new ArrayList<>()) .add(responsibility.getSubDeptId()); // List<SysDeptManage> allManage = deptMapper.getAllManage(dept.getCompanyId()); // // 构建父部门到子部门的映射 // Map<Long, List<Long>> parentToChildrenMap = new HashMap<>(); // for (SysDeptManage responsibility : allManage) { // parentToChildrenMap.computeIfAbsent(responsibility.getDeptId(), k -> new ArrayList<>()) // .add(responsibility.getSubDeptId()); // } // // // 构建部门ID到部门对象的映射 // Map<Long, SysDept> deptMap = depts.stream() // .collect(Collectors.toMap(SysDept::getDeptId, Function.identity())); return buildDeptTreeSelect(depts); } // 构建部门ID到部门对象的映射 Map<Long, SysDept> deptMap = depts.stream() .collect(Collectors.toMap(SysDept::getDeptId, Function.identity())); return buildDeptTree(depts,parentToChildrenMap, deptMap); @Override public List<SysDept> getParentInfo(Long deptId) { return deptMapper.getParentInfo(deptId); } public List<SysDept> buildDeptTree(List<SysDept> allDepts, Map<Long, List<Long>> parentToChildrenMap, Map<Long, SysDept> deptMap) { List<SysDept> rootNodes = new ArrayList<>(); for (SysDept dept : allDepts) { if (!deptMap.values().stream() .anyMatch(d -> parentToChildrenMap.containsValue(dept.getDeptId()))) { // 如果没有其他部门将它作为子部门,则为根节点 rootNodes.add(dept); } } for (SysDept root : rootNodes) { buildChildren(root, parentToChildrenMap, deptMap); } return rootNodes; } private void buildChildren(SysDept parent, Map<Long, List<Long>> parentToChildrenMap, Map<Long, SysDept> deptMap) { List<Long> childIds = parentToChildrenMap.getOrDefault(parent.getDeptId(), Collections.emptyList()); List<SysDept> children = childIds.stream() .map(deptMap::get) .filter(Objects::nonNull) .peek(child -> buildChildren(child, parentToChildrenMap, deptMap)) .collect(Collectors.toList()); parent.setChildren(children); } /** * 构建前端所需要树结构 @@ -346,7 +320,7 @@ } @Override @Transactional @Transactional(rollbackFor = RuntimeException.class) public int saveDept(SysDeptSaveDTOReq dept) { // Long companyId = SecurityUtils.getCompanyId(); // if (!companyId.equals(dept.getCompanyId())){ @@ -358,11 +332,29 @@ if (!b){ throw new ApiException("部门名称已存在!"); } SysDept newParentDept = deptMapper.selectDeptById(dept.getParentId()); int i = 0; if (sysDept.getDeptId() == null){ if (ObjectUtil.isNotNull(newParentDept)){ String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId(); dept.setAncestors(newAncestors); } sysDept.setCreateBy(SecurityUtils.getUsername()); i = deptMapper.insertDept(sysDept); }else { if (sysDept.getParentId().equals(sysDept.getDeptId())){ throw new ApiException("上级部门不能是自己!"); } SysDept oldDept = deptMapper.selectDeptById(dept.getDeptId()); if (ObjectUtil.isNotNull(newParentDept) && ObjectUtil.isNotNull(oldDept)) { String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId(); String oldAncestors = oldDept.getAncestors(); dept.setAncestors(newAncestors); updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors); } sysDept.setUpdateBy(SecurityUtils.getUsername()); sysDept.setUpdateTime(LocalDateTime.now()); i = deptMapper.updateDept(sysDept); @@ -376,8 +368,6 @@ //处理条款 batchSaveCaluse(sysDept.getDeptId(), dept.getCompanyId(), dept.getCaluseVO1List()); List<Long> childDeptIds = dept.getChildDeptIds(); bacthInsertManager(sysDept.getDeptId(), childDeptIds, dept.getCompanyId()); } return sysDept.getDeptId().byteValue(); @@ -451,7 +441,18 @@ List<DeptVo> deptVos = deptMapper.selectDeptList(sysDept); if (deptVos != null && !deptVos.isEmpty()){ List<SysFunctionalDistribution> sysFunctionalDistributions = new ArrayList<>(); Map<String, CaluseVO1> clauseNumMap = new HashMap<>(); for (DeptVo deptVo : deptVos) { List<CaluseVO1> caluseVO1List = deptVo.getCaluseVO1List(); if (ObjectUtil.isNotEmpty(caluseVO1List)){ // 转成 Map<String, CaluseVO1>,key 是 clauseNum clauseNumMap = caluseVO1List.stream() .collect(Collectors.toMap( CaluseVO1::getClauseNum, // key Function.identity(), // value (existing, replacement) -> existing // 如果有重复 key,保留现有的值 )); } for (String s : DEPT_ROOT) { SysFunctionalDistribution sysFunctionalDistribution = new SysFunctionalDistribution(); sysFunctionalDistribution.setDeptId(deptVo.getDeptId()); @@ -459,7 +460,14 @@ sysFunctionalDistribution.setCreateBy(SecurityUtils.getUsername()); sysFunctionalDistribution.setCreateTime(LocalDateTime.now()); sysFunctionalDistribution.setClauseNum(s); if (clauseNumMap.isEmpty()){ sysFunctionalDistribution.setChooseLab(0); }else if (clauseNumMap.containsKey(s)){ sysFunctionalDistribution.setChooseLab(1); }else { sysFunctionalDistribution.setChooseLab(0); } sysFunctionalDistributions.add(sysFunctionalDistribution); } multi-system/src/main/resources/mapper/system/SysDeptMapper.xml
@@ -34,12 +34,6 @@ <result property="clauseId" column="clause_id" /> <result property="id" column="data_id" /> </collection> <collection ofType="com.gkhy.exam.system.domain.vo.SysDeptManageVo" property="sysDeptManageVoList"> <result property="subDeptId" column="sub_dept_id" /> <result property="subDeptName" column="sub_dept_name" /> <result property="deptId" column="p_dept_id" /> </collection> </resultMap> <sql id="selectDeptVo"> @@ -52,14 +46,11 @@ <select id="selectDeptList" parameterType="com.gkhy.exam.common.domain.entity.SysDept" resultMap="DeptVoResult"> select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader_user_id, d.company_id, d.status, d.del_flag, d.create_by, d.create_time,d.person_num,d.internal_auditors, d.order_num,d.responsibilities,d.dept_type,d.respons_type,u.name as leader_name,d2.dept_name as parent_name, dr.content ,dr.clause_num,dr.id as data_id,dr.clause_id, sm.sub_dept_id ,sm2.dept_name sub_dept_name,sm.dept_id as p_dept_id d.order_num,d.responsibilities,d.dept_type,d.respons_type,u.name as leader_name,d2.dept_name as parent_name, dr.content ,dr.clause_num,dr.id as data_id,dr.clause_id from sys_dept d left join sys_user u on d.leader_user_id = u.id left join sys_dept d2 on d.parent_id = d2.dept_id left join sys_dept_responsibility dr on d.dept_id = dr.dept_id and dr.del_flag = '0' and data_type = 2 left join sys_dept_manage sm on d.dept_id = sm.dept_id left join sys_dept sm2 on sm2.dept_id = sm.sub_dept_id where d.del_flag = '0' <if test="companyId != null and companyId != 0"> AND d.company_id = #{companyId} @@ -91,12 +82,12 @@ <result property="clauseId" column="clause_id" /> <result property="id" column="id" /> </collection> <collection ofType="com.gkhy.exam.system.domain.vo.SysDeptManageVo" property="sysDeptManageVoList" column="deptId = dept_id" select="getSysDeptManageVo"> <result property="subDeptId" column="sub_dept_id" /> <result property="subDeptName" column="sub_dept_name" /> <result property="deptId" column="dept_id" /> <!-- <collection ofType="com.gkhy.exam.system.domain.vo.SysDeptManageVo" property="sysDeptManageVoList" column="deptId = dept_id" select="getSysDeptManageVo">--> <!-- <result property="subDeptId" column="sub_dept_id" />--> <!-- <result property="subDeptName" column="sub_dept_name" />--> <!-- <result property="deptId" column="dept_id" />--> </collection> <!-- </collection>--> </resultMap> <select id="selectDeptPageList" parameterType="com.gkhy.exam.system.domain.req.SysDeptPageReq" resultMap="DeptVoPageResult"> @@ -135,11 +126,11 @@ </select> <select id="getSysDeptManageVo" resultType="com.gkhy.exam.system.domain.vo.SysDeptManageVo"> select sm.sub_dept_id ,sm2.dept_name as sub_dept_name,sm.dept_id from sys_dept_manage sm left join sys_dept sm2 on sm2.dept_id = sm.sub_dept_id where sm.dept_id = #{deptId} </select> <!-- <select id="getSysDeptManageVo" resultType="com.gkhy.exam.system.domain.vo.SysDeptManageVo">--> <!-- select sm.sub_dept_id ,sm2.dept_name as sub_dept_name,sm.dept_id from sys_dept_manage sm--> <!-- left join sys_dept sm2 on sm2.dept_id = sm.sub_dept_id--> <!-- where sm.dept_id = #{deptId}--> <!-- </select>--> <select id="selectDeptListCount" parameterType="com.gkhy.exam.common.domain.entity.SysDept" resultType="int"> @@ -226,6 +217,12 @@ select * from sys_dept where find_in_set(#{deptId}, ancestors) </select> <select id="getParentInfo" parameterType="Long" resultMap="SysDeptResult"> SELECT * FROM sys_dept WHERE dept_id != #{deptId} AND FIND_IN_SET(#{deptId}, ancestors) = 0 </select> <select id="selectNormalChildrenDeptById" parameterType="Long" resultType="int"> select count(*) from sys_dept where status = 0 and del_flag = '0' and find_in_set(#{deptId}, ancestors) </select>