| | |
| | | package com.project.system.service.impl; |
| | | |
| | | import cn.hutool.core.collection.CollectionUtil; |
| | | import cn.hutool.core.util.StrUtil; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.project.common.annotation.DataScope; |
| | | import com.project.common.constant.UserConstants; |
| | |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Collections; |
| | | import java.util.Iterator; |
| | | import java.util.List; |
| | | import java.util.stream.Collectors; |
| | |
| | | public Long getCheckDeptIdByLoginDeptId(Long deptId) |
| | | { |
| | | SysDept loginDept = selectDeptById(deptId); |
| | | if (loginDept.getParentId()==100){ |
| | | if (loginDept.getDeptId()==100 || loginDept.getParentId()==100){ |
| | | return loginDept.getDeptId(); |
| | | } else { |
| | | return getCheckDeptIdByLoginDeptId(loginDept.getParentId()); |
| | |
| | | public List<Long> getApplyDeptIdsByLoginUserId(Long userId) |
| | | { |
| | | return deptMapper.getApplyDeptIdsByLoginUserId(userId); |
| | | } |
| | | |
| | | @Override |
| | | public String getDeptAllName(Long deptId) |
| | | { |
| | | List<String> names = new ArrayList<>(); |
| | | names = getAncestorsNames(deptId, names); |
| | | if (CollectionUtil.isEmpty(names)){ |
| | | return ""; |
| | | } |
| | | Collections.reverse(names); |
| | | return StrUtil.join("-", names); |
| | | } |
| | | |
| | | /** |
| | |
| | | { |
| | | return getChildList(list, t).size() > 0; |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 获取祖籍names列表 |
| | | * |
| | | * @param deptId 当前部门id |
| | | * @param names 祖籍id列表 |
| | | * @return names列表 |
| | | */ |
| | | public List<String> getAncestorsNames(long deptId, List<String> names) { |
| | | SysDept dept = deptMapper.selectDeptById(deptId); |
| | | if (dept == null) { |
| | | return names; |
| | | } |
| | | if (deptId == 100) { |
| | | names.add(dept.getDeptName()); |
| | | return names; |
| | | } |
| | | if (dept.getParentId() != null && dept.getParentId() == 100) { |
| | | names.add(dept.getDeptName()); |
| | | return names; |
| | | } else { |
| | | names.add(dept.getDeptName()); |
| | | return getAncestorsNames(dept.getParentId(), names); |
| | | } |
| | | } |
| | | } |