bfcd711748a5f7d71d9a72e5ba1ae35d4f294d0b.svn-base 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566
  1. package org.jeecg.modules.system.service.impl;
  2. import com.alibaba.fastjson.JSONArray;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  6. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  7. import io.netty.util.internal.StringUtil;
  8. import org.apache.commons.lang.StringUtils;
  9. import org.jeecg.common.constant.CacheConstant;
  10. import org.jeecg.common.constant.CommonConstant;
  11. import org.jeecg.common.constant.FillRuleConstant;
  12. import org.jeecg.common.util.FillRuleUtil;
  13. import org.jeecg.common.util.YouBianCodeUtil;
  14. import org.jeecg.common.util.oConvertUtils;
  15. import org.jeecg.modules.system.entity.*;
  16. import org.jeecg.modules.system.mapper.*;
  17. import org.jeecg.modules.system.model.DepartIdModel;
  18. import org.jeecg.modules.system.model.SysDepartTreeModel;
  19. import org.jeecg.modules.system.service.ISysDepartService;
  20. import org.jeecg.modules.system.util.FindsDepartsChildrenUtil;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. import org.springframework.cache.annotation.Cacheable;
  23. import org.springframework.stereotype.Service;
  24. import org.springframework.transaction.annotation.Transactional;
  25. import java.util.*;
  26. /**
  27. * <p>
  28. * 部门表 服务实现类
  29. * <p>
  30. *
  31. * @Author Steve
  32. * @Since 2019-01-22
  33. */
  34. @Service
  35. public class SysDepartServiceImpl extends ServiceImpl<SysDepartMapper, SysDepart> implements ISysDepartService {
  36. @Autowired
  37. private SysUserDepartMapper userDepartMapper;
  38. @Autowired
  39. private SysDepartRoleMapper sysDepartRoleMapper;
  40. @Autowired
  41. private SysDepartPermissionMapper departPermissionMapper;
  42. @Autowired
  43. private SysDepartRolePermissionMapper departRolePermissionMapper;
  44. @Autowired
  45. private SysDepartRoleUserMapper departRoleUserMapper;
  46. @Autowired
  47. private SysUserMapper sysUserMapper;
  48. @Override
  49. public List<SysDepartTreeModel> queryMyDeptTreeList(String departIds) {
  50. //根据部门id获取所负责部门
  51. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  52. String[] codeArr = this.getMyDeptParentOrgCode(departIds);
  53. for(int i=0;i<codeArr.length;i++){
  54. query.or().likeRight(SysDepart::getOrgCode,codeArr[i]);
  55. }
  56. query.eq(SysDepart::getDelFlag, CommonConstant.DEL_FLAG_0.toString());
  57. query.orderByAsc(SysDepart::getDepartOrder);
  58. //将父节点ParentId设为null
  59. List<SysDepart> listDepts = this.list(query);
  60. for(int i=0;i<codeArr.length;i++){
  61. for(SysDepart dept : listDepts){
  62. if(dept.getOrgCode().equals(codeArr[i])){
  63. dept.setParentId(null);
  64. }
  65. }
  66. }
  67. // 调用wrapTreeDataToTreeList方法生成树状数据
  68. List<SysDepartTreeModel> listResult = FindsDepartsChildrenUtil.wrapTreeDataToTreeList(listDepts);
  69. return listResult;
  70. }
  71. /**
  72. * queryTreeList 对应 queryTreeList 查询所有的部门数据,以树结构形式响应给前端
  73. */
  74. @Cacheable(value = CacheConstant.SYS_DEPARTS_CACHE)
  75. @Override
  76. public List<SysDepartTreeModel> queryTreeList() {
  77. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  78. query.eq(SysDepart::getDelFlag, CommonConstant.DEL_FLAG_0.toString());
  79. query.orderByAsc(SysDepart::getDepartOrder);
  80. List<SysDepart> list = this.list(query);
  81. // 调用wrapTreeDataToTreeList方法生成树状数据
  82. List<SysDepartTreeModel> listResult = FindsDepartsChildrenUtil.wrapTreeDataToTreeList(list);
  83. return listResult;
  84. }
  85. @Cacheable(value = CacheConstant.SYS_DEPART_IDS_CACHE)
  86. @Override
  87. public List<DepartIdModel> queryDepartIdTreeList() {
  88. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  89. query.eq(SysDepart::getDelFlag, CommonConstant.DEL_FLAG_0.toString());
  90. query.orderByAsc(SysDepart::getDepartOrder);
  91. List<SysDepart> list = this.list(query);
  92. // 调用wrapTreeDataToTreeList方法生成树状数据
  93. List<DepartIdModel> listResult = FindsDepartsChildrenUtil.wrapTreeDataToDepartIdTreeList(list);
  94. return listResult;
  95. }
  96. /**
  97. * saveDepartData 对应 add 保存用户在页面添加的新的部门对象数据
  98. */
  99. @Override
  100. @Transactional
  101. public void saveDepartData(SysDepart sysDepart, String username) {
  102. if (sysDepart != null && username != null) {
  103. if (sysDepart.getParentId() == null) {
  104. sysDepart.setParentId("");
  105. }
  106. String s = UUID.randomUUID().toString().replace("-", "");
  107. sysDepart.setId(s);
  108. // 先判断该对象有无父级ID,有则意味着不是最高级,否则意味着是最高级
  109. // 获取父级ID
  110. String parentId = sysDepart.getParentId();
  111. //update-begin--Author:baihailong Date:20191209 for:部门编码规则生成器做成公用配置
  112. JSONObject formData = new JSONObject();
  113. formData.put("parentId",parentId);
  114. String[] codeArray = (String[]) FillRuleUtil.executeRule(FillRuleConstant.DEPART,formData);
  115. //update-end--Author:baihailong Date:20191209 for:部门编码规则生成器做成公用配置
  116. sysDepart.setOrgCode(codeArray[0]);
  117. String orgType = codeArray[1];
  118. sysDepart.setOrgType(String.valueOf(orgType));
  119. sysDepart.setCreateTime(new Date());
  120. sysDepart.setDelFlag(CommonConstant.DEL_FLAG_0.toString());
  121. this.save(sysDepart);
  122. }
  123. }
  124. /**
  125. * saveDepartData 的调用方法,生成部门编码和部门类型(作废逻辑)
  126. * @deprecated
  127. * @param parentId
  128. * @return
  129. */
  130. private String[] generateOrgCode(String parentId) {
  131. //update-begin--Author:Steve Date:20190201 for:组织机构添加数据代码调整
  132. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  133. LambdaQueryWrapper<SysDepart> query1 = new LambdaQueryWrapper<SysDepart>();
  134. String[] strArray = new String[2];
  135. // 创建一个List集合,存储查询返回的所有SysDepart对象
  136. List<SysDepart> departList = new ArrayList<>();
  137. // 定义新编码字符串
  138. String newOrgCode = "";
  139. // 定义旧编码字符串
  140. String oldOrgCode = "";
  141. // 定义部门类型
  142. String orgType = "";
  143. // 如果是最高级,则查询出同级的org_code, 调用工具类生成编码并返回
  144. if (StringUtil.isNullOrEmpty(parentId)) {
  145. // 线判断数据库中的表是否为空,空则直接返回初始编码
  146. query1.eq(SysDepart::getParentId, "").or().isNull(SysDepart::getParentId);
  147. query1.orderByDesc(SysDepart::getOrgCode);
  148. departList = this.list(query1);
  149. if(departList == null || departList.size() == 0) {
  150. strArray[0] = YouBianCodeUtil.getNextYouBianCode(null);
  151. strArray[1] = "1";
  152. return strArray;
  153. }else {
  154. SysDepart depart = departList.get(0);
  155. oldOrgCode = depart.getOrgCode();
  156. orgType = depart.getOrgType();
  157. newOrgCode = YouBianCodeUtil.getNextYouBianCode(oldOrgCode);
  158. }
  159. } else { // 反之则查询出所有同级的部门,获取结果后有两种情况,有同级和没有同级
  160. // 封装查询同级的条件
  161. query.eq(SysDepart::getParentId, parentId);
  162. // 降序排序
  163. query.orderByDesc(SysDepart::getOrgCode);
  164. // 查询出同级部门的集合
  165. List<SysDepart> parentList = this.list(query);
  166. // 查询出父级部门
  167. SysDepart depart = this.getById(parentId);
  168. // 获取父级部门的Code
  169. String parentCode = depart.getOrgCode();
  170. // 根据父级部门类型算出当前部门的类型
  171. orgType = String.valueOf(Integer.valueOf(depart.getOrgType()) + 1);
  172. // 处理同级部门为null的情况
  173. if (parentList == null || parentList.size() == 0) {
  174. // 直接生成当前的部门编码并返回
  175. newOrgCode = YouBianCodeUtil.getSubYouBianCode(parentCode, null);
  176. } else { //处理有同级部门的情况
  177. // 获取同级部门的编码,利用工具类
  178. String subCode = parentList.get(0).getOrgCode();
  179. // 返回生成的当前部门编码
  180. newOrgCode = YouBianCodeUtil.getSubYouBianCode(parentCode, subCode);
  181. }
  182. }
  183. // 返回最终封装了部门编码和部门类型的数组
  184. strArray[0] = newOrgCode;
  185. strArray[1] = orgType;
  186. return strArray;
  187. //update-end--Author:Steve Date:20190201 for:组织机构添加数据代码调整
  188. }
  189. /**
  190. * removeDepartDataById 对应 delete方法 根据ID删除相关部门数据
  191. *
  192. */
  193. /*
  194. * @Override
  195. *
  196. * @Transactional public boolean removeDepartDataById(String id) {
  197. * System.out.println("要删除的ID 为=============================>>>>>"+id); boolean
  198. * flag = this.removeById(id); return flag; }
  199. */
  200. /**
  201. * updateDepartDataById 对应 edit 根据部门主键来更新对应的部门数据
  202. */
  203. @Override
  204. @Transactional
  205. public Boolean updateDepartDataById(SysDepart sysDepart, String username) {
  206. if (sysDepart != null && username != null) {
  207. sysDepart.setUpdateTime(new Date());
  208. sysDepart.setUpdateBy(username);
  209. this.updateById(sysDepart);
  210. return true;
  211. } else {
  212. return false;
  213. }
  214. }
  215. @Override
  216. @Transactional(rollbackFor = Exception.class)
  217. public void deleteBatchWithChildren(List<String> ids) {
  218. List<String> idList = new ArrayList<String>();
  219. for(String id: ids) {
  220. idList.add(id);
  221. this.checkChildrenExists(id, idList);
  222. }
  223. this.removeByIds(idList);
  224. //根据部门id获取部门角色id
  225. List<String> roleIdList = new ArrayList<>();
  226. LambdaQueryWrapper<SysDepartRole> query = new LambdaQueryWrapper<>();
  227. query.select(SysDepartRole::getId).in(SysDepartRole::getDepartId, idList);
  228. List<SysDepartRole> depRoleList = sysDepartRoleMapper.selectList(query);
  229. for(SysDepartRole deptRole : depRoleList){
  230. roleIdList.add(deptRole.getId());
  231. }
  232. //根据部门id删除用户与部门关系
  233. userDepartMapper.delete(new LambdaQueryWrapper<SysUserDepart>().in(SysUserDepart::getDepId,idList));
  234. //根据部门id删除部门授权
  235. departPermissionMapper.delete(new LambdaQueryWrapper<SysDepartPermission>().in(SysDepartPermission::getDepartId,idList));
  236. //根据部门id删除部门角色
  237. sysDepartRoleMapper.delete(new LambdaQueryWrapper<SysDepartRole>().in(SysDepartRole::getDepartId,idList));
  238. if(roleIdList != null && roleIdList.size()>0){
  239. //根据角色id删除部门角色授权
  240. departRolePermissionMapper.delete(new LambdaQueryWrapper<SysDepartRolePermission>().in(SysDepartRolePermission::getRoleId,roleIdList));
  241. //根据角色id删除部门角色用户信息
  242. departRoleUserMapper.delete(new LambdaQueryWrapper<SysDepartRoleUser>().in(SysDepartRoleUser::getDroleId,roleIdList));
  243. }
  244. }
  245. @Override
  246. public List<String> getSubDepIdsByDepId(String departId) {
  247. return this.baseMapper.getSubDepIdsByDepId(departId);
  248. }
  249. @Override
  250. public List<String> getMySubDepIdsByDepId(String departIds) {
  251. //根据部门id获取所负责部门
  252. String[] codeArr = this.getMyDeptParentOrgCode(departIds);
  253. return this.baseMapper.getSubDepIdsByOrgCodes(codeArr);
  254. }
  255. /**
  256. * <p>
  257. * 根据关键字搜索相关的部门数据
  258. * </p>
  259. */
  260. @Override
  261. public List<SysDepartTreeModel> searhBy(String keyWord,String myDeptSearch,String departIds) {
  262. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  263. List<SysDepartTreeModel> newList = new ArrayList<>();
  264. //myDeptSearch不为空时为我的部门搜索,只搜索所负责部门
  265. if(!StringUtil.isNullOrEmpty(myDeptSearch)){
  266. //departIds 为空普通用户或没有管理部门
  267. if(StringUtil.isNullOrEmpty(departIds)){
  268. return newList;
  269. }
  270. //根据部门id获取所负责部门
  271. String[] codeArr = this.getMyDeptParentOrgCode(departIds);
  272. for(int i=0;i<codeArr.length;i++){
  273. query.or().likeRight(SysDepart::getOrgCode,codeArr[i]);
  274. }
  275. query.eq(SysDepart::getDelFlag, CommonConstant.DEL_FLAG_0.toString());
  276. }
  277. query.like(SysDepart::getDepartName, keyWord);
  278. //update-begin--Author:huangzhilin Date:20140417 for:[bugfree号]组织机构搜索回显优化--------------------
  279. SysDepartTreeModel model = new SysDepartTreeModel();
  280. List<SysDepart> departList = this.list(query);
  281. if(departList.size() > 0) {
  282. for(SysDepart depart : departList) {
  283. model = new SysDepartTreeModel(depart);
  284. model.setChildren(null);
  285. //update-end--Author:huangzhilin Date:20140417 for:[bugfree号]组织机构搜索功回显优化----------------------
  286. newList.add(model);
  287. }
  288. return newList;
  289. }
  290. return null;
  291. }
  292. /**
  293. * 根据部门id删除并且删除其可能存在的子级任何部门
  294. */
  295. @Override
  296. @Transactional(rollbackFor = Exception.class)
  297. public boolean delete(String id) {
  298. List<String> idList = new ArrayList<>();
  299. idList.add(id);
  300. this.checkChildrenExists(id, idList);
  301. //清空部门树内存
  302. //FindsDepartsChildrenUtil.clearDepartIdModel();
  303. boolean ok = this.removeByIds(idList);
  304. //根据部门id获取部门角色id
  305. List<String> roleIdList = new ArrayList<>();
  306. LambdaQueryWrapper<SysDepartRole> query = new LambdaQueryWrapper<>();
  307. query.select(SysDepartRole::getId).in(SysDepartRole::getDepartId, idList);
  308. List<SysDepartRole> depRoleList = sysDepartRoleMapper.selectList(query);
  309. for(SysDepartRole deptRole : depRoleList){
  310. roleIdList.add(deptRole.getId());
  311. }
  312. //根据部门id删除用户与部门关系
  313. userDepartMapper.delete(new LambdaQueryWrapper<SysUserDepart>().in(SysUserDepart::getDepId,idList));
  314. //根据部门id删除部门授权
  315. departPermissionMapper.delete(new LambdaQueryWrapper<SysDepartPermission>().in(SysDepartPermission::getDepartId,idList));
  316. //根据部门id删除部门角色
  317. sysDepartRoleMapper.delete(new LambdaQueryWrapper<SysDepartRole>().in(SysDepartRole::getDepartId,idList));
  318. if(roleIdList != null && roleIdList.size()>0){
  319. //根据角色id删除部门角色授权
  320. departRolePermissionMapper.delete(new LambdaQueryWrapper<SysDepartRolePermission>().in(SysDepartRolePermission::getRoleId,roleIdList));
  321. //根据角色id删除部门角色用户信息
  322. departRoleUserMapper.delete(new LambdaQueryWrapper<SysDepartRoleUser>().in(SysDepartRoleUser::getDroleId,roleIdList));
  323. }
  324. return ok;
  325. }
  326. /**
  327. * delete 方法调用
  328. * @param id
  329. * @param idList
  330. */
  331. private void checkChildrenExists(String id, List<String> idList) {
  332. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  333. query.eq(SysDepart::getParentId,id);
  334. List<SysDepart> departList = this.list(query);
  335. if(departList != null && departList.size() > 0) {
  336. for(SysDepart depart : departList) {
  337. idList.add(depart.getId());
  338. this.checkChildrenExists(depart.getId(), idList);
  339. }
  340. }
  341. }
  342. @Override
  343. public List<SysDepart> queryUserDeparts(String userId) {
  344. return baseMapper.queryUserDeparts(userId);
  345. }
  346. @Override
  347. public List<SysDepart> queryDepartsByUsername(String username) {
  348. return baseMapper.queryDepartsByUsername(username);
  349. }
  350. /**
  351. * 根据用户所负责部门ids获取父级部门编码
  352. * @param departIds
  353. * @return
  354. */
  355. private String[] getMyDeptParentOrgCode(String departIds){
  356. //根据部门id查询所负责部门
  357. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  358. query.eq(SysDepart::getDelFlag, CommonConstant.DEL_FLAG_0.toString());
  359. query.in(SysDepart::getId, Arrays.asList(departIds.split(",")));
  360. query.orderByAsc(SysDepart::getOrgCode);
  361. List<SysDepart> list = this.list(query);
  362. //查找根部门
  363. if(list == null || list.size()==0){
  364. return null;
  365. }
  366. String orgCode = this.getMyDeptParentNode(list);
  367. String[] codeArr = orgCode.split(",");
  368. return codeArr;
  369. }
  370. /**
  371. * 获取负责部门父节点
  372. * @param list
  373. * @return
  374. */
  375. private String getMyDeptParentNode(List<SysDepart> list){
  376. Map<String,String> map = new HashMap<>();
  377. //1.先将同一公司归类
  378. for(SysDepart dept : list){
  379. String code = dept.getOrgCode().substring(0,3);
  380. if(map.containsKey(code)){
  381. String mapCode = map.get(code)+","+dept.getOrgCode();
  382. map.put(code,mapCode);
  383. }else{
  384. map.put(code,dept.getOrgCode());
  385. }
  386. }
  387. StringBuffer parentOrgCode = new StringBuffer();
  388. //2.获取同一公司的根节点
  389. for(String str : map.values()){
  390. String[] arrStr = str.split(",");
  391. parentOrgCode.append(",").append(this.getMinLengthNode(arrStr));
  392. }
  393. return parentOrgCode.substring(1);
  394. }
  395. /**
  396. * 获取同一公司中部门编码长度最小的部门
  397. * @param str
  398. * @return
  399. */
  400. private String getMinLengthNode(String[] str){
  401. int min =str[0].length();
  402. String orgCode = str[0];
  403. for(int i =1;i<str.length;i++){
  404. if(str[i].length()<=min){
  405. min = str[i].length();
  406. orgCode = orgCode+","+str[i];
  407. }
  408. }
  409. return orgCode;
  410. }
  411. /**
  412. * 获取部门树信息根据关键字
  413. * @param keyWord
  414. * @return
  415. */
  416. @Override
  417. public List<SysDepartTreeModel> queryTreeByKeyWord(String keyWord) {
  418. LambdaQueryWrapper<SysDepart> query = new LambdaQueryWrapper<SysDepart>();
  419. query.eq(SysDepart::getDelFlag, CommonConstant.DEL_FLAG_0.toString());
  420. query.orderByAsc(SysDepart::getDepartOrder);
  421. List<SysDepart> list = this.list(query);
  422. // 调用wrapTreeDataToTreeList方法生成树状数据
  423. List<SysDepartTreeModel> listResult = FindsDepartsChildrenUtil.wrapTreeDataToTreeList(list);
  424. List<SysDepartTreeModel> treelist =new ArrayList<>();
  425. if(StringUtils.isNotBlank(keyWord)){
  426. this.getTreeByKeyWord(keyWord,listResult,treelist);
  427. }else{
  428. return listResult;
  429. }
  430. return treelist;
  431. }
  432. /**
  433. * 根据parentId查询部门树
  434. * @param parentId
  435. * @return
  436. */
  437. @Override
  438. public List<SysDepartTreeModel> queryTreeListByPid(String parentId) {
  439. List<SysDepart> list = this.baseMapper.queryTreeListByPid(parentId);
  440. List<SysDepartTreeModel> records = new ArrayList<>();
  441. for (int i = 0; i < list.size(); i++) {
  442. SysDepart depart = list.get(i);
  443. SysDepartTreeModel treeModel = new SysDepartTreeModel(depart);
  444. //TODO 异步树加载key拼接__+时间戳,以便于每次展开节点会刷新数据
  445. //treeModel.setKey(treeModel.getKey()+"__"+System.currentTimeMillis());
  446. treeModel.setKey(treeModel.getKey());
  447. Integer count=this.baseMapper.queryCountByPid(depart.getId());
  448. if(count>0){
  449. treeModel.setIsLeaf(false);
  450. }else{
  451. treeModel.setIsLeaf(true);
  452. }
  453. records.add(treeModel);
  454. }
  455. return records;
  456. }
  457. @Override
  458. public JSONObject queryAllParentIdByDepartId(String departId) {
  459. JSONObject result = new JSONObject();
  460. for (String id : departId.split(",")) {
  461. JSONObject all = this.queryAllParentId("id", id);
  462. result.put(id, all);
  463. }
  464. return result;
  465. }
  466. @Override
  467. public JSONObject queryAllParentIdByOrgCode(String orgCode) {
  468. JSONObject result = new JSONObject();
  469. for (String code : orgCode.split(",")) {
  470. JSONObject all = this.queryAllParentId("org_code", code);
  471. result.put(code, all);
  472. }
  473. return result;
  474. }
  475. /**
  476. * 查询某个部门的所有父ID信息
  477. *
  478. * @param fieldName 字段名
  479. * @param value 值
  480. */
  481. private JSONObject queryAllParentId(String fieldName, String value) {
  482. JSONObject data = new JSONObject();
  483. // 父ID集合,有序
  484. data.put("parentIds", new JSONArray());
  485. // 父ID的部门数据,key是id,value是数据
  486. data.put("parentMap", new JSONObject());
  487. this.queryAllParentIdRecursion(fieldName, value, data);
  488. return data;
  489. }
  490. /**
  491. * 递归调用查询父部门接口
  492. */
  493. private void queryAllParentIdRecursion(String fieldName, String value, JSONObject data) {
  494. QueryWrapper<SysDepart> queryWrapper = new QueryWrapper<>();
  495. queryWrapper.eq(fieldName, value);
  496. SysDepart depart = super.getOne(queryWrapper);
  497. if (depart != null) {
  498. data.getJSONArray("parentIds").add(0, depart.getId());
  499. data.getJSONObject("parentMap").put(depart.getId(), depart);
  500. if (oConvertUtils.isNotEmpty(depart.getParentId())) {
  501. this.queryAllParentIdRecursion("id", depart.getParentId(), data);
  502. }
  503. }
  504. }
  505. @Override
  506. public SysDepart queryCompByOrgCode(String orgCode) {
  507. int length = YouBianCodeUtil.zhanweiLength;
  508. String compyOrgCode = orgCode.substring(0,length);
  509. return this.baseMapper.queryCompByOrgCode(compyOrgCode);
  510. }
  511. /**
  512. * 根据id查询下级部门
  513. * @param pid
  514. * @return
  515. */
  516. @Override
  517. public List<SysDepart> queryDeptByPid(String pid) {
  518. return this.baseMapper.queryDeptByPid(pid);
  519. }
  520. /**
  521. * 根据关键字筛选部门信息
  522. * @param keyWord
  523. * @return
  524. */
  525. public void getTreeByKeyWord(String keyWord,List<SysDepartTreeModel> allResult,List<SysDepartTreeModel> newResult){
  526. for (SysDepartTreeModel model:allResult) {
  527. if (model.getDepartName().contains(keyWord)){
  528. newResult.add(model);
  529. continue;
  530. }else if(model.getChildren()!=null){
  531. getTreeByKeyWord(keyWord,model.getChildren(),newResult);
  532. }
  533. }
  534. }
  535. }