package com.tievd.cube.modules.system.service.impl;
import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.tievd.cube.commons.base.Result;
import com.tievd.cube.commons.constant.CacheConst;
import com.tievd.cube.commons.constant.CommonConst;
import com.tievd.cube.commons.utils.FillRuleUtil;
import com.tievd.cube.commons.utils.spring.RedisUtil;
import com.tievd.cube.modules.system.entity.*;
import com.tievd.cube.modules.system.mapper.*;
import com.tievd.cube.modules.system.model.DepartIdModel;
import com.tievd.cube.modules.system.model.SysDepartTreeModel;
import com.tievd.cube.modules.system.service.ISysDepartService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
/**
*
* 部门表 服务实现类
*
*
* @author Steve
* @since 2019-01-22
*/
@Service
public class SysDepartServiceImpl extends ServiceImpl implements ISysDepartService {
@Autowired
private SysUserDepartMapper userDepartMapper;
@Autowired
private SysDepartRoleMapper sysDepartRoleMapper;
@Autowired
private SysDepartPermissionMapper departPermissionMapper;
@Autowired
private SysDepartRolePermissionMapper departRolePermissionMapper;
@Autowired
private SysDepartRoleUserMapper departRoleUserMapper;
@Autowired
private RedisUtil redisUtil;
@Override
public List queryMyDeptTreeList(String departIds) {
//根据部门id获取所负责部门
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
String[] codeArr = this.getMyDeptParentOrgCode(departIds);
if (codeArr != null) {
for (String s : codeArr) {
query.or().likeRight(SysDepart::getOrgCode, s);
}
}
query.eq(SysDepart::getDelFlag, CommonConst.NOT_DELETED.toString());
query.orderByAsc(SysDepart::getDepartOrder);
//将父节点ParentId设为null
List listDepts = this.list(query);
if (codeArr != null) {
for (String s : codeArr) {
for (SysDepart dept : listDepts) {
if (dept.getOrgCode().equals(s)) {
dept.setParentId(null);
}
}
}
}
return SysDepartTreeModel.toTreeList(listDepts);
}
/**
* queryTreeList 查询所有的部门数据,以树结构形式响应给前端
*/
@Override
@Cacheable(CacheConst.SYS_DEPARTS_CACHE_ALL)
public List queryTreeList() {
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.eq(SysDepart::getDelFlag, CommonConst.NOT_DELETED);
query.orderByAsc(SysDepart::getDepartOrder);
List list = this.list(query);
// 调用wrapTreeDataToTreeList方法生成树状数据
return SysDepartTreeModel.toTreeList(list);
}
@Override
@Cacheable(CacheConst.SYS_DEPART_IDS_CACHE)
public List queryDepartIdTreeList() {
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.eq(SysDepart::getDelFlag, CommonConst.NOT_DELETED.toString());
query.orderByAsc(SysDepart::getDepartOrder);
List list = this.list(query);
// 调用wrapTreeDataToTreeList方法生成树状数据
return SysDepartTreeModel.toIdTreeList(list);
}
/**
* saveDepartData 对应 add 保存用户在页面添加的新的部门对象数据
*/
@Override
@Transactional
public Result> saveDepartData(SysDepart sysDepart) {
if (sysDepart.getParentId() == null) {
sysDepart.setParentId("");
}
String s = UUID.randomUUID().toString().replace("-", "");
sysDepart.setId(s);
// 先判断该对象有无父级ID,有则意味着不是最高级,否则意味着是最高级
// 获取父级ID
String parentId = sysDepart.getParentId();
//update-begin--Author:baihailong Date:20191209 for:部门编码规则生成器做成公用配置
JSONObject formData = JSONUtil.createObj();
formData.set("parentId", parentId);
String[] codeArray = (String[]) FillRuleUtil.executeRule("org_num_role", formData.toString());
if (codeArray == null) {
return Result.error("生成部门OrgCode失败!");
}
//update-end--Author:baihailong Date:20191209 for:部门编码规则生成器做成公用配置
sysDepart.setOrgCode(codeArray[0]);
String orgType = codeArray[1];
sysDepart.setOrgType(String.valueOf(orgType));
sysDepart.setCreateTime(new Date());
sysDepart.setDelFlag(CommonConst.NOT_DELETED);
this.save(sysDepart);
redisUtil.prefixDel(CacheConst.SYS_DEPARTS_CACHE);
return Result.ok();
}
/**
* updateDepartDataById 对应 edit 根据部门主键来更新对应的部门数据
*/
@Override
@Transactional
public void updateDepartDataById(SysDepart sysDepart, String username) {
sysDepart.setUpdateTime(new Date());
sysDepart.setUpdateBy(username);
this.updateById(sysDepart);
redisUtil.prefixDel(CacheConst.SYS_DEPARTS_CACHE);
}
@Override
@Transactional(rollbackFor = Exception.class)
public void deleteBatchWithChildren(List ids) {
List idList = new ArrayList<>();
for (String id : ids) {
idList.add(id);
this.checkChildrenExists(id, idList);
}
this.removeByIds(idList);
//根据部门id获取部门角色id
List roleIdList = new ArrayList<>();
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.select(SysDepartRole::getId).in(SysDepartRole::getDepartId, idList);
List depRoleList = sysDepartRoleMapper.selectList(query);
for (SysDepartRole deptRole : depRoleList) {
roleIdList.add(deptRole.getId());
}
//根据部门id删除用户与部门关系
userDepartMapper.delete(new LambdaQueryWrapper().in(SysUserDepart::getDepId, idList));
//根据部门id删除部门授权
departPermissionMapper.delete(new LambdaQueryWrapper().in(SysDepartPermission::getDepartId, idList));
//根据部门id删除部门角色
sysDepartRoleMapper.delete(new LambdaQueryWrapper().in(SysDepartRole::getDepartId, idList));
if (roleIdList.size() > 0) {
//根据角色id删除部门角色授权
departRolePermissionMapper.delete(new LambdaQueryWrapper().in(SysDepartRolePermission::getRoleId, roleIdList));
//根据角色id删除部门角色用户信息
departRoleUserMapper.delete(new LambdaQueryWrapper().in(SysDepartRoleUser::getDroleId, roleIdList));
}
redisUtil.prefixDel(CacheConst.SYS_DEPARTS_CACHE);
}
@Override
public List getSubDepIdsByDepId(String departId) {
return this.baseMapper.getSubDepIdsByDepId(departId);
}
@Override
public List getMySubDepIdsByDepId(String departIds) {
//根据部门id获取所负责部门
String[] codeArr = this.getMyDeptParentOrgCode(departIds);
return this.baseMapper.getSubDepIdsByOrgCodes(codeArr);
}
/**
*
* 根据关键字搜索相关的部门数据
*
*/
@Override
public List searchBy(String keyWord, String myDeptSearch, String departIds) {
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.eq(SysDepart::getDelFlag, CommonConst.NOT_DELETED.toString());
List newList = new ArrayList<>();
//myDeptSearch不为空时为我的部门搜索,只搜索所负责部门
if (StrUtil.isNotEmpty(myDeptSearch)) {
//departIds 为空普通用户或没有管理部门
if (StrUtil.isEmpty(departIds)) {
return newList;
}
//根据部门id获取所负责部门
String[] codeArr = this.getMyDeptParentOrgCode(departIds);
if (codeArr != null && codeArr.length > 0) {
// fix 多部门下要有优先级
query.nested(i -> {
for (String s : codeArr) {
i.or().likeRight(SysDepart::getOrgCode, s);
}
});
}
}
query.like(SysDepart::getDepartName, keyWord);
//update-begin--Author:huangzhilin Date:20140417 for:[bugfree号]组织机构搜索回显优化--------------------
SysDepartTreeModel model;
List departList = this.list(query);
if (departList.size() > 0) {
for (SysDepart depart : departList) {
model = new SysDepartTreeModel(depart);
model.setChildren(null);
//update-end--Author:huangzhilin Date:20140417 for:[bugfree号]组织机构搜索功回显优化----------------------
newList.add(model);
}
return newList;
}
return null;
}
/**
* 根据部门id删除并且删除其可能存在的子级任何部门
*/
@Override
@Transactional(rollbackFor = Exception.class)
public boolean delete(String id) {
List idList = new ArrayList<>();
idList.add(id);
this.checkChildrenExists(id, idList);
//清空部门树内存
//FindsDepartsChildrenUtil.clearDepartIdModel();
boolean ok = this.removeByIds(idList);
//根据部门id获取部门角色id
List roleIdList = new ArrayList<>();
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.select(SysDepartRole::getId).in(SysDepartRole::getDepartId, idList);
List depRoleList = sysDepartRoleMapper.selectList(query);
for (SysDepartRole deptRole : depRoleList) {
roleIdList.add(deptRole.getId());
}
//根据部门id删除用户与部门关系
userDepartMapper.delete(new LambdaQueryWrapper().in(SysUserDepart::getDepId, idList));
//根据部门id删除部门授权
departPermissionMapper.delete(new LambdaQueryWrapper().in(SysDepartPermission::getDepartId, idList));
//根据部门id删除部门角色
sysDepartRoleMapper.delete(new LambdaQueryWrapper().in(SysDepartRole::getDepartId, idList));
if (roleIdList.size() > 0) {
//根据角色id删除部门角色授权
departRolePermissionMapper.delete(new LambdaQueryWrapper().in(SysDepartRolePermission::getRoleId, roleIdList));
//根据角色id删除部门角色用户信息
departRoleUserMapper.delete(new LambdaQueryWrapper().in(SysDepartRoleUser::getDroleId, roleIdList));
}
redisUtil.prefixDel(CacheConst.SYS_DEPARTS_CACHE);
return ok;
}
/**
* delete 方法调用
*/
private void checkChildrenExists(String id, List idList) {
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.eq(SysDepart::getParentId, id);
List departList = this.list(query);
if (departList != null && departList.size() > 0) {
for (SysDepart depart : departList) {
idList.add(depart.getId());
this.checkChildrenExists(depart.getId(), idList);
}
}
}
@Override
public List queryUserDeparts(String userId) {
return baseMapper.queryUserDeparts(userId);
}
@Override
public List queryDepartsByUsername(String username) {
return baseMapper.queryDepartsByUsername(username);
}
/**
* 根据用户所负责部门ids获取父级部门编码
*/
private String[] getMyDeptParentOrgCode(String departIds) {
//根据部门id查询所负责部门
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.eq(SysDepart::getDelFlag, CommonConst.NOT_DELETED.toString());
query.in(SysDepart::getId, Arrays.asList(departIds.split(",")));
query.orderByAsc(SysDepart::getOrgCode);
List list = this.list(query);
//查找根部门
if (list == null || list.size() == 0) {
return null;
}
String orgCode = this.getMyDeptParentNode(list);
return orgCode.split(",");
}
/**
* 获取负责部门父节点
*/
private String getMyDeptParentNode(List list) {
Map map = new HashMap<>();
//1.先将同一公司归类
for (SysDepart dept : list) {
String code = dept.getOrgCode().substring(0, 3);
if (map.containsKey(code)) {
String mapCode = map.get(code) + "," + dept.getOrgCode();
map.put(code, mapCode);
} else {
map.put(code, dept.getOrgCode());
}
}
StringBuilder parentOrgCode = new StringBuilder();
//2.获取同一公司的根节点
for (String str : map.values()) {
String[] arrStr = str.split(",");
parentOrgCode.append(",").append(this.getMinLengthNode(arrStr));
}
return parentOrgCode.substring(1);
}
/**
* 获取同一公司中部门编码长度最小的部门
*/
private String getMinLengthNode(String[] str) {
int min = str[0].length();
StringBuilder orgCode = new StringBuilder(str[0]);
for (int i = 1; i < str.length; i++) {
if (str[i].length() <= min) {
min = str[i].length();
orgCode.append(",").append(str[i]);
}
}
return orgCode.toString();
}
/**
* 获取部门树信息根据关键字
*/
@Override
public List queryTreeByKeyWord(String keyWord) {
LambdaQueryWrapper query = new LambdaQueryWrapper<>();
query.eq(SysDepart::getDelFlag, CommonConst.NOT_DELETED.toString());
query.orderByAsc(SysDepart::getDepartOrder);
List list = this.list(query);
// 调用wrapTreeDataToTreeList方法生成树状数据
List listResult = SysDepartTreeModel.toTreeList(list);
List treelist = new ArrayList<>();
if (StrUtil.isNotBlank(keyWord)) {
this.getTreeByKeyWord(keyWord, listResult, treelist);
} else {
return listResult;
}
return treelist;
}
@Override
public SysDepart getParentDepartId(String departId) {
return baseMapper.getParentDepartId(departId);
}
@Override
public String queryDepartIdByOrgCode(String orgCode) {
return baseMapper.queryDepartIdByOrgCode(orgCode);
}
@Override
public List getSubDepIdsByOrgCodes(String[] orgCodes) {
return baseMapper.getSubDepIdsByOrgCodes(orgCodes);
}
/**
* 根据关键字筛选部门信息
*/
public void getTreeByKeyWord(String keyWord, List allResult, List newResult) {
for (SysDepartTreeModel model : allResult) {
if (model.getDepartName().contains(keyWord)) {
newResult.add(model);
} else if (model.getChildren() != null) {
getTreeByKeyWord(keyWord, model.getChildren(), newResult);
}
}
}
}