/*
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
|
*
|
* Redistribution and use in source and binary forms, with or without
|
* modification, are permitted provided that the following conditions are met:
|
*
|
* Redistributions of source code must retain the above copyright notice,
|
* this list of conditions and the following disclaimer.
|
* Redistributions in binary form must reproduce the above copyright
|
* notice, this list of conditions and the following disclaimer in the
|
* documentation and/or other materials provided with the distribution.
|
* Neither the name of the dreamlu.net developer nor the names of its
|
* contributors may be used to endorse or promote products derived from
|
* this software without specific prior written permission.
|
* Author: Chill 庄骞 (smallchill@163.com)
|
*/
|
package org.springblade.modules.system.service.impl;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import org.springblade.common.cache.SysCache;
|
import org.springblade.common.node.TreeStringNode;
|
import org.springblade.common.utils.SpringUtils;
|
import org.springblade.core.log.exception.ServiceException;
|
import org.springblade.core.secure.utils.AuthUtil;
|
import org.springblade.core.tool.constant.BladeConstant;
|
import org.springblade.core.tool.node.ForestNodeMerger;
|
import org.springblade.core.tool.utils.BeanUtil;
|
import org.springblade.core.tool.utils.Func;
|
import org.springblade.core.tool.utils.StringPool;
|
import org.springblade.modules.grid.entity.GridEntity;
|
import org.springblade.modules.grid.service.IGridService;
|
import org.springblade.modules.property.entity.PropertyCompanyEntity;
|
import org.springblade.modules.property.service.IPropertyCompanyService;
|
import org.springblade.modules.system.entity.Dept;
|
import org.springblade.modules.system.mapper.DeptMapper;
|
import org.springblade.modules.system.service.IDeptService;
|
import org.springblade.modules.system.service.IRegionService;
|
import org.springblade.modules.system.vo.DeptDetailVO;
|
import org.springblade.modules.system.vo.DeptVO;
|
import org.springblade.modules.system.wrapper.DeptWrapper;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
import org.springframework.transaction.annotation.Transactional;
|
|
import java.util.List;
|
import java.util.Map;
|
import java.util.stream.Collectors;
|
|
/**
|
* 服务实现类
|
*
|
* @author Chill
|
*/
|
@Service
|
public class DeptServiceImpl extends ServiceImpl<DeptMapper, Dept> implements IDeptService {
|
private static final String TENANT_ID = "tenantId";
|
private static final String PARENT_ID = "parentId";
|
|
@Autowired
|
private IPropertyCompanyService propertyCompanyService;
|
|
@Autowired
|
private IRegionService regionService;
|
|
@Override
|
public List<DeptVO> lazyList(String tenantId, Long parentId, Map<String, Object> param) {
|
// 设置租户ID
|
if (AuthUtil.isAdministrator()) {
|
tenantId = StringPool.EMPTY;
|
}
|
String paramTenantId = Func.toStr(param.get(TENANT_ID));
|
if (Func.isNotEmpty(paramTenantId) && AuthUtil.isAdministrator()) {
|
tenantId = paramTenantId;
|
}
|
// 判断点击搜索但是没有查询条件的情况
|
if (Func.isEmpty(param.get(PARENT_ID)) && param.size() == 1) {
|
parentId = 0L;
|
}
|
// 判断数据权限控制,非超管角色只可看到本级及以下数据
|
if (Func.toLong(parentId) == 0L && !AuthUtil.isAdministrator()) {
|
Long deptId = Func.firstLong(AuthUtil.getDeptId());
|
Dept dept = SysCache.getDept(deptId);
|
if (dept.getParentId() != 0) {
|
parentId = dept.getParentId();
|
}
|
List<DeptVO> deptVOS = baseMapper.lazyList(tenantId, parentId, param);
|
deptVOS = deptVOS.stream().filter(item -> AuthUtil.getDeptId().contains(item.getId().toString())).collect(Collectors.toList());
|
return deptVOS;
|
}
|
// 判断点击搜索带有查询条件的情况
|
if (Func.isEmpty(param.get(PARENT_ID)) && param.size() > 1 && Func.toLong(parentId) == 0L) {
|
parentId = null;
|
}
|
return baseMapper.lazyList(tenantId, parentId, param);
|
}
|
|
@Override
|
public List<DeptVO> tree(String tenantId) {
|
Long id = null;
|
// 判断数据权限控制,非超管角色只可看到本级及以下数据
|
if (!AuthUtil.isAdmin()) {
|
id = Func.firstLong(AuthUtil.getDeptId());
|
}
|
List<DeptVO> tree = baseMapper.tree(tenantId, id);
|
return ForestNodeMerger.merge(tree);
|
}
|
|
@Override
|
public List<DeptVO> lazyTree(String tenantId, Long parentId) {
|
if (AuthUtil.isAdministrator()) {
|
tenantId = StringPool.EMPTY;
|
}
|
// 判断数据权限控制,非超管角色只可看到本级及以下数据
|
// if (Func.toLong(parentId) == 0L && !AuthUtil.isAdministrator()) {
|
// Long deptId = Func.firstLong(AuthUtil.getDeptId());
|
// Dept dept = SysCache.getDept(deptId);
|
// if (dept.getParentId() != 0) {
|
// parentId = dept.getParentId();
|
// }
|
// }
|
if (Func.toLong(parentId) == 0L && !AuthUtil.isAdmin()) {
|
Long deptId = Func.firstLong(AuthUtil.getDeptId());
|
Dept dept = SysCache.getDept(deptId);
|
if (dept.getParentId() != 0) {
|
parentId = dept.getParentId();
|
}
|
List<DeptVO> merge = ForestNodeMerger.merge(baseMapper.lazyTree(tenantId, parentId));
|
List<DeptVO> copy = BeanUtil.copy(merge, DeptVO.class);
|
copy = copy.stream().filter(item -> AuthUtil.getDeptId().contains(item.getId().toString())).collect(Collectors.toList());
|
return copy;
|
}
|
return ForestNodeMerger.merge(baseMapper.lazyTree(tenantId, parentId));
|
}
|
|
@Override
|
public String getDeptIds(String tenantId, String deptNames) {
|
List<Dept> deptList = baseMapper.selectList(Wrappers.<Dept>query().lambda().eq(Dept::getTenantId, tenantId).in(Dept::getDeptName, Func.toStrList(deptNames)));
|
if (deptList != null && deptList.size() > 0) {
|
return deptList.stream().map(dept -> Func.toStr(dept.getId())).distinct().collect(Collectors.joining(","));
|
}
|
return null;
|
}
|
|
@Override
|
public String getDeptIdsByFuzzy(String tenantId, String deptNames) {
|
LambdaQueryWrapper<Dept> queryWrapper = Wrappers.<Dept>query().lambda().eq(Dept::getTenantId, tenantId);
|
queryWrapper.and(wrapper -> {
|
List<String> names = Func.toStrList(deptNames);
|
names.forEach(name -> wrapper.like(Dept::getDeptName, name).or());
|
});
|
List<Dept> deptList = baseMapper.selectList(queryWrapper);
|
if (deptList != null && deptList.size() > 0) {
|
return deptList.stream().map(dept -> Func.toStr(dept.getId())).distinct().collect(Collectors.joining(","));
|
}
|
return null;
|
}
|
|
@Override
|
public List<String> getDeptNames(String deptIds) {
|
return baseMapper.getDeptNames(Func.toLongArray(deptIds));
|
}
|
|
@Override
|
public List<Dept> getDeptChild(Long deptId) {
|
return baseMapper.selectList(Wrappers.<Dept>query().lambda().like(Dept::getAncestors, deptId));
|
}
|
|
@Override
|
@Transactional(rollbackFor = Exception.class)
|
public boolean removeDept(String ids) {
|
Long cnt = baseMapper.selectCount(Wrappers.<Dept>query().lambda().in(Dept::getParentId, Func.toLongList(ids)));
|
if (cnt > 0L) {
|
throw new ServiceException("请先删除子节点!");
|
}
|
List<Long> longs = Func.toLongList(ids);
|
// 遍历
|
for (Long id : longs) {
|
// 查询当前机构信息
|
DeptVO dept = baseMapper.getDeptById(id);
|
// 如果父机构为物业公司
|
if (dept.getParentName().equals("物业公司")) {
|
// 删除
|
propertyCompanyService.remove(Wrappers.<PropertyCompanyEntity>update().lambda().eq(PropertyCompanyEntity::getDeptId, id));
|
}
|
}
|
return removeByIds(longs);
|
}
|
|
@Override
|
public boolean submit(Dept dept) {
|
deptHandle(dept);
|
// 保存并返回
|
return saveOrUpdate(dept);
|
}
|
|
/**
|
* 机构信息处理
|
*
|
* @param dept
|
*/
|
private void deptHandle(Dept dept) {
|
if (Func.isEmpty(dept.getParentId())) {
|
dept.setTenantId(AuthUtil.getTenantId());
|
dept.setParentId(BladeConstant.TOP_PARENT_ID);
|
dept.setAncestors(String.valueOf(BladeConstant.TOP_PARENT_ID));
|
}
|
if (dept.getParentId() > 0) {
|
Dept parent = getById(dept.getParentId());
|
if (Func.toLong(dept.getParentId()) == Func.toLong(dept.getId())) {
|
throw new ServiceException("父节点不可选择自身!");
|
}
|
dept.setTenantId(parent.getTenantId());
|
String ancestors = parent.getAncestors() + StringPool.COMMA + dept.getParentId();
|
dept.setAncestors(ancestors);
|
}
|
dept.setIsDeleted(BladeConstant.DB_NOT_DELETED);
|
}
|
|
/**
|
* 自定义新增或修改
|
*
|
* @param dept
|
* @return
|
*/
|
@Override
|
@Transactional(rollbackFor = Exception.class)
|
public boolean saveOrUpdateDeptInfo(Dept dept) {
|
boolean flag = false;
|
deptHandle(dept);
|
// 判断类型,如果为物业公司(上级机构名称为物业公司),名称不能重复
|
QueryWrapper<Dept> queryWrapper = new QueryWrapper<>();
|
queryWrapper.eq("is_deleted", 0).eq("id", dept.getParentId());
|
Dept parentDept = getOne(queryWrapper);
|
// 如果父机构为物业公司
|
if (parentDept != null && parentDept.getDeptName().equals("物业公司")) {
|
// 查询当前
|
QueryWrapper<Dept> wrapper = new QueryWrapper<>();
|
wrapper.eq("is_deleted", 0)
|
.eq("dept_name", dept.getDeptName());
|
Dept one = getOne(wrapper);
|
if (null != one) {
|
dept.setId(one.getId());
|
flag = updateById(dept);
|
} else {
|
if (dept.getId() > 0) {
|
flag = updateById(dept);
|
} else {
|
flag = save(dept);
|
}
|
}
|
//保存物业公司信息
|
savePropertyCompany(dept);
|
} else {
|
flag = saveOrUpdate(dept);
|
}
|
// 保存并返回
|
return flag;
|
}
|
|
/**
|
* 保存物业公司信息
|
*
|
* @param dept
|
*/
|
@Transactional(rollbackFor = Exception.class)
|
public void savePropertyCompany(Dept dept) {
|
// 查询物业公司是否存在
|
QueryWrapper<PropertyCompanyEntity> wrapper = new QueryWrapper<>();
|
wrapper.eq("is_deleted", 0)
|
.eq("dept_id", dept.getId())
|
.eq("name", dept.getDeptName());
|
PropertyCompanyEntity propertyCompanyEntity = propertyCompanyService.getOne(wrapper);
|
if (null != propertyCompanyEntity) {
|
// 修改
|
propertyCompanyEntity.setDeptId(dept.getId());
|
propertyCompanyEntity.setName(dept.getDeptName());
|
// 往物业公司表中插入一条数据
|
propertyCompanyService.updateById(propertyCompanyEntity);
|
} else {
|
// 新增
|
PropertyCompanyEntity companyEntity = new PropertyCompanyEntity();
|
companyEntity.setDeptId(dept.getId());
|
companyEntity.setName(dept.getDeptName());
|
// 往物业公司表中插入一条数据
|
propertyCompanyService.save(companyEntity);
|
}
|
}
|
|
@Override
|
public List<DeptVO> search(String deptName, Long parentId) {
|
String tenantId = AuthUtil.getTenantId();
|
LambdaQueryWrapper<Dept> queryWrapper = Wrappers.<Dept>query().lambda();
|
if (Func.isNotEmpty(tenantId)) {
|
queryWrapper.eq(Dept::getTenantId, tenantId);
|
}
|
if (Func.isNotEmpty(deptName)) {
|
queryWrapper.like(Dept::getDeptName, deptName);
|
}
|
if (Func.isNotEmpty(parentId) && parentId > 0L) {
|
queryWrapper.eq(Dept::getParentId, parentId);
|
}
|
List<Dept> deptList = baseMapper.selectList(queryWrapper);
|
return DeptWrapper.build().listNodeVO(deptList);
|
}
|
|
/**
|
* 数据处理(社区绑定)
|
*/
|
@Override
|
@Transactional(rollbackFor = Exception.class)
|
public Object dataHandle() {
|
// 查询未绑定的网格
|
List<TreeStringNode> list = regionService.getTree(null);
|
// 遍历
|
for (TreeStringNode treeStringNode : list) {
|
// 查询是否已创建
|
QueryWrapper<Dept> wrapper = new QueryWrapper<>();
|
wrapper.eq("is_deleted", 0).eq("dept_name", treeStringNode.getName());
|
Dept one = getOne(wrapper);
|
if (null == one) {
|
// 新增
|
Dept dept = new Dept();
|
dept.setParentId(1733066387113734145L);
|
dept.setFullName(treeStringNode.getName());
|
dept.setDeptName(treeStringNode.getName());
|
dept.setDeptCategory(1);
|
dept.setTenantId("000000");
|
// 新增
|
save(dept);
|
}
|
}
|
return null;
|
}
|
|
/**
|
* 数据处理(区域网格编号绑定)
|
*/
|
@Override
|
@Transactional(rollbackFor = Exception.class)
|
public Object dataRegionGridCodeBindHandle() {
|
// 查询网格对应的机构信息(包含父级机构名称)
|
List<DeptVO> deptVOS = baseMapper.getGridDeptAndParentList();
|
//遍历处理
|
for (DeptVO deptVO : deptVOS) {
|
GridEntity gridEntity = SpringUtils.getBean(IGridService.class).getGridByNames(deptVO.getDeptName(), deptVO.getParentName());
|
if (null != gridEntity) {
|
deptVO.setRegionCode(gridEntity.getGridCode());
|
// 更新
|
updateById(deptVO);
|
}
|
}
|
return null;
|
}
|
}
|