|
|
|
@ -3,9 +3,11 @@ package com.engine.organization.thread;
|
|
|
|
|
import com.engine.organization.entity.job.po.JobPO;
|
|
|
|
|
import com.engine.organization.entity.logview.bo.FieldBaseEquator;
|
|
|
|
|
import com.engine.organization.entity.map.JclOrgMap;
|
|
|
|
|
import com.engine.organization.entity.staff.po.StaffPO;
|
|
|
|
|
import com.engine.organization.enums.ModuleTypeEnum;
|
|
|
|
|
import com.engine.organization.mapper.jclorgmap.JclOrgMapper;
|
|
|
|
|
import com.engine.organization.mapper.job.JobMapper;
|
|
|
|
|
import com.engine.organization.mapper.staff.StaffMapper;
|
|
|
|
|
import com.engine.organization.mapper.trigger.CompTriggerMapper;
|
|
|
|
|
import com.engine.organization.mapper.trigger.JobTriggerMapper;
|
|
|
|
|
import com.engine.organization.util.OrganizationDateUtil;
|
|
|
|
@ -44,6 +46,10 @@ public class JobTriggerRunnable implements Runnable {
|
|
|
|
|
this.oldJob = new JobPO();
|
|
|
|
|
this.newJob = MapperProxyFactory.getProxy(JobMapper.class).getJobById(jobId);
|
|
|
|
|
}
|
|
|
|
|
public JobTriggerRunnable(Long oldJobId,Long newJobId) {
|
|
|
|
|
this.oldJob = MapperProxyFactory.getProxy(JobMapper.class).getJobById(oldJobId);
|
|
|
|
|
this.newJob = MapperProxyFactory.getProxy(JobMapper.class).getJobById(newJobId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public JobTriggerRunnable(JobPO newJob) {
|
|
|
|
|
this.oldJob = new JobPO();
|
|
|
|
@ -81,9 +87,19 @@ public class JobTriggerRunnable implements Runnable {
|
|
|
|
|
jclMap.setFDateEnd(new Date(OrganizationDateUtil.stringToDate("2099-12-31").getTime()));
|
|
|
|
|
|
|
|
|
|
JclOrgMap jclOrgMapByObjID = MapperProxyFactory.getProxy(JclOrgMapper.class).getJclOrgMapByObjID(currentDate, ModuleTypeEnum.jobfielddefined.getValue().toString(), jclMap.getFObjId().toString());
|
|
|
|
|
|
|
|
|
|
StaffPO staffPO = MapperProxyFactory.getProxy(StaffMapper.class).getStaffsByParamId(null,null,jclOrgMapByObjID.getFObjId().toString());
|
|
|
|
|
// 该岗位有下级岗位时,查询
|
|
|
|
|
JclOrgMap jclOrgMap = MapperProxyFactory.getProxy(JclOrgMapper.class).getSumPlanAndJobByFParentId(currentDate, jclMap.getId().toString());
|
|
|
|
|
|
|
|
|
|
if (null != jclOrgMapByObjID) {
|
|
|
|
|
jclMap.setFPlan(jclOrgMapByObjID.getFPlan());
|
|
|
|
|
jclMap.setFOnJob(jclOrgMapByObjID.getFOnJob());
|
|
|
|
|
if (null != jclOrgMap) {
|
|
|
|
|
jclMap.setFPlan(staffPO.getStaffNum() + jclOrgMap.getFPlan());
|
|
|
|
|
jclMap.setFOnJob(jclOrgMapByObjID.getFOnJob() + jclOrgMap.getFOnJob());
|
|
|
|
|
} else {
|
|
|
|
|
jclMap.setFPlan(jclOrgMapByObjID.getFPlan());
|
|
|
|
|
jclMap.setFOnJob(jclOrgMapByObjID.getFOnJob());
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
jclMap.setFPlan(0);
|
|
|
|
|
jclMap.setFOnJob(0);
|
|
|
|
@ -97,12 +113,47 @@ public class JobTriggerRunnable implements Runnable {
|
|
|
|
|
getCompTriggerMapper().deleteMap(jclMap.getFType(), jclMap.getFObjId(), jclMap.getFDateBegin());
|
|
|
|
|
getCompTriggerMapper().updateMap(jclMap.getFType(), jclMap.getFObjId(), jclMap.getFDateBegin(), time);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (1 != newJob.getDeleteType() && 1 != newJob.getForbiddenTag()) {
|
|
|
|
|
MapperProxyFactory.getProxy(JclOrgMapper.class).insertMap(jclMap);
|
|
|
|
|
if (null != jclOrgMapByObjID.getFParentId()) {
|
|
|
|
|
updateParentPlanAndJob(currentDate, jclOrgMapByObjID.getFParentId().toString());
|
|
|
|
|
}
|
|
|
|
|
if (null != oldJob) {
|
|
|
|
|
updateParentPlanAndJob(currentDate, oldJob.getId().toString());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 更新上级部门在编、在岗数
|
|
|
|
|
*/
|
|
|
|
|
void updateParentPlanAndJob(String currentDate, String parentId) {
|
|
|
|
|
JclOrgMap parentJclOrgMap = MapperProxyFactory.getProxy(JclOrgMapper.class).getJclOrgMapById(currentDate, parentId);
|
|
|
|
|
if (null != parentJclOrgMap) {
|
|
|
|
|
// 上级部门当前在编、在岗数
|
|
|
|
|
JclOrgMap jclOrgMapSum = MapperProxyFactory.getProxy(JclOrgMapper.class).getSumPlanAndJobByFParentId(currentDate, parentJclOrgMap.getId().toString());
|
|
|
|
|
StaffPO staffPO = MapperProxyFactory.getProxy(StaffMapper.class).getStaffsByParamId(null,null,parentJclOrgMap.getFObjId().toString());
|
|
|
|
|
if (null != jclOrgMapSum) {
|
|
|
|
|
parentJclOrgMap.setFPlan(staffPO.getStaffNum() + jclOrgMapSum.getFPlan());
|
|
|
|
|
parentJclOrgMap.setFOnJob(jclOrgMapSum.getFOnJob());
|
|
|
|
|
} else {
|
|
|
|
|
parentJclOrgMap.setFPlan(0);
|
|
|
|
|
parentJclOrgMap.setFOnJob(0);
|
|
|
|
|
}
|
|
|
|
|
parentJclOrgMap.setFDateBegin(new Date(OrganizationDateUtil.stringToDate(currentDate).getTime()));
|
|
|
|
|
parentJclOrgMap.setFDateEnd(new Date(OrganizationDateUtil.stringToDate("2099-12-31").getTime()));
|
|
|
|
|
|
|
|
|
|
Calendar cal = Calendar.getInstance();
|
|
|
|
|
cal.setTime(parentJclOrgMap.getFDateBegin());
|
|
|
|
|
Calendar calendar = DateUtil.addDay(cal, -1);
|
|
|
|
|
Date time = new Date(calendar.getTime().getTime());
|
|
|
|
|
getCompTriggerMapper().deleteMap(parentJclOrgMap.getFType(), parentJclOrgMap.getFObjId(), parentJclOrgMap.getFDateBegin());
|
|
|
|
|
getCompTriggerMapper().updateMap(parentJclOrgMap.getFType(), parentJclOrgMap.getFObjId(), parentJclOrgMap.getFDateBegin(), time);
|
|
|
|
|
MapperProxyFactory.getProxy(JclOrgMapper.class).insertMap(parentJclOrgMap);
|
|
|
|
|
if (null != parentJclOrgMap.getFParentId() && -1 != parentJclOrgMap.getFParentId()) {
|
|
|
|
|
updateParentPlanAndJob(currentDate, parentJclOrgMap.getFParentId().toString());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|