|
@@ -14,9 +14,13 @@ package vip.xiaonuo.modular.base.department.service.impl;
|
|
|
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
import cn.hutool.core.collection.CollStreamUtil;
|
|
|
+import cn.hutool.core.lang.tree.Tree;
|
|
|
+import cn.hutool.core.lang.tree.TreeNode;
|
|
|
+import cn.hutool.core.lang.tree.TreeUtil;
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
import cn.hutool.core.util.StrUtil;
|
|
|
import cn.hutool.json.JSONUtil;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
@@ -24,6 +28,7 @@ import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
import org.springframework.web.multipart.MultipartFile;
|
|
|
+import vip.xiaonuo.auth.core.pojo.SaBaseLoginUser;
|
|
|
import vip.xiaonuo.auth.core.util.StpLoginUserUtil;
|
|
|
import vip.xiaonuo.common.enums.CommonSortOrderEnum;
|
|
|
import vip.xiaonuo.common.exception.CommonException;
|
|
@@ -32,19 +37,19 @@ import vip.xiaonuo.common.page.CommonPageRequest;
|
|
|
import vip.xiaonuo.core.enums.BaseDataTypeEnum;
|
|
|
import vip.xiaonuo.dev.modular.file.enums.DevFileEngineTypeEnum;
|
|
|
import vip.xiaonuo.dev.modular.file.service.DevFileService;
|
|
|
+import vip.xiaonuo.modular.base.baseConfig.entity.BaseConfig;
|
|
|
import vip.xiaonuo.modular.base.department.entity.Department;
|
|
|
import vip.xiaonuo.modular.base.department.mapper.DepartmentMapper;
|
|
|
-import vip.xiaonuo.modular.base.department.param.DepartmentAddParam;
|
|
|
-import vip.xiaonuo.modular.base.department.param.DepartmentEditParam;
|
|
|
-import vip.xiaonuo.modular.base.department.param.DepartmentIdParam;
|
|
|
-import vip.xiaonuo.modular.base.department.param.DepartmentPageParam;
|
|
|
+import vip.xiaonuo.modular.base.department.param.*;
|
|
|
import vip.xiaonuo.modular.base.department.service.DepartmentService;
|
|
|
import vip.xiaonuo.sys.core.enums.SysDataTypeEnum;
|
|
|
import vip.xiaonuo.sys.modular.user.entity.SysUser;
|
|
|
import vip.xiaonuo.sys.modular.user.mapper.SysUserMapper;
|
|
|
|
|
|
import javax.validation.constraints.NotBlank;
|
|
|
+import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* 部门Service接口实现类
|
|
@@ -61,6 +66,22 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
|
|
|
@Autowired
|
|
|
private DevFileService devFileService;
|
|
|
|
|
|
+
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public List<Tree<String>> tree() {
|
|
|
+ String orgId = StpLoginUserUtil.getLoginUser().getOrgId();
|
|
|
+ List<Department> allDepartment= new ArrayList<>();
|
|
|
+ List<Department> baseConfigs = this.list(new LambdaQueryWrapper<Department>().eq(Department::getOrgId, orgId).orderByAsc(Department::getSortCode));
|
|
|
+
|
|
|
+ allDepartment.addAll(baseConfigs);
|
|
|
+ List<TreeNode<String>> treeNodeList = allDepartment.stream().map(department ->
|
|
|
+ new TreeNode<>(department.getId(), department.getParentId(),
|
|
|
+ department.getDepartmentName(), department.getSortCode()).setExtra(JSONUtil.parseObj(department)))
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ return TreeUtil.build(treeNodeList, "0");
|
|
|
+ }
|
|
|
+
|
|
|
@Override
|
|
|
public Page<Department> page(DepartmentPageParam departmentPageParam) {
|
|
|
QueryWrapper<Department> queryWrapper = new QueryWrapper<>();
|
|
@@ -71,6 +92,12 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
|
|
|
} else {
|
|
|
queryWrapper.lambda().orderByAsc(Department::getSortCode);
|
|
|
}
|
|
|
+ if (ObjectUtil.isNotEmpty(departmentPageParam.getParentId())){
|
|
|
+ queryWrapper.lambda().eq(Department::getParentId,departmentPageParam.getParentId());
|
|
|
+ }
|
|
|
+ if (ObjectUtil.isNotEmpty(departmentPageParam.getSearchKey())){
|
|
|
+ queryWrapper.lambda().eq(Department::getDepartmentName,departmentPageParam.getSearchKey());
|
|
|
+ }
|
|
|
return this.page(CommonPageRequest.defaultPage(), queryWrapper);
|
|
|
}
|
|
|
|
|
@@ -90,8 +117,8 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
|
|
|
department.setRemarks(remarks);
|
|
|
department.setSortCode(sortCode);
|
|
|
if (ObjectUtil.isNotEmpty(departmentImgUrl)){
|
|
|
- String uploadReturnUrl = devFileService.uploadReturnUrl(DevFileEngineTypeEnum.LOCAL.getValue(), departmentImgUrl);
|
|
|
- department.setDepartmentImgUrl(uploadReturnUrl);
|
|
|
+ String uploadReturnUrl = devFileService.uploadReturnId(DevFileEngineTypeEnum.LOCAL.getValue(), departmentImgUrl);
|
|
|
+ department.setDepartmentImgId(uploadReturnUrl);
|
|
|
}
|
|
|
this.save(department);
|
|
|
|
|
@@ -115,8 +142,8 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
|
|
|
department.setRemarks(remarks);
|
|
|
department.setSortCode(sortCode);
|
|
|
if (ObjectUtil.isNotEmpty(departmentImgUrl)){
|
|
|
- String uploadReturnUrl = devFileService.uploadReturnUrl(DevFileEngineTypeEnum.LOCAL.getValue(), departmentImgUrl);
|
|
|
- department.setDepartmentImgUrl(uploadReturnUrl);
|
|
|
+ String uploadReturnUrl = devFileService.uploadReturnId(DevFileEngineTypeEnum.LOCAL.getValue(), departmentImgUrl);
|
|
|
+ department.setDepartmentImgId(uploadReturnUrl);
|
|
|
}
|
|
|
this.updateById(department);
|
|
|
|
|
@@ -158,9 +185,18 @@ public class DepartmentServiceImpl extends ServiceImpl<DepartmentMapper, Departm
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public List<Department> departmentSelector() {
|
|
|
+ public Page<Department> listChild(DepartmentChildParam departmentChildParam) {
|
|
|
String orgId = StpLoginUserUtil.getLoginUser().getOrgId();
|
|
|
- List<Department> departmentList = this.list(new QueryWrapper<Department>().lambda().eq(Department::getOrgId, orgId));
|
|
|
+ Page<Department> departmentList = this.page(CommonPageRequest.defaultPage(),new QueryWrapper<Department>().lambda().eq(Department::getOrgId, orgId).eq(Department::getParentId,departmentChildParam.getParentId()));
|
|
|
return departmentList;
|
|
|
}
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public List<SysUser> userSelector() {
|
|
|
+ String orgId = StpLoginUserUtil.getLoginUser().getOrgId();
|
|
|
+ List<SysUser> users = sysUserMapper.selectList(new QueryWrapper<SysUser>().eq("ORG_ID", orgId));
|
|
|
+ return users;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
}
|