成本中心定时任务添加维护组织分录,人员非新增取消更新部门
This commit is contained in:
parent
4bb5f6f8ec
commit
d716d27dd5
|
@ -24,6 +24,9 @@ import java.math.BigDecimal;
|
||||||
import java.math.RoundingMode;
|
import java.math.RoundingMode;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 定时任务:更新成本中心和部门信息
|
||||||
|
*/
|
||||||
public class CostCenterTaskImpl extends AbstractTask {
|
public class CostCenterTaskImpl extends AbstractTask {
|
||||||
|
|
||||||
private static Logger logger = LoggerFactory.getLogger(HrmDepartmentTaskImpl.class);
|
private static Logger logger = LoggerFactory.getLogger(HrmDepartmentTaskImpl.class);
|
||||||
|
@ -55,8 +58,8 @@ public class CostCenterTaskImpl extends AbstractTask {
|
||||||
queryDTO.setCreated(time.toString());
|
queryDTO.setCreated(time.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
//创建人员对应成本中心集合
|
//创建人员对应成本中心、部门集合
|
||||||
HashMap<String, String> orgMap = new HashMap<>();
|
HashMap<String, HashMap<String,String>> orgMap = new HashMap<>();
|
||||||
|
|
||||||
JSONObject data = this.getOAUserData(query,oaUrl);
|
JSONObject data = this.getOAUserData(query,oaUrl);
|
||||||
this.importOrgMap(orgMap,data);//填充人员数据(人员编码,成本中心编码)
|
this.importOrgMap(orgMap,data);//填充人员数据(人员编码,成本中心编码)
|
||||||
|
@ -81,26 +84,59 @@ public class CostCenterTaskImpl extends AbstractTask {
|
||||||
QFilter userQF = new QFilter("number", QCP.equals, key);
|
QFilter userQF = new QFilter("number", QCP.equals, key);
|
||||||
DynamicObject bos_user = BusinessDataServiceHelper.loadSingle("bos_user", userQF.toArray());//查找星瀚对应人员
|
DynamicObject bos_user = BusinessDataServiceHelper.loadSingle("bos_user", userQF.toArray());//查找星瀚对应人员
|
||||||
if (bos_user != null){//当人员数据不为空时
|
if (bos_user != null){//当人员数据不为空时
|
||||||
String costNumber = orgMap.get(key);//对应的成本中心编码
|
boolean changeFlag = false;
|
||||||
QFilter costQFr = new QFilter("number", QCP.equals, costNumber);
|
HashMap<String,String> valueMap = orgMap.get(key);//部门及成本中心数据集合
|
||||||
DynamicObject bos_costCenter = BusinessDataServiceHelper.loadSingle("bos_costcenter", costQFr.toArray());
|
String departmentcode = valueMap.get("departmentcode");//部门编码
|
||||||
if (bos_costCenter != null){//当成本中心不为空时
|
String costCenterNumber = valueMap.get("costCenterNumber");//成本中心编码
|
||||||
//获取用户的成本中心信息分录
|
if (!"".equals(costCenterNumber)){
|
||||||
DynamicObjectCollection costEntity = bos_user.getDynamicObjectCollection("shkd_costentity");
|
//对应的成本中心编码
|
||||||
//首先遍历移除已存在的来源为泛微的数据
|
QFilter costQFr = new QFilter("number", QCP.equals, costCenterNumber);
|
||||||
for (int i = 0;i < costEntity.size();i++){
|
DynamicObject bos_costCenter = BusinessDataServiceHelper.loadSingle("bos_costcenter", costQFr.toArray());
|
||||||
DynamicObject dynamicObject = costEntity.get(i);
|
if (bos_costCenter != null){//当成本中心不为空时
|
||||||
String shkd_e_source = dynamicObject.getString("shkd_e_source");
|
//获取用户的成本中心信息分录
|
||||||
if ("B".equals(shkd_e_source)){
|
DynamicObjectCollection costEntity = bos_user.getDynamicObjectCollection("shkd_costentity");
|
||||||
int index = costEntity.indexOf(dynamicObject);
|
//首先遍历移除已存在的来源为泛微的数据
|
||||||
costEntity.remove(index);
|
for (int i = 0;i < costEntity.size();i++){
|
||||||
|
DynamicObject dynamicObject = costEntity.get(i);
|
||||||
|
String shkd_e_source = dynamicObject.getString("shkd_e_source");
|
||||||
|
if ("B".equals(shkd_e_source)){
|
||||||
|
int index = costEntity.indexOf(dynamicObject);
|
||||||
|
costEntity.remove(index);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
DynamicObject newObject = costEntity.addNew();
|
||||||
|
newObject.set("shkd_e_cost",bos_costCenter);
|
||||||
|
newObject.set("shkd_e_source","B");
|
||||||
|
changeFlag = true;
|
||||||
}
|
}
|
||||||
DynamicObject newObject = costEntity.addNew();
|
|
||||||
newObject.set("shkd_e_cost",bos_costCenter);
|
|
||||||
newObject.set("shkd_e_source","B");
|
|
||||||
OperationResult operationResult = OperationServiceHelper.executeOperate("save", "bos_user", new DynamicObject[]{bos_user}, option);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!"".equals(departmentcode)){
|
||||||
|
//对应的部门编码
|
||||||
|
QFilter deptQFr = new QFilter("number", QCP.equals, departmentcode);
|
||||||
|
DynamicObject bos_adminorg = BusinessDataServiceHelper.loadSingle("bos_adminorg", deptQFr.toArray());
|
||||||
|
if (bos_adminorg != null){//当行政组织不为空时
|
||||||
|
//获取人员的组织分录
|
||||||
|
DynamicObjectCollection entryentity = bos_user.getDynamicObjectCollection("entryentity");//组织分录
|
||||||
|
//首先遍历移除已存在的来源为泛微的数据
|
||||||
|
for (int i = 0;i < entryentity.size();i++){
|
||||||
|
DynamicObject dynamicObject = entryentity.get(i);
|
||||||
|
String shkd_deptsource = dynamicObject.getString("shkd_deptsource");
|
||||||
|
if ("2".equals(shkd_deptsource)){
|
||||||
|
int index = entryentity.indexOf(dynamicObject);
|
||||||
|
entryentity.remove(index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
DynamicObject newObject = entryentity.addNew();
|
||||||
|
newObject.set("dpt",bos_adminorg);//部门
|
||||||
|
newObject.set("position", valueMap.get("position"));//职位
|
||||||
|
newObject.set("isincharge",false);
|
||||||
|
newObject.set("ispartjob",false);
|
||||||
|
newObject.set("shkd_deptsource","2");
|
||||||
|
changeFlag = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
OperationResult operationResult = OperationServiceHelper.executeOperate("save", "bos_user", new DynamicObject[]{bos_user}, option);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,17 +158,26 @@ public class CostCenterTaskImpl extends AbstractTask {
|
||||||
return data ;
|
return data ;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void importOrgMap(HashMap<String, String> orgMap,JSONObject data){
|
|
||||||
|
/**
|
||||||
|
* 根据人员接口返回的数据填充创建人员对应成本中心、部门集合
|
||||||
|
* sh
|
||||||
|
* @param orgMap
|
||||||
|
* @param data
|
||||||
|
*/
|
||||||
|
private void importOrgMap(HashMap<String, HashMap<String,String>> orgMap,JSONObject data){
|
||||||
JSONArray dataList = data.getJSONArray("dataList");//oa人员数据集合
|
JSONArray dataList = data.getJSONArray("dataList");//oa人员数据集合
|
||||||
for (int i = 0; i < dataList.size(); i++) {
|
for (int i = 0; i < dataList.size(); i++) {//遍历
|
||||||
JSONObject userData = dataList.getJSONObject(i);
|
JSONObject userData = dataList.getJSONObject(i);
|
||||||
JSONObject base_custom_data = userData.getJSONObject("base_custom_data");
|
HashMap<String, String> valueMap = new HashMap<>();
|
||||||
if (base_custom_data != null){
|
valueMap.put("departmentcode",userData.getString("departmentcode"));//设置部门信息
|
||||||
String field0 = base_custom_data.getString("field0");
|
valueMap.put("position", userData.getString("jobactivityname"));// 职位
|
||||||
if (!"".equals(field0)){
|
valueMap.put("superior", userData.getString("managerid"));//直接上级
|
||||||
orgMap.put(userData.getString("workcode"),field0);
|
JSONObject base_custom_data = userData.getJSONObject("base_custom_data");//获取自定义数据包
|
||||||
}
|
if (base_custom_data != null){//设置成本中心数据
|
||||||
|
valueMap.put("costCenterNumber",base_custom_data.getString("field0"));
|
||||||
}
|
}
|
||||||
|
orgMap.put(userData.getString("workcode"), valueMap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -190,29 +190,33 @@ public class UserTaskImpl extends AbstractTask {
|
||||||
}
|
}
|
||||||
// 职位分
|
// 职位分
|
||||||
if(workid == null){//若人不存在则更新部门
|
if(workid == null){//若人不存在则更新部门
|
||||||
|
List<Map<String, Object>> posList = new ArrayList<>();
|
||||||
}
|
Map<String, Object> entryentity = new HashMap<>();
|
||||||
List<Map<String, Object>> posList = new ArrayList<>();
|
// 通过编码设置部门
|
||||||
Map<String, Object> entryentity = new HashMap<>();
|
Map<String, Object> dptNumMap = new HashMap<>();
|
||||||
// 通过编码设置部门
|
String departmentcode = userData.getString("departmentcode");
|
||||||
Map<String, Object> dptNumMap = new HashMap<>();
|
if (departmentcode.isEmpty()){
|
||||||
dptNumMap.put("number", userData.getString("departmentcode"));
|
logger.info("人员:"+userData.getString("lastname")+",所属部门编码未携带,新增用户时会导致失败");
|
||||||
entryentity.put("dpt",dptNumMap ); // 部门
|
|
||||||
entryentity.put("position", userData.getString("jobactivityname")); // 职位
|
|
||||||
entryentity.put("isincharge", false); //负责人
|
|
||||||
entryentity.put("ispartjob", false); //兼职
|
|
||||||
String managerId_oa = userData.getString("managerid");//获取上级人员id(oa)
|
|
||||||
Long managerId = userIds.get(managerId_oa);//直接上级id
|
|
||||||
if (managerId != null){
|
|
||||||
entryentity.put("superior", managerId); // 赋值直接上级
|
|
||||||
}else {
|
|
||||||
if (!"".equals(managerId_oa)){//当上级人员id(oa)存在且未在星瀚系统检索成功时,修改参数flag,接口将重新构造人员类更新数据
|
|
||||||
flag = true;
|
|
||||||
}
|
}
|
||||||
|
dptNumMap.put("number", departmentcode);
|
||||||
|
entryentity.put("dpt",dptNumMap ); // 部门
|
||||||
|
entryentity.put("position", userData.getString("jobactivityname")); // 职位
|
||||||
|
entryentity.put("isincharge", false); //负责人
|
||||||
|
entryentity.put("ispartjob", false); //兼职
|
||||||
|
entryentity.put("shkd_deptsource","2");//来源设置为泛微
|
||||||
|
String managerId_oa = userData.getString("managerid");//获取上级人员id(oa)
|
||||||
|
Long managerId = userIds.get(managerId_oa);//直接上级id
|
||||||
|
if (managerId != null){
|
||||||
|
entryentity.put("superior", managerId); // 赋值直接上级
|
||||||
|
}else {
|
||||||
|
if (!"".equals(managerId_oa)){//当上级人员id(oa)存在且未在星瀚系统检索成功时,修改参数flag,接口将重新构造人员类更新数据
|
||||||
|
flag = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
entryentity.put("seq", 1);
|
||||||
|
posList.add(entryentity);
|
||||||
|
dataMap.put("entryentity", posList);
|
||||||
}
|
}
|
||||||
entryentity.put("seq", 1);
|
|
||||||
posList.add(entryentity);
|
|
||||||
dataMap.put("entryentity", posList);
|
|
||||||
user.setDataMap(dataMap);
|
user.setDataMap(dataMap);
|
||||||
paramList.add(user);
|
paramList.add(user);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue