package com.engine.organization.service.impl ;
import com.api.browser.bean.SearchConditionGroup ;
import com.api.browser.bean.SearchConditionItem ;
import com.api.browser.bean.SearchConditionOption ;
import com.api.hrm.bean.HrmFieldBean ;
import com.api.hrm.util.HrmFieldSearchConditionComInfo ;
import com.cloudstore.eccom.pc.table.WeaTableColumn ;
import com.cloudstore.eccom.result.WeaResultMsg ;
import com.engine.common.util.ServiceUtil ;
import com.engine.core.impl.Service ;
import com.engine.hrm.entity.RuleCodeType ;
import com.engine.hrm.service.impl.OrganizationServiceImpl ;
import com.engine.organization.component.OrganizationWeaTable ;
import com.engine.organization.entity.codesetting.po.CodeRulePO ;
import com.engine.organization.entity.company.bo.CompanyBO ;
import com.engine.organization.entity.company.po.CompanyPO ;
import com.engine.organization.entity.department.bo.DepartmentBO ;
import com.engine.organization.entity.department.dto.DepartmentListDTO ;
import com.engine.organization.entity.department.param.* ;
import com.engine.organization.entity.department.po.DepartmentPO ;
import com.engine.organization.entity.department.vo.SingleDeptTreeVO ;
import com.engine.organization.entity.extend.po.ExtendTitlePO ;
import com.engine.organization.entity.job.bo.JobBO ;
import com.engine.organization.entity.job.po.JobPO ;
import com.engine.organization.entity.job.vo.SingleJobTreeVO ;
import com.engine.organization.entity.map.JclOrgMap ;
import com.engine.organization.entity.searchtree.SearchTree ;
import com.engine.organization.entity.searchtree.SearchTreeParams ;
import com.engine.organization.enums.LogModuleNameEnum ;
import com.engine.organization.enums.ModuleTypeEnum ;
import com.engine.organization.enums.OperateTypeEnum ;
import com.engine.organization.exception.OrganizationRunTimeException ;
import com.engine.organization.mapper.codesetting.CodeRuleMapper ;
import com.engine.organization.mapper.comp.CompanyMapper ;
import com.engine.organization.mapper.department.DepartmentMapper ;
import com.engine.organization.mapper.extend.ExtDTMapper ;
import com.engine.organization.mapper.extend.ExtMapper ;
import com.engine.organization.mapper.extend.ExtendTitleMapper ;
import com.engine.organization.mapper.jclorgmap.JclOrgMapper ;
import com.engine.organization.mapper.job.JobMapper ;
import com.engine.organization.service.DepartmentService ;
import com.engine.organization.service.ExtService ;
import com.engine.organization.thread.JobTriggerRunnable ;
import com.engine.organization.thread.OrganizationSyncEc ;
import com.engine.organization.util.* ;
import com.engine.organization.util.coderule.CodeRuleUtil ;
import com.engine.organization.util.db.MapperProxyFactory ;
import com.engine.organization.util.detach.DetachUtil ;
import com.engine.organization.util.page.Column ;
import com.engine.organization.util.page.PageInfo ;
import com.engine.organization.util.page.PageUtil ;
import com.engine.organization.util.relation.EcHrmRelationUtil ;
import com.engine.organization.util.tree.SearchTreeUtil ;
import com.google.common.collect.Lists ;
import org.apache.commons.collections4.CollectionUtils ;
import org.apache.commons.lang.StringUtils ;
import weaver.conn.RecordSet ;
import weaver.general.StringUtil ;
import weaver.general.Util ;
import weaver.hrm.User ;
import weaver.hrm.company.DepartmentComInfo ;
import weaver.hrm.definedfield.HrmDeptFieldManagerE9 ;
import weaver.hrm.definedfield.HrmFieldComInfo ;
import weaver.hrm.definedfield.HrmFieldGroupComInfo ;
import weaver.systeminfo.SystemEnv ;
import java.util.* ;
import java.util.stream.Collectors ;
/ * *
* @Author weaver_cl
* @description :
* @Date 2022 / 5 / 20
* @Version V1 .0
* * /
public class DepartmentServiceImpl extends Service implements DepartmentService {
/ * *
* 分 组 类 型
* 1 : 分 部
* 2 : 部 门
* 3 : 岗 位
* /
private static final String EXTEND_TYPE = "2" ;
/ * *
* 主 表
* /
private static final String JCL_ORG_DEPT = "JCL_ORG_DEPT" ;
/ * *
* 主 表 拓 展 表
* /
private static final String JCL_ORG_DEPTEXT = "JCL_ORG_DEPTEXT" ;
/ * *
* 明 细 表 拓 展 表
* /
private static final String JCL_ORG_DEPTEXT_DT1 = "JCL_ORG_DEPTEXT_DT1" ;
private static final String RIGHT_NAME = "Department:All" ;
/ * *
* 部 门 主 表 title 指 定 ID
* /
private static final Long GROUP_ID = 2L ;
private static DepartmentMapper getDepartmentMapper ( ) {
return MapperProxyFactory . getProxy ( DepartmentMapper . class ) ;
}
private static JobMapper getJobMapper ( ) {
return MapperProxyFactory . getProxy ( JobMapper . class ) ;
}
private CompanyMapper getCompanyMapper ( ) {
return MapperProxyFactory . getProxy ( CompanyMapper . class ) ;
}
private ExtendTitleMapper getExtendTitleMapper ( ) {
return MapperProxyFactory . getProxy ( ExtendTitleMapper . class ) ;
}
private ExtService getExtService ( User user ) {
return ServiceUtil . getService ( ExtServiceImpl . class , user ) ;
}
@Override
public PageInfo < SingleDeptTreeVO > getDeptListByPid ( QuerySingleDeptListParam param ) {
//1.查询分部下所有部门
//PageUtil.start(param.getCurrent(), param.getPageSize());
List < DepartmentPO > departmentPOS = MapperProxyFactory . getProxy ( DepartmentMapper . class ) . listAll ( "showOrder" ) ;
PageInfo < DepartmentPO > pageInfo = new PageInfo < > ( departmentPOS ) ;
List < SingleDeptTreeVO > singleDeptTreeVOS = DepartmentBO . buildSingleDeptTreeVOS ( departmentPOS , param . getParentComp ( ) ) ;
PageInfo < SingleDeptTreeVO > pageInfos = new PageInfo < > ( singleDeptTreeVOS , SingleDeptTreeVO . class ) ;
pageInfos . setTotal ( pageInfo . getTotal ( ) ) ;
pageInfos . setPageNum ( param . getCurrent ( ) ) ;
pageInfos . setPageSize ( param . getPageSize ( ) ) ;
return pageInfos ;
}
@Override
public PageInfo < SingleJobTreeVO > getJobListByPid ( QuerySingleDeptListParam param ) {
List < JobPO > jobPOS = MapperProxyFactory . getProxy ( JobMapper . class ) . listAll ( ) ;
PageInfo < JobPO > pageInfo = new PageInfo < > ( jobPOS ) ;
List < SingleJobTreeVO > singleDeptTreeVOS = JobBO . buildSingleJobTreeVOS ( jobPOS , param . getParentDept ( ) ) ;
PageInfo < SingleJobTreeVO > pageInfos = new PageInfo < > ( singleDeptTreeVOS , SingleJobTreeVO . class ) ;
pageInfos . setTotal ( pageInfo . getTotal ( ) ) ;
pageInfos . setPageNum ( param . getCurrent ( ) ) ;
pageInfos . setPageSize ( param . getPageSize ( ) ) ;
return pageInfos ;
}
@Override
public Map < String , Object > getSearchTree ( SearchTreeParams params ) {
String keyword = params . getKeyword ( ) ;
String id = params . getId ( ) ;
String type = Util . null2String ( params . getType ( ) ) ;
List < SearchTree > treeList = getFilterCompany ( id , keyword ) ;
return SearchTreeUtil . getSearchTree ( type , treeList ) ;
}
@Override
public Map < String , Object > listPage ( DeptSearchParam param ) {
Map < String , Object > datas = new HashMap < > ( ) ;
boolean hasRight = HasRightUtil . hasRight ( user , RIGHT_NAME , true ) ;
datas . put ( "hasRight" , hasRight ) ;
if ( ! hasRight ) {
return datas ;
}
DepartmentPO departmentPO = DepartmentBO . convertParamsToPO ( param , user . getUID ( ) ) ;
boolean filter = isFilter ( departmentPO ) ;
PageInfo < DepartmentListDTO > pageInfos ;
String orderSql = PageInfoSortUtil . getSortSql ( param . getSortParams ( ) ) ;
List < DepartmentPO > allList = getDepartmentMapper ( ) . listAll ( orderSql ) ;
new DetachUtil ( user . getUID ( ) ) . filterDepartmentList ( allList ) ;
// 通过子级遍历父级元素
if ( filter ) {
// 根据条件获取元素
List < DepartmentPO > filterDeptPOs = getDepartmentMapper ( ) . listByFilter ( departmentPO , orderSql ) ;
new DetachUtil ( user . getUID ( ) ) . filterDepartmentList ( filterDeptPOs ) ;
// 添加父级元素
List < DepartmentListDTO > compListDTOS = DepartmentBO . buildDeptDTOList ( allList , filterDeptPOs ) ;
List < DepartmentListDTO > subList = PageUtil . subList ( param . getCurrent ( ) , param . getPageSize ( ) , compListDTOS ) ;
pageInfos = new PageInfo < > ( subList , DepartmentListDTO . class ) ;
pageInfos . setTotal ( compListDTOS . size ( ) ) ;
} else {
// 组合list
List < DepartmentListDTO > compListDTOS = DepartmentBO . buildDeptDTOList ( allList ) ;
List < DepartmentListDTO > subList = PageUtil . subList ( param . getCurrent ( ) , param . getPageSize ( ) , compListDTOS ) ;
pageInfos = new PageInfo < > ( subList , DepartmentListDTO . class ) ;
pageInfos . setTotal ( compListDTOS . size ( ) ) ;
}
pageInfos . setPageNum ( param . getCurrent ( ) ) ;
pageInfos . setPageSize ( param . getPageSize ( ) ) ;
OrganizationWeaTable < DepartmentListDTO > table = new OrganizationWeaTable < > ( user , DepartmentListDTO . class ) ;
List < Column > columns = pageInfos . getColumns ( ) ;
List < WeaTableColumn > weaTableColumn = columns . stream ( ) . map ( v - > new WeaTableColumn ( "100" , v . getTitle ( ) , v . getKey ( ) ) ) . collect ( Collectors . toList ( ) ) ;
table . setColumns ( weaTableColumn ) ;
WeaResultMsg result = new WeaResultMsg ( false ) ;
result . putAll ( table . makeDataResult ( ) ) ;
result . success ( ) ;
datas . put ( "pageInfo" , pageInfos ) ;
datas . put ( "dataKey" , result . getResultMap ( ) ) ;
return datas ;
}
@Override
public Long saveBaseForm ( Map < String , Object > params ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
Map < String , Object > syncMap = new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . ADD , params ) . sync ( ) ;
String ecCompanyID = Util . null2String ( syncMap . get ( "id" ) ) ;
OrganizationAssert . isTrue ( StringUtils . isNotBlank ( ecCompanyID ) , syncMap . get ( "message" ) . toString ( ) ) ;
return Long . parseLong ( ecCompanyID ) ;
}
@Override
public int updateForbiddenTagById ( DeptSearchParam params ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
DepartmentPO departmentPO = DepartmentPO . builder ( ) . id ( params . getId ( ) ) . canceled ( params . getCanceled ( ) ? 0 : 1 ) . build ( ) ;
Map < String , Object > map = new HashMap < > ( ) ;
map . put ( "id" , departmentPO . getId ( ) ) ;
map . put ( "forbiddenTag" , departmentPO . getCanceled ( ) ) ;
new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . CANCELED , map ) . sync ( ) ;
return 1 ;
}
@Override
public Long updateForm ( Map < String , Object > params ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
String ecCompanyId = Util . null2String ( params . get ( "id" ) ) ;
new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . UPDATE , params ) . sync ( ) ;
return Long . parseLong ( ecCompanyId ) ;
}
@Override
public Map < String , Object > deleteByIds ( Map < String , Object > params ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
return ServiceUtil . getService ( OrganizationServiceImpl . class , user ) . delDepartment ( params , user ) ;
}
@Override
public Map < String , Object > getSearchCondition ( Map < String , Object > params ) {
Map < String , Object > apiDatas = new HashMap < > ( ) ;
List < SearchConditionGroup > addGroups = new ArrayList < > ( ) ;
List < SearchConditionItem > conditionItems = new ArrayList < > ( ) ;
// 编号
SearchConditionItem departmentCodeItem = OrganizationFormItemUtil . inputItem ( user , 2 , 16 , 2 , 50 , "编号" , "departmentCode" ) ;
// 名称
SearchConditionItem departmentNameItem = OrganizationFormItemUtil . inputItem ( user , 2 , 16 , 2 , 50 , "名称" , "departmentName" ) ;
// 所属分部
SearchConditionItem subCompanyId1Item = OrganizationFormItemUtil . browserItem ( user , 2 , 16 , 2 , false , "所属分部" , "164" , "subCompanyId1" , "" ) ;
// 上级部门
SearchConditionItem supDepIdItem = OrganizationFormItemUtil . browserItem ( user , 2 , 16 , 2 , false , "上级部门" , "4" , "supDepId" , "" ) ;
conditionItems . add ( departmentCodeItem ) ;
conditionItems . add ( departmentNameItem ) ;
conditionItems . add ( subCompanyId1Item ) ;
conditionItems . add ( supDepIdItem ) ;
addGroups . add ( new SearchConditionGroup ( "高级搜索条件" , true , conditionItems ) ) ;
apiDatas . put ( "conditions" , addGroups ) ;
return apiDatas ;
}
@Override
public Map < String , List < MenuBtn > > getHasRight ( ) {
return MenuBtn . getDatasHasCopy ( ) ;
}
@Override
public Map < String , Object > getDeptBaseForm ( Map < String , Object > params ) {
OrganizationAssert . notNull ( params . get ( "viewAttr" ) , "请标识操作类型" ) ;
// 2编辑 1查看
int viewAttr = Integer . parseInt ( ( String ) params . get ( "viewAttr" ) ) ;
long id = Long . parseLong ( ( String ) params . get ( "id" ) ) ;
String groupId = ( String ) params . get ( "viewCondition" ) ;
HashMap < String , Object > buttonsMap = new HashMap < > ( ) ;
buttonsMap . put ( "hasEdit" , true ) ;
buttonsMap . put ( "hasSave" , true ) ;
List < SearchConditionGroup > addGroups = new ArrayList < > ( ) ;
if ( "0" . equals ( groupId ) ) {
groupId = GROUP_ID . toString ( ) ;
}
List < ExtendTitlePO > extendTitles = getExtendTitleMapper ( ) . getTitlesByGroupID ( Long . parseLong ( groupId ) , "1" ) ;
if ( CollectionUtils . isNotEmpty ( extendTitles ) ) {
for ( ExtendTitlePO extendTitle : extendTitles ) {
List < SearchConditionItem > items = getExtService ( user ) . getExtForm ( user , EXTEND_TYPE + "" , GROUP_ID . equals ( Long . parseLong ( groupId ) ) ? JCL_ORG_DEPT : JCL_ORG_DEPTEXT , viewAttr , id , extendTitle . getId ( ) . toString ( ) , "" ) ;
if ( CollectionUtils . isNotEmpty ( items ) ) {
addGroups . add ( new SearchConditionGroup ( extendTitle . getTitle ( ) , true , items ) ) ;
}
}
}
HashMap < String , Object > resultMap = new HashMap < > ( ) ;
resultMap . put ( "buttons" , buttonsMap ) ;
resultMap . put ( "conditions" , addGroups ) ;
resultMap . put ( "id" , id ) ;
// 拓展页面分组
resultMap . put ( "tabInfo" , getExtService ( user ) . getTabInfo ( EXTEND_TYPE , JCL_ORG_DEPTEXT ) ) ;
// 处理明细表
resultMap . put ( "tables" , getExtService ( user ) . getExtendTables ( user , EXTEND_TYPE , Long . parseLong ( groupId ) , JCL_ORG_DEPTEXT_DT1 , id , viewAttr , false ) ) ;
Map < String , Object > apiDatas = new HashMap < > ( ) ;
apiDatas . put ( "result" , resultMap ) ;
return apiDatas ;
}
@Override
public Map < String , Object > getSaveForm ( Map < String , Object > params ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
Map < String , Object > apiDatas = new HashMap < > ( ) ;
List < Map < String , Object > > groupList = new ArrayList < > ( ) ;
Map < String , Object > groupItem ;
List < Object > itemList ;
String id = Util . null2String ( params . get ( "id" ) ) ;
int viewAttr = Util . getIntValue ( Util . null2String ( params . get ( "viewattr" ) ) , 1 ) ;
String nodeType = Util . null2String ( params . get ( "type" ) ) ;
String addType = Util . null2String ( params . get ( "addType" ) ) ;
DepartmentComInfo departmentComInfo = new DepartmentComInfo ( ) ;
String subcompanyid1 = "" ;
String supDepId = "" ;
switch ( addType ) {
case "normal" :
if ( nodeType . equals ( "subcompany" ) ) {
subcompanyid1 = id ;
} else {
subcompanyid1 = departmentComInfo . getSubcompanyid1 ( id ) ;
}
break ;
case "sibling" :
subcompanyid1 = departmentComInfo . getSubcompanyid1 ( id ) ;
supDepId = departmentComInfo . getDepartmentsupdepid ( id ) ;
break ;
case "child" :
subcompanyid1 = departmentComInfo . getSubcompanyid1 ( id ) ;
supDepId = id ;
break ;
}
HrmFieldGroupComInfo HrmFieldGroupComInfo = new HrmFieldGroupComInfo ( ) ;
HrmFieldComInfo HrmFieldComInfo = new HrmFieldComInfo ( ) ;
HrmFieldSearchConditionComInfo hrmFieldSearchConditionComInfo = new HrmFieldSearchConditionComInfo ( ) ;
SearchConditionItem searchConditionItem ;
HrmFieldBean hrmFieldBean ;
HrmDeptFieldManagerE9 hfm ;
try {
hfm = new HrmDeptFieldManagerE9 ( 5 ) ;
} catch ( Exception e ) {
throw new OrganizationRunTimeException ( "" ) ;
}
hfm . isReturnDecryptData ( true ) ;
hfm . getCustomData ( Util . getIntValue ( id ) ) ;
List lsGroup = hfm . getLsGroup ( ) ;
for ( int tmp = 0 ; lsGroup ! = null & & tmp < lsGroup . size ( ) ; tmp + + ) {
String groupid = ( String ) lsGroup . get ( tmp ) ;
List lsField = hfm . getLsField ( groupid ) ;
boolean groupHide = lsField . size ( ) = = 0 | | hfm . getGroupCount ( lsField ) = = 0 | | ! Util . null2String ( HrmFieldGroupComInfo . getIsShow ( groupid ) ) . equals ( "1" ) ;
String grouplabel = HrmFieldGroupComInfo . getLabel ( groupid ) ;
itemList = new ArrayList < > ( ) ;
groupItem = new HashMap < > ( ) ;
groupItem . put ( "title" , SystemEnv . getHtmlLabelNames ( grouplabel , user . getLanguage ( ) ) ) ;
groupItem . put ( "hide" , groupHide ) ;
groupItem . put ( "defaultshow" , true ) ;
for ( Object o : lsField ) {
String fieldId = ( String ) o ;
String fieldName = HrmFieldComInfo . getFieldname ( fieldId ) ;
String isUse = HrmFieldComInfo . getIsused ( fieldId ) ;
if ( ! isUse . equals ( "1" ) ) continue ;
int tmpViewAttr = viewAttr ;
String rules = "" ;
String fieldLabel = HrmFieldComInfo . getLabel ( fieldId ) ;
String fieldHtmlType = HrmFieldComInfo . getFieldhtmltype ( fieldId ) ;
String type = HrmFieldComInfo . getFieldType ( fieldId ) ;
String dmlUrl = Util . null2String ( HrmFieldComInfo . getFieldDmlurl ( fieldId ) ) ;
String fieldValue = "" ;
if ( StringUtils . isBlank ( addType ) ) {
if ( HrmFieldComInfo . getIssystem ( fieldId ) . equals ( "1" ) ) {
fieldValue = hfm . getData ( fieldName ) ;
} else {
fieldValue = hfm . getData ( "hrmdepartmentdefined" , fieldName ) ;
}
}
if ( ! groupHide & & tmpViewAttr = = 2 & & HrmFieldComInfo . getIsmand ( fieldId ) . equals ( "1" ) ) {
tmpViewAttr = 3 ;
if ( "1" . equals ( fieldHtmlType ) & & "2" . equals ( type ) ) {
rules = "required|integer" ;
} else {
rules = "required|string" ;
}
}
if ( subcompanyid1 . length ( ) > 0 & & fieldName . equals ( "subcompanyid1" ) ) {
fieldValue = subcompanyid1 ;
}
if ( supDepId . length ( ) > 0 & & fieldName . equals ( "supdepid" ) ) {
fieldValue = supDepId ;
}
if ( fieldName . equals ( "showid" ) ) {
if ( addType . length ( ) > 0 ) {
continue ;
} else {
fieldValue = id ;
tmpViewAttr = 1 ;
}
}
hrmFieldBean = new HrmFieldBean ( ) ;
hrmFieldBean . setFieldid ( fieldId ) ;
hrmFieldBean . setFieldname ( fieldName ) ;
hrmFieldBean . setFieldlabel ( fieldLabel ) ;
hrmFieldBean . setFieldhtmltype ( fieldHtmlType ) ;
hrmFieldBean . setType ( type ) ;
hrmFieldBean . setIsFormField ( true ) ;
hrmFieldBean . setIssystem ( "1" ) ;
hrmFieldBean . setFieldvalue ( fieldValue ) ;
hrmFieldBean . setDmlurl ( dmlUrl ) ;
hrmFieldBean . setViewAttr ( tmpViewAttr ) ;
hrmFieldBean . setRules ( rules ) ;
if ( hrmFieldBean . getFieldname ( ) . equals ( "subcompanyid1" ) | | hrmFieldBean . getFieldname ( ) . equals ( "supdepid" ) ) {
hrmFieldBean . setHideVirtualOrg ( true ) ;
}
if ( hrmFieldBean . getFieldname ( ) . equals ( "departmentcode" ) ) {
hrmFieldBean . setMultilang ( false ) ;
}
searchConditionItem = hrmFieldSearchConditionComInfo . getSearchConditionItem ( hrmFieldBean , user ) ;
if ( searchConditionItem ! = null ) {
searchConditionItem . setLabelcol ( 8 ) ;
searchConditionItem . setFieldcol ( 16 ) ;
if ( fieldName . equals ( "showorder" ) ) {
searchConditionItem . setPrecision ( 2 ) ;
}
if ( fieldName . equals ( "showid" ) ) {
Map < String , Object > otherParams = new HashMap < > ( ) ;
otherParams . put ( "hasBorder" , true ) ;
searchConditionItem . setOtherParams ( otherParams ) ;
}
if ( "6" . equals ( fieldHtmlType ) ) { //附件
Map < String , Object > otherParams1 = new HashMap < > ( ) ;
otherParams1 . put ( "showOrder" , false ) ;
searchConditionItem . setOtherParams ( otherParams1 ) ;
}
itemList . add ( searchConditionItem ) ;
}
}
groupItem . put ( "items" , itemList ) ;
groupList . add ( groupItem ) ;
}
apiDatas . put ( "condition" , groupList ) ;
return apiDatas ;
}
/ * *
* 复 制 表 单
*
* @return
* /
@Override
public List < SearchConditionGroup > getCopyForm ( ) {
List < SearchConditionGroup > addGroups = new ArrayList < > ( ) ;
List < SearchConditionItem > condition = new ArrayList < > ( ) ;
SearchConditionItem compBrowserItem = OrganizationFormItemUtil . browserItem ( user , 2 , 16 , 3 , false , "复制到" , "164" , "company" , "" ) ;
compBrowserItem . setRules ( "required|string" ) ;
SearchConditionItem isCheckItem = OrganizationFormItemUtil . selectItem ( user , Lists . newArrayList ( new SearchConditionOption ( "1" , "" ) ) , 2 , 5 , 10 , false , "复制岗位信息" , "copyJob" ) ;
isCheckItem . setDetailtype ( 2 ) ;
SearchConditionItem copySubDeptItem = OrganizationFormItemUtil . selectItem ( user , Lists . newArrayList ( new SearchConditionOption ( "1" , "" ) ) , 2 , 5 , 10 , false , "复制子部门信息" , "copySubDept" ) ;
copySubDeptItem . setDetailtype ( 2 ) ;
SearchConditionItem copySubJob = OrganizationFormItemUtil . selectItem ( user , Lists . newArrayList ( new SearchConditionOption ( "1" , "" ) ) , 2 , 5 , 10 , false , "复制子部门岗位信息" , "copySubJob" ) ;
copySubJob . setDetailtype ( 2 ) ;
condition . add ( compBrowserItem ) ;
condition . add ( isCheckItem ) ;
condition . add ( copySubDeptItem ) ;
condition . add ( copySubJob ) ;
addGroups . add ( new SearchConditionGroup ( "" , true , condition ) ) ;
return addGroups ;
}
/ * *
* 复 制 岗 位 到 指 定 部 门
*
* @param copyParam
* @return
* /
@Override
public int copyDepartment ( DeptCopyParam copyParam ) {
// 批量复制,后续优化
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
OrganizationAssert . notBlank ( copyParam . getCompany ( ) , "请指定需要复制的公司/分部" ) ;
int insertCount = 0 ;
// 需复制的部门
List < Integer > idList = Arrays . stream ( copyParam . getIds ( ) . split ( "," ) ) . map ( Integer : : parseInt ) . collect ( Collectors . toList ( ) ) ;
Double maxShowOrder = getDepartmentMapper ( ) . getMaxShowOrder ( ) ;
maxShowOrder = null = = maxShowOrder ? 0 : maxShowOrder ;
for ( Integer departmentId : idList ) {
// 复制当前部门
recursionCopyDept ( departmentId , null , Integer . parseInt ( copyParam . getCompany ( ) ) , maxShowOrder , copyParam . getCopyJob ( ) , copyParam . getCopySubDept ( ) , copyParam . getCopySubJob ( ) ) ;
}
return insertCount ;
}
private void recursionCopyDept ( Integer originalDeptId , Integer parentDepartmentId , Integer companyId , Double maxShowOrder , String copyJob , String copySubDept , String copySubJob ) {
// 源部门
DepartmentPO deptById = getDepartmentMapper ( ) . getDeptById ( originalDeptId ) ;
long timeMillis = System . currentTimeMillis ( ) ;
// 处理自动编号
deptById . setDepartmentCode ( null ) ;
// 设置上级分部
deptById . setSubCompanyId1 ( companyId ) ;
deptById . setSupDepId ( parentDepartmentId ) ;
// 显示顺序字段
deptById . setShowOrder ( + + maxShowOrder ) ;
// 新增EC表部门
Map < String , Object > syncMap = addEcDepartment ( deptById ) ;
String ecDepartmentID = Util . null2String ( syncMap . get ( "id" ) ) ;
OrganizationAssert . isTrue ( StringUtils . isNotBlank ( ecDepartmentID ) , syncMap . get ( "message" ) . toString ( ) ) ;
// 更新组织架构图
//TODO new DepartmentTriggerRunnable(deptById.getId()).run();
// 复制当前部门岗位信息
if ( "1" . equals ( copyJob ) ) {
List < JobPO > jobPOS = MapperProxyFactory . getProxy ( JobMapper . class ) . listJobsByDepartmentId ( originalDeptId ) ;
jobPOS = jobPOS . stream ( ) . filter ( item - > null = = item . getParentJob ( ) | | 0 = = item . getParentJob ( ) ) . collect ( Collectors . toList ( ) ) ;
Integer maxJobOrder = MapperProxyFactory . getProxy ( JobMapper . class ) . getMaxShowOrder ( ) ;
if ( maxJobOrder = = null ) {
maxJobOrder = 0 ;
}
recursionCopyJob ( jobPOS , companyId , deptById . getId ( ) , null , maxJobOrder , timeMillis ) ;
}
// 是否复制子部门信息
if ( "1" . equals ( copySubDept ) ) {
// 查询当前部门的子部门
List < DepartmentPO > deptListByPId = getDepartmentMapper ( ) . getDeptListByPId ( originalDeptId ) ;
for ( DepartmentPO departmentPO : deptListByPId ) {
// 复制子部门信息、子部门岗位信息
recursionCopyDept ( departmentPO . getId ( ) , deptById . getId ( ) , companyId , maxShowOrder , copySubJob , copySubDept , copySubJob ) ;
}
}
}
@Override
public List < SearchConditionGroup > getMergeForm ( ) {
List < SearchConditionGroup > addGroups = new ArrayList < > ( ) ;
List < SearchConditionItem > condition = new ArrayList < > ( ) ;
SearchConditionItem deptBrowserItem = OrganizationFormItemUtil . browserItem ( user , 2 , 16 , 3 , false , "合并到部门" , "4" , "department" , "" ) ;
deptBrowserItem . setRules ( "required|string" ) ;
SearchConditionItem mergeNameItem = OrganizationFormItemUtil . inputItem ( user , 2 , 16 , 3 , 50 , "合并后名称" , "mergeName" ) ;
mergeNameItem . setRules ( "required|string" ) ;
condition . add ( deptBrowserItem ) ;
condition . add ( mergeNameItem ) ;
addGroups . add ( new SearchConditionGroup ( "" , true , condition ) ) ;
return addGroups ;
}
@Override
public int mergeDepartment ( DepartmentMergeParam mergeParam ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
// 被合并部门
Integer ecParamDepartment = mergeParam . getDepartment ( ) ;
DepartmentPO targetDepartment = getDepartmentMapper ( ) . getDeptById ( ecParamDepartment ) ;
// map表中合并部门parentID
Integer oldParamDepartment = mergeParam . getId ( ) ;
DepartmentPO oldDepartment = getDepartmentMapper ( ) . getDeptById ( oldParamDepartment ) ;
Integer oldFParentId = null ;
if ( null ! = oldDepartment ) {
java . sql . Date currentDate = new java . sql . Date ( OrganizationDateUtil . stringToDate ( OrganizationDateUtil . getFormatLocalDate ( new Date ( ) ) ) . getTime ( ) ) ;
JclOrgMap jclOrgMap = MapperProxyFactory . getProxy ( JclOrgMapper . class ) . getJclOrgMapByObjID ( currentDate , ModuleTypeEnum . departmentfielddefined . getValue ( ) . toString ( ) , oldDepartment . getId ( ) . toString ( ) ) ;
if ( null ! = jclOrgMap ) {
oldFParentId = jclOrgMap . getFParentId ( ) ;
}
}
// 断言判断
OrganizationAssert . isFalse ( null = = targetDepartment , "被合并部门数据有误,暂时无法合并" ) ;
OrganizationAssert . isFalse ( mergeParam . getId ( ) . equals ( targetDepartment . getId ( ) ) , "所选部门与待合并部门一致,无需操作" ) ;
OrganizationAssert . notNull ( mergeParam . getDepartment ( ) , "请选择需要合并的部门" ) ;
OrganizationAssert . notBlank ( mergeParam . getMergeName ( ) , "请输入合并后的名称" ) ;
// 不可选择合并的数据,本身及子部门
Set < Integer > disableIds = new HashSet < > ( ) ;
// 添加选择部门本身
disableIds . add ( mergeParam . getId ( ) ) ;
List < DepartmentPO > deptListByPId = getDepartmentMapper ( ) . getDeptListByPId ( mergeParam . getId ( ) ) ;
if ( CollectionUtils . isNotEmpty ( deptListByPId ) ) {
addDisableIds ( disableIds , deptListByPId ) ;
}
OrganizationAssert . isFalse ( disableIds . contains ( targetDepartment . getId ( ) ) , "请勿选择当前部门本身及其子部门" ) ;
// 查询该部门下一级部门
List < DepartmentPO > firstChildDeptList = getDepartmentMapper ( ) . getDeptListByPId ( mergeParam . getId ( ) ) ;
// 更新所属部门、所属分部
for ( DepartmentPO departmentPO : firstChildDeptList ) {
departmentPO . setSupDepId ( targetDepartment . getId ( ) ) ;
departmentPO . setSubCompanyId1 ( targetDepartment . getSubCompanyId1 ( ) ) ;
updateEcDepartment ( departmentPO ) ;
// 更新组织架构图
//TODO new DepartmentTriggerRunnable(departmentPO.getId()).run();
}
// 查询该部门一级岗位、更新岗位所属分部、所属部门
List < JobPO > firstChildJobList = getJobMapper ( ) . listJobsByDepartmentId ( mergeParam . getId ( ) ) ;
firstChildJobList = firstChildJobList . stream ( ) . filter ( item - > null = = item . getParentJob ( ) | | 0 = = item . getParentJob ( ) ) . collect ( Collectors . toList ( ) ) ;
// 批量更新部门、所属分部
RecordSet rs = new RecordSet ( ) ;
String targetEcDeptId = targetDepartment . getId ( ) . toString ( ) ;
String mergeEcDeptId = mergeParam . getId ( ) . toString ( ) ;
rs . executeUpdate ( "update jcl_org_job set parent_comp =?,ec_company =?,parent_dept =?,ec_department =? where ec_department =?" , targetDepartment . getSubCompanyId1 ( ) , targetDepartment . getSubCompanyId1 ( ) , targetDepartment . getId ( ) , targetEcDeptId , mergeParam . getId ( ) ) ;
// 更新岗位组织架构图
for ( JobPO jobPO : firstChildJobList ) {
// 刷新组织架构图
new JobTriggerRunnable ( jobPO . getId ( ) ) . run ( ) ;
}
// 更新当前部门下的人员
rs . executeUpdate ( "update hrmresource set SUBCOMPANYID1 =?,DEPARTMENTID =? where DEPARTMENTID =?" , targetDepartment . getSubCompanyId1 ( ) , targetEcDeptId , mergeEcDeptId ) ;
//new RecordSet().executeUpdate("update jcl_org_hrmresource set company_id =? ,ec_company = ? ,department_id = ?, ec_department = ?where department_id =?", targetDepartment.getParentComp(), targetDepartment.getEcCompany(), targetDepartment.getId(), targetEcDeptId, mergeParam.getId());
//List<Long> hrmResourceIds = getSystemDataMapper().getHrmResourceIdsByDept(mergeParam.getId().toString());
//// 更新人员组织架构图
//for (Long hrmResourceId : hrmResourceIds) {
//TODO new HrmResourceTriggerRunnable(hrmResourceId).run();
//}
// 更新子部门下岗位的所属分部
for ( DepartmentPO departmentPO : firstChildDeptList ) {
List < DepartmentPO > deptList = getDepartmentMapper ( ) . getDeptListByPId ( departmentPO . getId ( ) ) ;
forbiddenChildTag ( targetDepartment . getSubCompanyId1 ( ) , Util . null2String ( targetDepartment . getSubCompanyId1 ( ) ) , deptList ) ;
}
// 原部门删除
DepartmentPO mergeDepartment = getDepartmentMapper ( ) . getDeptById ( mergeParam . getId ( ) ) ;
Map < String , Object > map = new HashMap < > ( ) ;
map . put ( "id" , mergeParam . getId ( ) ) ;
new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . CANCELED , map ) . sync ( ) ;
// 删除拓展表、明细表
MapperProxyFactory . getProxy ( ExtMapper . class ) . deleteByID ( "jcl_org_deptext" , mergeParam . getId ( ) ) ;
MapperProxyFactory . getProxy ( ExtDTMapper . class ) . deleteByMainID ( "jcl_org_deptext_dt1" , mergeParam . getId ( ) , null ) ;
// TODO 删除 getDepartmentMapper().deleteByIds(DeleteParam.builder().ids(mergeParam.getId().toString()).build().getIds());
// 更新组织架构图
// TODO new DepartmentTriggerRunnable(mergeDepartment).run();
// 更新部门合并后名称
targetDepartment . setDepartmentName ( mergeParam . getMergeName ( ) ) ;
targetDepartment . setDepartmentMark ( mergeParam . getMergeName ( ) ) ;
updateEcDepartment ( targetDepartment ) ;
// 更新组织架构图
// TODO new DepartmentTriggerRunnable(oldFParentId, targetDepartment.getId()).run();
return 0 ;
}
@Override
public List < SearchConditionGroup > getMoveForm ( ) {
List < SearchConditionGroup > addGroups = new ArrayList < > ( ) ;
List < SearchConditionItem > condition = new ArrayList < > ( ) ;
SearchConditionItem compBrowserItem = OrganizationFormItemUtil . browserItem ( user , 2 , 16 , 2 , false , "选择分部" , "164" , "company" , "" ) ;
SearchConditionItem deptBrowserItem = OrganizationFormItemUtil . browserItem ( user , 2 , 16 , 2 , false , "选择部门" , "4" , "department" , "" ) ;
List < SearchConditionOption > selectOptions = new ArrayList < > ( ) ;
SearchConditionOption compOption = new SearchConditionOption ( "0" , "分部" ) ;
SearchConditionOption deptOption = new SearchConditionOption ( "1" , "部门" ) ;
selectOptions . add ( compOption ) ;
selectOptions . add ( deptOption ) ;
SearchConditionItem moveTypeItem = OrganizationFormItemUtil . selectItem ( user , selectOptions , 2 , 16 , 6 , false , "转移到" , "moveType" ) ;
moveTypeItem . setDetailtype ( 3 ) ;
moveTypeItem . setValue ( "0" ) ;
condition . add ( moveTypeItem ) ;
condition . add ( compBrowserItem ) ;
condition . add ( deptBrowserItem ) ;
addGroups . add ( new SearchConditionGroup ( "" , true , condition ) ) ;
return addGroups ;
}
@Override
public int moveDepartment ( DepartmentMoveParam moveParam ) {
HasRightUtil . hasRight ( user , RIGHT_NAME , false ) ;
OrganizationAssert . notBlank ( moveParam . getMoveType ( ) , "请选择转移类型" ) ;
DepartmentPO deptById = getDepartmentMapper ( ) . getDeptById ( moveParam . getId ( ) ) ;
// 0: 公司/分部 1: 部门
if ( "0" . equals ( moveParam . getMoveType ( ) ) ) {
Integer company = moveParam . getCompany ( ) ;
OrganizationAssert . notNull ( company , "请选择要转移到的分部" ) ;
deptById . setSubCompanyId1 ( company ) ;
deptById . setSupDepId ( null ) ;
// 更新组织架构图
//TODO new DepartmentTriggerRunnable(company.toString(), deptById).run();
} else if ( "1" . equals ( moveParam . getMoveType ( ) ) ) {
Integer departmentId = moveParam . getDepartment ( ) ;
OrganizationAssert . notNull ( departmentId , "请选择要转移到的部门" ) ;
List < DepartmentPO > deptListByPId = getDepartmentMapper ( ) . getDeptListByPId ( moveParam . getId ( ) ) ;
Set < Integer > disableIds = new HashSet < > ( ) ;
disableIds . add ( moveParam . getId ( ) ) ;
if ( CollectionUtils . isNotEmpty ( deptListByPId ) ) {
addDisableIds ( disableIds , deptListByPId ) ;
}
OrganizationAssert . isFalse ( disableIds . contains ( departmentId ) , "请勿选择当前部门本身及其子部门" ) ;
deptById . setSupDepId ( departmentId ) ;
DepartmentPO parentDepartment = getDepartmentMapper ( ) . getDeptById ( departmentId ) ;
deptById . setSubCompanyId1 ( parentDepartment . getSubCompanyId1 ( ) ) ;
// 更新组织架构图
// TODO new DepartmentTriggerRunnable(Integer.toString(100000000 + department.intValue()), deptById).run();
}
// 更新EC部门
updateEcDepartment ( deptById ) ;
// 刷新岗位分部
refreshJobComp ( deptById . getId ( ) , deptById . getSubCompanyId1 ( ) ) ;
List < DepartmentPO > deptList = getDepartmentMapper ( ) . getDeptListByPId ( deptById . getId ( ) ) ;
// 更新当前部门下的人员
new RecordSet ( ) . executeUpdate ( "update hrmresource set SUBCOMPANYID1 =? where DEPARTMENTID = ?" , deptById . getSubCompanyId1 ( ) , deptById . getId ( ) ) ;
//// 更新人员组织架构图
//List<Long> hrmResourceIds = getSystemDataMapper().getHrmResourceIdsByDept(deptById.getId().toString());
//for (Long hrmResourceId : hrmResourceIds) {
//TODO new HrmResourceTriggerRunnable(hrmResourceId).run();
//}
forbiddenChildTag ( deptById . getSubCompanyId1 ( ) , Util . null2String ( deptById . getSubCompanyId1 ( ) ) , deptList ) ;
// 递归更新下级部门、岗位
return 1 ;
}
/ * *
* 获 取 所 有 子 部 门 id
*
* @param parentComp
* @param deptList
* /
void forbiddenChildTag ( Integer parentComp , String ecCompanyId , List < DepartmentPO > deptList ) {
if ( CollectionUtils . isNotEmpty ( deptList ) ) {
for ( DepartmentPO departmentPO : deptList ) {
departmentPO . setSubCompanyId1 ( parentComp ) ;
// 更新EC表部门
updateEcDepartment ( departmentPO ) ;
// 更新组织架构图
// TODO new DepartmentTriggerRunnable(departmentPO.getId()).run();
// 刷新岗位所属分部
refreshJobComp ( departmentPO . getId ( ) , parentComp ) ;
// 更新当前部门下的人员
String ecDepartmentId = EcHrmRelationUtil . getEcDepartmentId ( departmentPO . getId ( ) . toString ( ) ) ;
new RecordSet ( ) . executeUpdate ( "update hrmresource set SUBCOMPANYID1 =? where DEPARTMENTID = ?" , ecCompanyId , ecDepartmentId ) ;
new RecordSet ( ) . executeUpdate ( "update jcl_org_hrmresource set company_id =? ,ec_company = ? where department_id =?" , parentComp , ecCompanyId , departmentPO . getId ( ) ) ;
//List<Long> hrmResourceIds = getSystemDataMapper().getHrmResourceIdsByDept(departmentPO.getId().toString());
//// 更新人员组织架构图
//for (Long hrmResourceId : hrmResourceIds) {
//TODO new HrmResourceTriggerRunnable(hrmResourceId).run();
//}
List < DepartmentPO > childList = getDepartmentMapper ( ) . getDeptListByPId ( departmentPO . getId ( ) ) ;
forbiddenChildTag ( parentComp , ecCompanyId , childList ) ;
}
}
}
/ * *
* 是 否 为 搜 索 查 询
*
* @param departmentPO
* @return
* /
private boolean isFilter ( DepartmentPO departmentPO ) {
return ! ( StringUtil . isEmpty ( departmentPO . getDepartmentCode ( ) )
& & StringUtil . isEmpty ( departmentPO . getDepartmentName ( ) )
& & null = = departmentPO . getSubCompanyId1 ( )
& & null = = departmentPO . getSupDepId ( ) ) ;
}
/ * *
* 根 据 keyword 查 询 数 据
*
* @param id
* @param keyword
* @return
* /
private List < SearchTree > getFilterCompany ( String id , String keyword ) {
// 查询部门信息
Integer parentCompId = StringUtil . isEmpty ( id ) ? null : Integer . parseInt ( id ) ;
CompanyPO compBuild = CompanyPO . builder ( ) . subCompanyName ( keyword ) . supSubComId ( parentCompId ) . canceled ( 0 ) . build ( ) ;
List < CompanyPO > allCompanys = getCompanyMapper ( ) . listAll ( "showOrder" ) ;
new DetachUtil ( user . getUID ( ) ) . filterCompanyList ( allCompanys ) ;
List < CompanyPO > filterComps = getCompanyMapper ( ) . listByFilter ( compBuild , "showOrder" ) ;
new DetachUtil ( user . getUID ( ) ) . filterCompanyList ( filterComps ) ;
Map < Integer , CompanyPO > allMaps = allCompanys . stream ( ) . collect ( Collectors . toMap ( CompanyPO : : getId , item - > item , ( k1 , k2 ) - > k1 ) ) ;
Set < CompanyPO > builderComps = new HashSet < > ( ) ;
for ( CompanyPO companyPO : filterComps ) {
buildParentComps ( companyPO , builderComps , allMaps ) ;
}
return SearchTreeUtil . builderTreeMode ( CompanyBO . buildSetToSearchTree ( builderComps ) ) ;
}
/ * *
* 添 加 查 询 元 素 的 父 级 元 素
*
* @param compPO
* @param builderComps
* /
private void buildParentComps ( CompanyPO compPO , Set < CompanyPO > builderComps , Map < Integer , CompanyPO > allMaps ) {
builderComps . add ( compPO ) ;
CompanyPO parentComp = allMaps . get ( compPO . getSupSubComId ( ) ) ;
if ( null ! = parentComp & & ( null = = parentComp . getCanceled ( ) | | 0 = = parentComp . getCanceled ( ) ) ) {
buildParentComps ( parentComp , builderComps , allMaps ) ;
}
}
/ * *
* 判 断 编 号 是 否 重 复
*
* @return
* /
public static String repeatDetermine ( String deptNo ) {
CodeRulePO codeRuleByType = MapperProxyFactory . getProxy ( CodeRuleMapper . class ) . getCodeRuleByType ( RuleCodeType . DEPARTMENT . getValue ( ) ) ;
if ( StringUtils . isNotBlank ( deptNo ) ) {
deptNo = CodeRuleUtil . generateCode ( RuleCodeType . DEPARTMENT , deptNo ) ;
List < DepartmentPO > list = getDepartmentMapper ( ) . listByNo ( Util . null2String ( deptNo ) ) ;
OrganizationAssert . isEmpty ( list , "编号不允许重复" ) ;
} else {
OrganizationAssert . isTrue ( null ! = codeRuleByType & & "1" . equals ( codeRuleByType . getSerialEnable ( ) ) , "编号不允许为空" ) ;
deptNo = autoCreateCompanyNo ( ) ;
}
return deptNo ;
}
/ * *
* 自 动 编 号 处 理
*
* @return
* /
private static String autoCreateCompanyNo ( ) {
String generateCode = CodeRuleUtil . generateCode ( RuleCodeType . DEPARTMENT , "" ) ;
List < DepartmentPO > list = getDepartmentMapper ( ) . listByNo ( Util . null2String ( generateCode ) ) ;
if ( CollectionUtils . isNotEmpty ( list ) ) {
generateCode = autoCreateCompanyNo ( ) ;
}
return generateCode ;
}
/ * *
* 递 归 复 制 岗 位 信 息
*
* @param jobPOS
* @param parentCompId
* @param parentDeptId
* @param orderNum
* /
private void recursionCopyJob ( List < JobPO > jobPOS , Integer parentCompId , Integer parentDeptId , Long currentParentJobId , int orderNum , long timeMillis ) {
for ( JobPO jobPO : jobPOS ) {
orderNum + + ;
// 查询源岗位的下级岗位
List < JobPO > jobsByPid = MapperProxyFactory . getProxy ( JobMapper . class ) . getJobsByPid ( jobPO . getId ( ) ) ;
// 处理自动编号
jobPO . setJobNo ( CodeRuleUtil . generateCode ( RuleCodeType . JOBTITLES , jobPO . getJobNo ( ) , timeMillis ) ) ;
// 所属部门赋值
jobPO . setParentDept ( parentDeptId ) ;
jobPO . setEcDepartment ( parentDeptId ) ;
// 所属分部赋值
jobPO . setEcCompany ( parentCompId ) ;
jobPO . setParentComp ( parentCompId ) ;
// 指定上级岗位
jobPO . setParentJob ( currentParentJobId ) ;
jobPO . setCreator ( ( long ) user . getUID ( ) ) ;
jobPO . setCreateTime ( new Date ( ) ) ;
jobPO . setShowOrder ( orderNum ) ;
MapperProxyFactory . getProxy ( JobMapper . class ) . insertIgnoreNull ( jobPO ) ;
// 更新组织架构图
new JobTriggerRunnable ( jobPO . getId ( ) ) . run ( ) ;
// 处理子级元素
if ( CollectionUtils . isNotEmpty ( jobsByPid ) ) {
recursionCopyJob ( jobsByPid , parentCompId , parentDeptId , jobPO . getId ( ) , orderNum , timeMillis ) ;
}
}
}
/ * *
* 更 新 EC 表 部 门
*
* @param departmentPO
* /
private void updateEcDepartment ( DepartmentPO departmentPO ) {
Map < String , Object > map = new HashMap < > ( ) ;
map . put ( "departmentmark" , departmentPO . getDepartmentMark ( ) ) ;
map . put ( "departmentname" , departmentPO . getDepartmentName ( ) ) ;
map . put ( "subcompanyid1" , departmentPO . getSubCompanyId1 ( ) ) ;
map . put ( "supdepid" , departmentPO . getSupDepId ( ) ) ;
map . put ( "showorder" , departmentPO . getShowOrder ( ) ) ;
map . put ( "departmentcode" , departmentPO . getDepartmentCode ( ) ) ;
map . put ( "coadjutant" , departmentPO . getCoadjutant ( ) ) ;
map . put ( "id" , departmentPO . getId ( ) ) ;
new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . UPDATE , map ) . sync ( ) ;
}
/ * *
* 新 增 EC 表 部 门
*
* @param departmentPO
* @return
* /
private Map < String , Object > addEcDepartment ( DepartmentPO departmentPO ) {
Map < String , Object > map = new HashMap < > ( ) ;
map . put ( "departmentmark" , departmentPO . getDepartmentMark ( ) ) ;
map . put ( "departmentname" , departmentPO . getDepartmentName ( ) ) ;
map . put ( "subcompanyid1" , departmentPO . getSubCompanyId1 ( ) ) ;
map . put ( "supdepid" , departmentPO . getSupDepId ( ) ) ;
map . put ( "showorder" , departmentPO . getShowOrder ( ) ) ;
map . put ( "departmentcode" , departmentPO . getDepartmentCode ( ) ) ;
return new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . ADD , map ) . sync ( ) ;
}
/ * *
* 封 存 EC 表 部 门
*
* @param id
* /
private void cancelEcDepartment ( Long id ) {
Map < String , Object > map = new HashMap < > ( ) ;
map . put ( "id" , id ) ;
map . put ( "forbiddenTag" , 1 ) ;
new OrganizationSyncEc ( user , LogModuleNameEnum . DEPARTMENT , OperateTypeEnum . CANCELED , map ) . sync ( ) ;
}
private void addDisableIds ( Set < Integer > disableIds , List < DepartmentPO > deptListByPId ) {
for ( DepartmentPO departmentPO : deptListByPId ) {
disableIds . add ( departmentPO . getId ( ) ) ;
List < DepartmentPO > childDeptPOS = getDepartmentMapper ( ) . getDeptListByPId ( departmentPO . getId ( ) ) ;
addDisableIds ( disableIds , childDeptPOS ) ;
}
}
/ * *
* 更 新 岗 位 的 所 属 分 部
*
* @param parentDepartment
* @param parentComp
* /
private void refreshJobComp ( Integer parentDepartment , Integer parentComp ) {
List < JobPO > jobPOS = getJobMapper ( ) . listJobsByDepartmentId ( parentDepartment ) ;
jobPOS = jobPOS . stream ( ) . filter ( item - > null = = item . getParentJob ( ) | | 0 = = item . getParentJob ( ) ) . collect ( Collectors . toList ( ) ) ;
if ( CollectionUtils . isNotEmpty ( jobPOS ) ) {
String ecCompanyId = EcHrmRelationUtil . getEcCompanyId ( parentComp . toString ( ) ) ;
getJobMapper ( ) . updateJobCompany ( jobPOS . stream ( ) . map ( JobPO : : getId ) . collect ( Collectors . toList ( ) ) , parentComp , ecCompanyId ) ;
for ( JobPO jobPO : jobPOS ) {
// 刷新组织架构图
new JobTriggerRunnable ( jobPO . getId ( ) ) . run ( ) ;
}
}
}
}