123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501 |
- package com.ozs.system.service.impl;
- import java.math.BigDecimal;
- import java.util.ArrayList;
- import java.util.HashMap;
- import java.util.Iterator;
- import java.util.List;
- import java.util.Map;
- import java.util.stream.Collectors;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.ozs.common.core.domain.AjaxResult;
- import com.ozs.common.core.domain.entity.SysProcurementStandard;
- import com.ozs.common.core.domain.model.LoginUser;
- import com.ozs.common.exception.base.BaseException;
- import com.ozs.pm.service.IPmDemandService;
- import com.ozs.system.domain.vo.responseVo.SysDeptResponseVo;
- import com.ozs.system.mapper.SysDeptMapper;
- import com.ozs.system.mapper.SysProcurementStandardMapper;
- import com.ozs.system.mapper.SysRoleMapper;
- import com.ozs.system.service.ISysDeptService;
- import org.springframework.beans.BeanUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import com.ozs.common.annotation.DataScope;
- import com.ozs.common.constant.UserConstants;
- import com.ozs.common.core.domain.TreeSelect;
- import com.ozs.common.core.domain.entity.SysDept;
- import com.ozs.common.core.domain.entity.SysRole;
- import com.ozs.common.core.domain.entity.SysUser;
- import com.ozs.common.core.text.Convert;
- import com.ozs.common.exception.ServiceException;
- import com.ozs.common.utils.SecurityUtils;
- import com.ozs.common.utils.StringUtils;
- import com.ozs.common.utils.spring.SpringUtils;
- import org.springframework.util.ObjectUtils;
- import javax.annotation.Resource;
- /**
- * 部门管理 服务实现
- *
- * @author ruoyi
- */
- @Service
- public class SysDeptServiceImpl implements ISysDeptService {
- @Autowired
- private SysDeptMapper deptMapper;
- @Autowired
- private ISysDeptService deptService;
- @Autowired
- private SysRoleMapper roleMapper;
- @Resource
- private SysProcurementStandardMapper sysProcurementStandardMapper;
- /**
- * 查询部门管理数据
- *
- * @param dept 部门信息
- * @return 部门信息集合
- */
- @Override
- @DataScope(deptAlias = "d")
- public List<SysDept> selectDeptList(SysDept dept) {
- LoginUser loginUser = SecurityUtils.getLoginUser();
- if (!String.valueOf(loginUser.getUserId()).equals("1")) {
- List<Long> deptList = new ArrayList<>();
- //获取到子孙级部门id
- Long deptId = loginUser.getDeptId();
- if (deptService.hasChildByDeptId(deptId)) {
- List<Long> children = deptService.getDeptChildren(deptId);
- System.err.println(children.size());
- deptList.addAll(children);
- }
- deptList.add(deptId);
- dept.setDeptList(deptList);
- }
- return deptMapper.selectDeptList(dept);
- }
- /**
- * 查询部门管理数据
- *
- * @param dept 部门信息
- * @return 部门信息集合
- */
- @Override
- @DataScope(deptAlias = "d")
- public List<SysDept> selectDeptListAndF(SysDept dept) {
- LoginUser loginUser = SecurityUtils.getLoginUser();
- Long deptId = loginUser.getDeptId();
- if (!String.valueOf(loginUser.getUserId()).equals("1")) {
- List<Long> deptList = new ArrayList<>();
- //获取到子孙级部门id
- if (deptService.hasChildByDeptId(deptId)) {
- List<Long> children = deptService.getDeptChildren(deptId);
- System.err.println(children.size());
- deptList.addAll(children);
- }
- //查询上一级到顶级
- SysDept sysDept = deptService.selectById(deptId);
- String[] split = sysDept.getAncestors().split(",");
- if (split.length > 1) {
- for (String s : split) {
- deptList.add(Long.valueOf(s));
- }
- }
- deptList.add(deptId);
- dept.setDeptList(deptList);
- }
- return deptMapper.selectDeptList(dept);
- }
- /**
- * 查询部门管理数据
- *
- * @param dept 部门信息
- * @return 部门信息集合
- */
- @Override
- @DataScope(deptAlias = "d")
- public List<SysDept> selectDeptListAndUp(SysDept dept) {
- LoginUser loginUser = SecurityUtils.getLoginUser();
- if (!String.valueOf(loginUser.getUserId()).equals("1")) {
- List<Long> deptList = new ArrayList<>();
- //获取到子孙级部门id
- Long deptId = loginUser.getDeptId();
- if (deptService.hasChildByDeptId(deptId)) {
- List<Long> children = deptService.getDeptChildren(deptId);
- System.err.println(children.size());
- deptList.addAll(children);
- }
- //查询上一级
- SysDept sysDept = deptService.selectByCid(loginUser.getDeptId());
- if (!ObjectUtils.isEmpty(sysDept)) {
- deptList.add(sysDept.getDeptId());
- }
- deptList.add(deptId);
- dept.setDeptList(deptList);
- }
- return deptMapper.selectDeptList(dept);
- }
- /**
- * 查询部门树结构信息
- *
- * @param dept 部门信息
- * @return 部门树信息集合
- */
- @Override
- public List<TreeSelect> selectDeptTreeList(SysDept dept) {
- List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept);
- return buildDeptTreeSelect(depts);
- }
- /**
- * 查询部门树结构信息
- *
- * @param dept 部门信息
- * @return 部门树信息集合
- */
- @Override
- public List<TreeSelect> selectDeptTreeListF(SysDept dept) {
- List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptListAndF(dept);
- return buildDeptTreeSelect(depts);
- }
- /**
- * 构建前端所需要树结构
- *
- * @param depts 部门列表
- * @return 树结构列表
- */
- @Override
- public List<SysDept> buildDeptTree(List<SysDept> depts) {
- List<SysDept> returnList = new ArrayList<SysDept>();
- List<Long> tempList = depts.stream().map(SysDept::getDeptId).collect(Collectors.toList());
- for (SysDept dept : depts) {
- // 如果是顶级节点, 遍历该父节点的所有子节点
- if (!tempList.contains(dept.getParentId())) {
- recursionFn(depts, dept);
- returnList.add(dept);
- }
- }
- if (returnList.isEmpty()) {
- returnList = depts;
- }
- return returnList;
- }
- /**
- * 构建前端所需要下拉树结构
- *
- * @param depts 部门列表
- * @return 下拉树结构列表
- */
- @Override
- public List<TreeSelect> buildDeptTreeSelect(List<SysDept> depts) {
- List<SysDept> deptTrees = buildDeptTree(depts);
- return deptTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
- }
- /**
- * 根据角色ID查询部门树信息
- *
- * @param roleId 角色ID
- * @return 选中部门列表
- */
- @Override
- public List<Long> selectDeptListByRoleId(Long roleId) {
- SysRole role = roleMapper.selectRoleById(roleId);
- return deptMapper.selectDeptListByRoleId(roleId, role.isDeptCheckStrictly());
- }
- /**
- * 根据部门ID查询信息
- *
- * @param deptId 部门ID
- * @return 部门信息
- */
- @Override
- public Map<String, Object> selectDeptById(Long deptId) {
- Map<String, Object> returnMap = new HashMap<>();
- SysDept sysDept = deptMapper.selectDeptById(deptId);
- SysDeptResponseVo sysDeptResponseVo = new SysDeptResponseVo();
- if (ObjectUtils.isEmpty(sysDept)) {
- throw new BaseException("deptId为" + deptId + "的单位不存在");
- }
- BeanUtils.copyProperties(sysDept, sysDeptResponseVo);
- QueryWrapper<SysProcurementStandard> queryWrapper = new QueryWrapper<>();
- queryWrapper.eq("dept_id", deptId);
- List<SysProcurementStandard> sysProcurementStandardsList = sysProcurementStandardMapper.selectList(queryWrapper);
- returnMap.put("sysDept", sysDeptResponseVo);
- returnMap.put("sysProcurementStandardsList", sysProcurementStandardsList);
- returnMap.put("dto", sysDept);
- return returnMap;
- }
- /**
- * 根据ID查询所有子部门(正常状态)
- *
- * @param deptId 部门ID
- * @return 子部门数
- */
- @Override
- public int selectNormalChildrenDeptById(Long deptId) {
- return deptMapper.selectNormalChildrenDeptById(deptId);
- }
- /**
- * 是否存在子节点
- *
- * @param deptId 部门ID
- * @return 结果
- */
- @Override
- public boolean hasChildByDeptId(Long deptId) {
- int result = deptMapper.hasChildByDeptId(deptId);
- return result > 0;
- }
- /**
- * 获取所有子节点id
- *
- * @param deptId 部门ID
- * @return 结果
- */
- @Override
- public List<Long> getChildIdByDeptId(Long deptId) {
- return deptMapper.getChildIdByDeptId(deptId);
- }
- /**
- * 查询部门是否存在用户
- *
- * @param deptId 部门ID
- * @return 结果 true 存在 false 不存在
- */
- @Override
- public boolean checkDeptExistUser(Long deptId) {
- int result = deptMapper.checkDeptExistUser(deptId);
- return result > 0;
- }
- /**
- * 校验部门名称是否唯一
- *
- * @param dept 部门信息
- * @return 结果
- */
- @Override
- public String checkDeptNameUnique(SysDept dept) {
- Long deptId = StringUtils.isNull(dept.getDeptId()) ? -1L : dept.getDeptId();
- SysDept info = deptMapper.checkDeptNameUnique(dept.getDeptName(), dept.getParentId());
- if (StringUtils.isNotNull(info) && info.getDeptId().longValue() != deptId.longValue()) {
- return UserConstants.NOT_UNIQUE;
- }
- return UserConstants.UNIQUE;
- }
- /**
- * 校验部门是否有数据权限
- *
- * @param deptId 部门id
- */
- @Override
- public void checkDeptDataScope(Long deptId) {
- if (!SysUser.isAdmin(SecurityUtils.getUserId())) {
- SysDept dept = new SysDept();
- dept.setDeptId(deptId);
- List<SysDept> depts = SpringUtils.getAopProxy(this).selectDeptList(dept);
- if (StringUtils.isEmpty(depts)) {
- throw new ServiceException("没有权限访问部门数据!");
- }
- }
- }
- /**
- * 新增保存部门信息
- *
- * @param dept 部门信息
- * @return 结果
- */
- @Override
- public AjaxResult insertDept(SysDept dept) {
- SysDept info = deptMapper.selectDeptById(dept.getParentId());
- // 如果父节点不为正常状态,则不允许新增子节点
- if (!UserConstants.DEPT_NORMAL.equals(info.getStatus())) {
- throw new ServiceException("部门停用,不允许新增");
- }
- //授权到5级单位,创建6级单位时提示:只允许创建5级单位
- String[] ancestors = info.getAncestors().split(",");
- if (ancestors.length >= 6) {
- return AjaxResult.error("只允许创建5级单位");
- }
- dept.setAncestors(info.getAncestors() + "," + dept.getParentId());
- Integer dept1 = deptMapper.insertDept(dept);
- return AjaxResult.success(dept.getDeptId());
- }
- /**
- * 修改保存部门信息
- *
- * @param dept 部门信息
- * @return 结果
- */
- @Override
- public int updateDept(SysDept dept) {
- SysDept newParentDept = deptMapper.selectDeptById(dept.getParentId());
- SysDept oldDept = deptMapper.selectDeptById(dept.getDeptId());
- if (StringUtils.isNotNull(newParentDept) && StringUtils.isNotNull(oldDept)) {
- String newAncestors = newParentDept.getAncestors() + "," + newParentDept.getDeptId();
- String oldAncestors = oldDept.getAncestors();
- dept.setAncestors(newAncestors);
- updateDeptChildren(dept.getDeptId(), newAncestors, oldAncestors);
- }
- int result = deptMapper.updateDept(dept);
- if (UserConstants.DEPT_NORMAL.equals(dept.getStatus()) && StringUtils.isNotEmpty(dept.getAncestors())
- && !StringUtils.equals("0", dept.getAncestors())) {
- // 如果该部门是启用状态,则启用该部门的所有上级部门
- updateParentDeptStatusNormal(dept);
- }
- return result;
- }
- /**
- * 修改该部门的父级部门状态
- *
- * @param dept 当前部门
- */
- private void updateParentDeptStatusNormal(SysDept dept) {
- String ancestors = dept.getAncestors();
- Long[] deptIds = Convert.toLongArray(ancestors);
- deptMapper.updateDeptStatusNormal(deptIds);
- }
- /**
- * 修改子元素关系
- *
- * @param deptId 被修改的部门ID
- * @param newAncestors 新的父ID集合
- * @param oldAncestors 旧的父ID集合
- */
- public void updateDeptChildren(Long deptId, String newAncestors, String oldAncestors) {
- List<SysDept> children = deptMapper.selectChildrenDeptById(deptId);
- for (SysDept child : children) {
- child.setAncestors(child.getAncestors().replaceFirst(oldAncestors, newAncestors));
- }
- if (children.size() > 0) {
- deptMapper.updateDeptChildren(children);
- }
- }
- /**
- * 删除部门管理信息
- *
- * @param deptId 部门ID
- * @return 结果
- */
- @Override
- public int deleteDeptById(Long deptId) {
- return deptMapper.deleteDeptById(deptId);
- }
- /**
- * 递归列表
- */
- private void recursionFn(List<SysDept> list, SysDept t) {
- // 得到子节点列表
- List<SysDept> childList = getChildList(list, t);
- t.setChildren(childList);
- for (SysDept tChild : childList) {
- if (hasChild(list, tChild)) {
- recursionFn(list, tChild);
- }
- }
- }
- /**
- * 得到子节点列表
- */
- private List<SysDept> getChildList(List<SysDept> list, SysDept t) {
- List<SysDept> tlist = new ArrayList<SysDept>();
- Iterator<SysDept> it = list.iterator();
- while (it.hasNext()) {
- SysDept n = (SysDept) it.next();
- if (StringUtils.isNotNull(n.getParentId()) && n.getParentId().longValue() == t.getDeptId().longValue()) {
- tlist.add(n);
- }
- }
- return tlist;
- }
- /**
- * 判断是否有子节点
- */
- private boolean hasChild(List<SysDept> list, SysDept t) {
- return getChildList(list, t).size() > 0;
- }
- //判断是否为超额计划
- @Override
- public String isExcessOrNo(String projectType, BigDecimal evaluation, Long deptId) {
- String result = "0";
- BigDecimal threshold = new BigDecimal(0);
- //获取各个项目类型设定的概算金额阈值
- QueryWrapper<SysProcurementStandard> queryWrapper = new QueryWrapper<>();
- queryWrapper.eq("dept_id", deptId);
- queryWrapper.eq("category", projectType.equals("2") ? "1" : projectType.equals("1") ? "2" : projectType);
- List<SysProcurementStandard> sysProcurementStandardsList = sysProcurementStandardMapper.selectList(queryWrapper);
- if (!ObjectUtils.isEmpty(sysProcurementStandardsList)) {
- BigDecimal maximum = sysProcurementStandardsList.get(0).getMaximum();
- if (ObjectUtils.isEmpty(maximum)) {
- return "0";
- }
- if (evaluation.compareTo(maximum) == 1) {
- //是超额计划
- result = "1";
- } else {
- result = "0";
- }
- }
- return result;
- }
- //获取到子孙级部门id
- public List<Long> getDeptChildren(Long deptId) {
- List<Long> deptList = new ArrayList<>();
- List<Long> childByDeptId = getChildIdByDeptId(deptId);
- for (Long cid : childByDeptId) {
- deptList.add(cid);
- if (hasChildByDeptId(cid)) {
- deptList.addAll(getDeptChildren(cid));
- }
- }
- return deptList;
- }
- @Override
- public SysDept selectById(Long deptId) {
- return deptMapper.selectDeptById(deptId);
- }
- @Override
- public List<SysDept> selectChildrenDeptById(Long deptId) {
- return deptMapper.selectChildrenDeptById(deptId);
- }
- @Override
- public List<SysDept> selectMaxDeptByParentId(Long deptId) {
- return deptMapper.selectMaxDeptByParentId(deptId);
- }
- @Override
- public SysDept selectByCid(Long deptId) {
- return deptMapper.selectByCid(deptId);
- }
- }
|