|
@@ -138,7 +138,9 @@ public class TestPlugin extends AbstractListPlugin {
|
|
|
|
|
|
data = new DynamicObject(dynamicObjectType);
|
|
|
for (int i = 0; i < selector.size(); i++) {
|
|
|
- data.set(selector.get(i), fields[i]);
|
|
|
+ if (!fields[i].isEmpty()) {
|
|
|
+ data.set(selector.get(i), fields[i]);
|
|
|
+ }
|
|
|
}
|
|
|
Date now = new Date();
|
|
|
data.set("nckd_createdate", now);
|
|
@@ -581,11 +583,13 @@ public class TestPlugin extends AbstractListPlugin {
|
|
|
}
|
|
|
|
|
|
else if ("scsj".equals(e.getOperateKey())) {
|
|
|
- try {
|
|
|
- generateDataFile(getFileUrl("organduserurl"));
|
|
|
- } catch (IOException ex) {
|
|
|
- throw new RuntimeException(ex);
|
|
|
- }
|
|
|
+ generateDataFile(filePath);
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
}
|
|
|
|
|
|
if ("jzsj".equals(e.getOperateKey()))
|
|
@@ -799,172 +803,8 @@ public class TestPlugin extends AbstractListPlugin {
|
|
|
|
|
|
if ("connect".equals(e.getOperateKey()))
|
|
|
{
|
|
|
-
|
|
|
-
|
|
|
- DynamicObject[] personDataArray = BusinessDataServiceHelper.load(
|
|
|
- "nckd_basicdata",
|
|
|
- "id,nckd_employeeid,nckd_name,nckd_gender,nckd_nl,nckd_zzmm,nckd_zgxl,nckd_orgidname,nckd_orgidcode,nckd_posidname,nckd_posidcode,nckd_yggxlb,nckd_status,nckd_sjh",
|
|
|
- null
|
|
|
- );
|
|
|
- if (personDataArray == null || personDataArray.length == 0) {
|
|
|
- this.getView().showMessage("未从 nckd_basicdata 表中获取到任何人员数据!");
|
|
|
- return;
|
|
|
- }
|
|
|
- String msg="";
|
|
|
- for (DynamicObject personData : personDataArray) {
|
|
|
-
|
|
|
- String id=personData.getString("id");
|
|
|
-
|
|
|
- String gonghao = personData.getString("nckd_employeeid");
|
|
|
- if (gonghao == null || gonghao.isEmpty()) {
|
|
|
- continue;
|
|
|
- }
|
|
|
-
|
|
|
- String empname=personData.getString("");
|
|
|
-
|
|
|
- DynamicObject existingUser = BusinessDataServiceHelper.loadSingle(
|
|
|
- "bos_user", new QFilter[]{new QFilter("number", "=", gonghao)}
|
|
|
- );
|
|
|
-
|
|
|
- if (existingUser != null) {
|
|
|
-
|
|
|
- boolean isUpdated = false;
|
|
|
-
|
|
|
- Object newGender = personData.get("nckd_gender");
|
|
|
- if (!newGender.equals(existingUser.get("gender"))) {
|
|
|
- existingUser.set("gender", newGender);
|
|
|
- isUpdated = true;
|
|
|
- }
|
|
|
-
|
|
|
- Object newPhone = personData.get("nckd_sjh");
|
|
|
- if (!newPhone.equals(existingUser.get("phone"))) {
|
|
|
- existingUser.set("phone", newPhone);
|
|
|
- isUpdated = true;
|
|
|
- }
|
|
|
-
|
|
|
- DynamicObjectCollection existingDeptEntries = existingUser.getDynamicObjectCollection("entryentity");
|
|
|
-
|
|
|
- DynamicObject existingDeptEntry = existingDeptEntries.isEmpty() ? null : existingDeptEntries.get(0);
|
|
|
-
|
|
|
- String deptCode = personData.getString("nckd_orgidcode");
|
|
|
- DynamicObject newOrgInfo = BusinessDataServiceHelper.loadSingle(
|
|
|
- "bos_adminorg", new QFilter[]{new QFilter("number", "=", deptCode)}
|
|
|
- );
|
|
|
- boolean deptUpdated = false;
|
|
|
- if (newOrgInfo != null) {
|
|
|
- if (existingDeptEntry == null) {
|
|
|
-
|
|
|
- existingDeptEntry = existingDeptEntries.addNew();
|
|
|
- deptUpdated = true;
|
|
|
- }
|
|
|
-
|
|
|
- if (!deptCode.equals(existingDeptEntry.get("dpt.number"))) {
|
|
|
- existingDeptEntry.set("dpt", newOrgInfo);
|
|
|
- deptUpdated = true;
|
|
|
- }
|
|
|
-
|
|
|
- DynamicObjectCollection structureInfoCollection = newOrgInfo.getDynamicObjectCollection("structure");
|
|
|
- if (structureInfoCollection != null && !structureInfoCollection.isEmpty()) {
|
|
|
- DynamicObject structureInfo = structureInfoCollection.get(0);
|
|
|
- if(existingDeptEntry.getDynamicObject("orgstructure")!=null){
|
|
|
- if (!structureInfo.getPkValue().equals(existingDeptEntry.getDynamicObject("orgstructure").getPkValue())) {
|
|
|
- existingDeptEntry.set("orgstructure", structureInfo.getPkValue());
|
|
|
- deptUpdated = true;
|
|
|
- }
|
|
|
- }else{
|
|
|
- existingDeptEntry.set("orgstructure", structureInfo.getPkValue());
|
|
|
- deptUpdated = true;
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- if (deptUpdated) {
|
|
|
- isUpdated = true;
|
|
|
- }
|
|
|
- } else {
|
|
|
- this.getView().showMessage("未找到部门编码为 " + deptCode + " 的部门信息!");
|
|
|
- }
|
|
|
-
|
|
|
- String postName = personData.getString("nckd_posidname");
|
|
|
- if (!postName.equals(existingDeptEntry.getString("position"))) {
|
|
|
- existingDeptEntry.set("position", postName);
|
|
|
- isUpdated = true;
|
|
|
- }
|
|
|
-
|
|
|
- if (isUpdated) {
|
|
|
- SaveServiceHelper.save(new DynamicObject[]{existingUser});
|
|
|
- msg+="工号为 " + gonghao + " 的用户信息已更新!";
|
|
|
- }
|
|
|
- } else {
|
|
|
-
|
|
|
- DynamicObjectType userType = EntityMetadataCache.getDataEntityType("bos_user");
|
|
|
- DynamicObject userinfo = new DynamicObject(userType);
|
|
|
- ORM impl = ORM.create();
|
|
|
- userinfo.set("id", impl.genLongId("bos_user"));
|
|
|
- userinfo.set("number", gonghao);
|
|
|
-
|
|
|
- userinfo.set("gender", personData.get("nckd_gender"));
|
|
|
-
|
|
|
- userinfo.set("phone", personData.get("nckd_sjh"));
|
|
|
-
|
|
|
- userinfo.set("startdate", new Date());
|
|
|
- Calendar c = Calendar.getInstance();
|
|
|
- c.set(Calendar.YEAR, 2999);
|
|
|
- userinfo.set("enddate", c.getTime());
|
|
|
- userinfo.set("masterid", userinfo.get("id"));
|
|
|
- userinfo.set("enable", 1);
|
|
|
- userinfo.set("status", "C");
|
|
|
- userinfo.set("password", "8HrquJnZfyOkmmHkpGLXfg==");
|
|
|
- userinfo.set("isregisted", "1");
|
|
|
- userinfo.set("isactived", "1");
|
|
|
- userinfo.set("pswstrategy", "338333884850648064");
|
|
|
- userinfo.set("psweffectivedate", new Date());
|
|
|
- userinfo.set("useenddate", c.getTime());
|
|
|
-
|
|
|
- String name = personData.getString("nckd_name");
|
|
|
- userinfo.set("name", name);
|
|
|
- String fullPinyin = UserOperationUtils.getFullSpellByName(name);
|
|
|
- String simplePinyin = UserOperationUtils.getFirstSpellByName(name);
|
|
|
- userinfo.set("fullpinyin", fullPinyin);
|
|
|
- userinfo.set("simplepinyin", simplePinyin);
|
|
|
-
|
|
|
- String username = UserOperationUtils.getUserNameByFormatedFullPinyin(
|
|
|
- (long) userinfo.getPkValue(), fullPinyin, null
|
|
|
- );
|
|
|
- userinfo.set("username", username);
|
|
|
-
|
|
|
- DynamicObjectCollection bmflList = userinfo.getDynamicObjectCollection("entryentity");
|
|
|
- DynamicObject bumeninfo = bmflList.addNew();
|
|
|
-
|
|
|
- String deptCode = personData.getString("nckd_orgidcode");
|
|
|
- DynamicObject orginfo = BusinessDataServiceHelper.loadSingle(
|
|
|
- "bos_adminorg", new QFilter[]{new QFilter("number", "=", deptCode)}
|
|
|
- );
|
|
|
- if (orginfo != null) {
|
|
|
- bumeninfo.set("dpt", orginfo);
|
|
|
-
|
|
|
- DynamicObjectCollection structureInfoCollection = orginfo.getDynamicObjectCollection("structure");
|
|
|
- if (structureInfoCollection != null && !structureInfoCollection.isEmpty()) {
|
|
|
- DynamicObject structureInfo = structureInfoCollection.get(0);
|
|
|
- bumeninfo.set("orgstructure", structureInfo.getPkValue());
|
|
|
- } else {
|
|
|
- this.getView().showMessage("部门编码为 " + deptCode + " 的部门缺少组织结构信息,跳过该记录。");
|
|
|
- }
|
|
|
- }
|
|
|
- String postName = personData.getString("nckd_posidname");;
|
|
|
- bumeninfo.set("position", postName);
|
|
|
-
|
|
|
- String positionnumber = personData.getString("nckd_posidname");;
|
|
|
- bumeninfo.set("post", positionnumber);
|
|
|
-
|
|
|
- SaveServiceHelper.save(new DynamicObject[]{userinfo});
|
|
|
- msg+="工号为 " + gonghao + " 的用户已创建!";
|
|
|
- }
|
|
|
- }
|
|
|
- if("".equals(msg)){
|
|
|
- this.getView().showMessage("没有需要更新或新增的人员");
|
|
|
- }else{
|
|
|
- this.getView().showMessage(msg);
|
|
|
- }
|
|
|
+ generateDataFile(filePath);
|
|
|
+
|
|
|
}
|
|
|
|
|
|
}
|