package com.vci.frameworkcore.compatibility; import com.vci.dto.OrgDepartmentDTO; import com.vci.corba.common.PLException; import com.vci.pagemodel.OrgDepartmentVO; import com.vci.starter.web.exception.VciBaseException; import com.vci.starter.web.pagemodel.*; import java.io.File; import java.util.Collection; import java.util.List; import java.util.Map; /** * 部门的查询服务,兼容老平台 * @author weidy * @date 2020/3/1 */ public interface OrgDeptQueryServiceI { /** * 根据部门主键获取部门的信息 * @param deptOid 部门主键 * @return 部门的显示对象,如果部门不存在则返回null,不会抛出异常 * @throws VciBaseException 参数为空或者数据库存在问题的时候会抛出异常 */ OrgDepartmentVO getDeptByDeptOid(String deptOid) throws VciBaseException; /** * 根据父部门主键获取和部门名称部门的信息 * @param parentDeptOid 父部门主键 * @param conditionMap 查询条件 * @return 部门的显示对象,如果部门不存在则返回null,不会抛出异常 * @throws VciBaseException 参数为空或者数据库存在问题的时候会抛出异常 */ List getDeptByDeptPOidAndCondition(String parentDeptOid,Map conditionMap) throws VciBaseException; /** * 批量获取部门的信息 (根据部门主键) * @param deptOidCollections 部门主键的集合,可以超过1000个 * @return 部门的显示对象,如果部门不存在则返回空的列表,不会抛出异常 * @throws VciBaseException 参数为空或者数据库存在问题的时候会抛出异常 */ List listDeptByDeptOids(Collection deptOidCollections) throws VciBaseException; /** * 获取部门的列表,默认会以部门名称升序排列,部门的编辑页面列表不要使用这个接口 * @param queryMap 查询条件 * @param pageHelper 分页和排序的信息,在兼容老平台的时候会自动兼容,如果属性不存在会自动忽略 * @return 部门的显示对象列表 * @throws VciBaseException 参数为空的时候会抛出异常 */ DataGrid gridDepts(Map queryMap, PageHelper pageHelper) throws VciBaseException; /** * 根据部门主键获取部门的姓名 * @param deptOid 部门主键 * @return 部门姓名,如果不存在会返回null */ String getDeptNameByDeptOid(String deptOid); /** * 根据用户主键获取关联的部门 * @param userOid 用户主键 * @param queryMap 查询条件,如果需要使用用户的属性来查询可以使用pkUser.xxxx * @return 部门的显示对象 */ List listDeptByUserOid(String userOid, Map queryMap); /** * 获取未关联某个用户的部门 * @param userOid 用户主键 * @param queryMap 查询条件,如果需要使用用户的属性来查询可以使用pkUser.xxxx * @return 部门的显示对象 */ List listDeptUnInUserOid(String userOid, Map queryMap); /** * 获取未关联某个用户的部门 * @param userOid 用户主键 * @param queryMap 查询条件,如果需要使用用户的属性来查询可以使用pkUser.xxxx * @param pageHelper 分页和排序对象,老平台不支持使用部门编号来排序 * @return 部门的显示对象 */ DataGrid gridDeptUninUserOid(String userOid, Map queryMap, PageHelper pageHelper); /** * 批量根据用户的主键来获取部门 * @param userOidCollection 用户主键集合 * @param queryMap 查询条件,如果需要使用用户的属性来查询可以使用pkUser.xxxx * @return 部门的显示对象,key是用户主键,value是关联的部门 */ Map> batchListDeptByUserOids(Collection userOidCollection, Map queryMap); /** * 批量根据用户的主键来获取部门名称(/间隔方式) * @param userOidCollection 用户主键集合 * @param queryMap 查询条件,如果需要使用用户的属性来查询可以使用pkUser.xxxx * @return 部门的显示对象,key是用户主键,value是关联的部门(key:关联的部门oid,value:包含父节点如当前部门为人力资源部则值为:550/人力资源部) */ Map> batchMapDeptNameByUserOids(Collection userOidCollection, Map queryMap); /** * 获取某个部门的直属下级部门 * @param pkFatherDepartmment 部门的主键 * @param queryMap 查询条件 * @return 部门显示对象 */ List listChildrenDeptByParentOid(String pkFatherDepartmment, Map queryMap); /** * 获取某个部门的所有层级的下级部门 * @param pkFatherDepartmment 部门的主键 * @param queryMap 查询条件 * @return 部门显示对象 */ List listAllLevelChildrenDeptByParentOid(String pkFatherDepartmment, Map queryMap); /** * 参照树形数据的部门信息 * @param treeQueryObject 树形查询的条件 * @return 树节点 */ List refTreeDept(TreeQueryObject treeQueryObject); /** * 参照树形表格的部门信息,上级部门的是表格中的树形列 * @param treeQueryObject 树形查询的条件 * @return 部门的树表信息 */ DataGrid refTreeGridDept(TreeQueryObject treeQueryObject); /** * 保存部门角色关联信息,带查重功能,多对多保存 * @param userOIds 用户id * @param deptId 部门oid * @return */ boolean saveUsersDept(String[] userOIds, String deptId) throws PLException; /** * 增加部门信息 * @param orgDepartmentDTO * @return */ boolean addDept(OrgDepartmentDTO orgDepartmentDTO) throws PLException; /** * 修改部门信息 * @param orgDepartmentDTO * @return */ boolean updateDept(OrgDepartmentDTO orgDepartmentDTO) throws PLException; /** * 删除部门 * @param ids * @return */ boolean deleteDept(String[] ids) throws PLException; /** * 获取所有部门的信息 * @return key:部门由名称组成的路径(/间隔),value对应最小层级的部门信息 */ Map getDeptAllTreeMap(); /** * 下载导入部门的excel模板。 * @param downloadFileName * @return */ String downloadImportTemplate(String downloadFileName); /** * 导入部门 * @param file * @return * @throws VciBaseException */ BaseResult importDept(File file) throws Exception; }