2024-08-29 17:01:41 +08:00
|
|
|
|
package com.yem.em.task;
|
|
|
|
|
|
|
|
|
|
import com.yem.rf.utils.RFUtils;
|
|
|
|
|
import com.yem.wm.utils.DynamicObjectUtil;
|
2024-09-09 15:31:49 +08:00
|
|
|
|
import com.yem.wm.utils.YEM;
|
2024-08-29 17:01:41 +08:00
|
|
|
|
import kd.bos.context.RequestContext;
|
|
|
|
|
import kd.bos.dataentity.entity.DynamicObject;
|
|
|
|
|
import kd.bos.dataentity.entity.DynamicObjectCollection;
|
|
|
|
|
import kd.bos.exception.KDException;
|
|
|
|
|
import kd.bos.orm.query.QFilter;
|
|
|
|
|
import kd.bos.schedule.executor.AbstractTask;
|
|
|
|
|
import kd.bos.servicehelper.BusinessDataServiceHelper;
|
|
|
|
|
import kd.bos.servicehelper.operation.SaveServiceHelper;
|
2024-09-02 15:09:25 +08:00
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
|
import org.slf4j.LoggerFactory;
|
2024-08-29 17:01:41 +08:00
|
|
|
|
|
|
|
|
|
import java.math.BigDecimal;
|
2024-09-02 09:33:19 +08:00
|
|
|
|
import java.util.Date;
|
2024-08-29 17:01:41 +08:00
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
|
|
|
|
/**
|
2024-09-09 11:45:33 +08:00
|
|
|
|
* @Description: 1.根据《PLM变更单》中的
|
2024-08-29 17:01:41 +08:00
|
|
|
|
* 【PLM工艺变更单号】+【总成编码】+【子项零件编码】+【子件数量】
|
|
|
|
|
* 匹配《BOM》变更单
|
|
|
|
|
* 【更改单号】+【总成编码】+【子项零件编码】+【数量】+【启用停用状态=‘停用’】更新 《PLM变更单》【启用停用状态】【启用停用时间】;
|
|
|
|
|
* <p>
|
|
|
|
|
* 2.根据《PLM变更单》中的
|
|
|
|
|
* 【PLM工艺变更单号】+【替换后总成编码】+【替换后子项零件编码】+【替换子件数量】
|
|
|
|
|
* 匹配《BOM》变更单
|
|
|
|
|
* 【更改单号】+【总成编码】+【子项零件编码】+【数量】+【启用停用状态=‘启用’】更新 《PLM变更单》【替换件启用停用状态】【替换件启用停用时间】;
|
|
|
|
|
* @Date: 2024/8/29 15:08
|
|
|
|
|
* @Created: by ZZSLL
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
public class MatchingPLMChangeUpdateTaskEdit extends AbstractTask {
|
|
|
|
|
|
2024-09-02 15:09:25 +08:00
|
|
|
|
private static Logger logger = LoggerFactory.getLogger(MatchingPLMChangeUpdateTaskEdit.class);
|
|
|
|
|
|
2024-08-29 17:01:41 +08:00
|
|
|
|
@Override
|
|
|
|
|
public void execute(RequestContext requestContext, Map<String, Object> map) throws KDException {
|
|
|
|
|
DynamicObject[] plms = queryPLMChange();
|
|
|
|
|
DynamicObject[] boms = queryBOMChange();
|
|
|
|
|
|
2024-09-10 15:38:40 +08:00
|
|
|
|
for (DynamicObject bomObj : boms) {
|
|
|
|
|
DynamicObjectCollection bom_entry = bomObj.getDynamicObjectCollection("yem_entryentity");
|
|
|
|
|
for (DynamicObject bom : bom_entry) {
|
|
|
|
|
for (DynamicObject plmObj : plms) {
|
|
|
|
|
DynamicObjectCollection plm_entry = plmObj.getDynamicObjectCollection("yem_change_detail");
|
|
|
|
|
for (DynamicObject plm : plm_entry) {
|
|
|
|
|
String plm_billno = plmObj.getString("yem_gybg_no");//PLM工艺变更单号
|
|
|
|
|
String plm_parent = plm.getString("yem_textfield");//总成编码
|
2024-09-09 11:45:33 +08:00
|
|
|
|
String bom_enablesta = bom.getString("yem_enablesta");//启用停用状态
|
2024-09-10 14:27:50 +08:00
|
|
|
|
Date bom_completetime = bom.getDate("yem_completetime");
|
|
|
|
|
Boolean plmMatchBom = isPlmMatchBom(plmObj, bom, plm);
|
|
|
|
|
if (plmMatchBom != null && !plmMatchBom) {
|
2024-09-09 15:31:49 +08:00
|
|
|
|
Date stoptime = plm.getDate("yem_stoptime");
|
|
|
|
|
if (YEM.isEmpty(stoptime)) {
|
2024-09-10 14:27:50 +08:00
|
|
|
|
plm.set("yem_enablestatus_before", bom_enablesta);
|
2024-09-09 17:58:30 +08:00
|
|
|
|
Date downdate = bom.getDate("yem_downdate");
|
|
|
|
|
plm.set("yem_stoptime", downdate);
|
2024-09-10 14:27:50 +08:00
|
|
|
|
plm.set("yem_completetime", bom_completetime);
|
2024-09-09 15:31:49 +08:00
|
|
|
|
} else {
|
|
|
|
|
logger.info("停用_已有时间,不更新,{},{}", plm_billno, plm_parent);
|
|
|
|
|
}
|
2024-09-09 11:45:33 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-09-10 14:27:50 +08:00
|
|
|
|
if (plmMatchBom != null && plmMatchBom) {
|
2024-09-09 15:31:49 +08:00
|
|
|
|
Date starttime = plm.getDate("yem_starttime");
|
|
|
|
|
if (YEM.isEmpty(starttime)) {
|
2024-09-09 17:58:30 +08:00
|
|
|
|
Date enableddate = bom.getDate("yem_enableddate");
|
2024-09-09 15:31:49 +08:00
|
|
|
|
plm.set("yem_enablesta", bom_enablesta);
|
2024-09-09 17:58:30 +08:00
|
|
|
|
plm.set("yem_starttime", enableddate);
|
2024-09-10 14:27:50 +08:00
|
|
|
|
plm.set("yem_completetime", bom_completetime);
|
2024-09-09 15:31:49 +08:00
|
|
|
|
} else {
|
|
|
|
|
logger.info("启用_已有时间,不更新,{},{}", plm_billno, plm_parent);
|
|
|
|
|
}
|
2024-08-29 17:01:41 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-09-10 15:38:40 +08:00
|
|
|
|
//
|
|
|
|
|
// for (DynamicObject plmObj : plms) {
|
|
|
|
|
// DynamicObjectCollection plm_entry = plmObj.getDynamicObjectCollection("yem_change_detail");
|
|
|
|
|
// String plm_billno = plmObj.getString("yem_gybg_no");//PLM工艺变更单号
|
|
|
|
|
// for (DynamicObject plm : plm_entry) {
|
|
|
|
|
// String plm_parent = plm.getString("yem_textfield");//总成编码
|
|
|
|
|
// for (DynamicObject bomObj : boms) {
|
|
|
|
|
// DynamicObjectCollection bom_entry = bomObj.getDynamicObjectCollection("yem_entryentity");
|
|
|
|
|
// for (DynamicObject bom : bom_entry) {
|
|
|
|
|
// String bom_enablesta = bom.getString("yem_enablesta");//启用停用状态
|
|
|
|
|
// Date bom_completetime = bom.getDate("yem_completetime");
|
|
|
|
|
// Boolean plmMatchBom = isPlmMatchBom(plmObj, bom, plm);
|
|
|
|
|
// if (plmMatchBom != null && !plmMatchBom) {
|
|
|
|
|
// Date stoptime = plm.getDate("yem_stoptime");
|
|
|
|
|
// if (YEM.isEmpty(stoptime)) {
|
|
|
|
|
// plm.set("yem_enablestatus_before", bom_enablesta);
|
|
|
|
|
// Date downdate = bom.getDate("yem_downdate");
|
|
|
|
|
// plm.set("yem_stoptime", downdate);
|
|
|
|
|
// plm.set("yem_completetime", bom_completetime);
|
|
|
|
|
// } else {
|
|
|
|
|
// logger.info("停用_已有时间,不更新,{},{}", plm_billno, plm_parent);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// if (plmMatchBom != null && plmMatchBom) {
|
|
|
|
|
// Date starttime = plm.getDate("yem_starttime");
|
|
|
|
|
// if (YEM.isEmpty(starttime)) {
|
|
|
|
|
// Date enableddate = bom.getDate("yem_enableddate");
|
|
|
|
|
// plm.set("yem_enablesta", bom_enablesta);
|
|
|
|
|
// plm.set("yem_starttime", enableddate);
|
|
|
|
|
// plm.set("yem_completetime", bom_completetime);
|
|
|
|
|
// } else {
|
|
|
|
|
// logger.info("启用_已有时间,不更新,{},{}", plm_billno, plm_parent);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
2024-08-29 17:01:41 +08:00
|
|
|
|
|
|
|
|
|
SaveServiceHelper.save(plms);
|
|
|
|
|
}
|
|
|
|
|
|
2024-09-10 14:27:50 +08:00
|
|
|
|
/**
|
|
|
|
|
* PLM匹配BOM,
|
|
|
|
|
* @param plmObj
|
|
|
|
|
* @param bom
|
|
|
|
|
* @param plm
|
|
|
|
|
* @return 匹配到停用返回false,启用返回true,未匹配到返回null
|
|
|
|
|
*/
|
|
|
|
|
public static Boolean isPlmMatchBom(DynamicObject plmObj, DynamicObject bom, DynamicObject plm) {
|
|
|
|
|
String plm_billno = plmObj.getString("yem_gybg_no");//PLM工艺变更单号
|
|
|
|
|
String bom_billno = bom.getString("yem_changeno");//更改单号
|
|
|
|
|
String bom_parent = bom.getString("yem_parentno");//父件编码
|
|
|
|
|
String bom_child = bom.getString("yem_subno");//子项零件编码
|
|
|
|
|
BigDecimal bom_qty = bom.getBigDecimal("yem_qty");//数量
|
|
|
|
|
String bom_enablesta = bom.getString("yem_enablesta");//启用停用状态
|
|
|
|
|
String plm_parent = plm.getString("yem_textfield");//总成编码
|
|
|
|
|
String plm_child = plm.getString("yem_child_before");//子项零件编码
|
|
|
|
|
BigDecimal plm_qty = plm.getBigDecimal("yem_qty_before");//子件数量
|
|
|
|
|
String plm_after_parent_now = plm.getString("yem_parent_now");//父项编码
|
|
|
|
|
String plm_after_child_now = plm.getString("yem_child_now");//子项编码
|
|
|
|
|
BigDecimal plm_after_qty = plm.getBigDecimal("yem_qty_new");
|
|
|
|
|
|
|
|
|
|
String bom_before_parent_no = bom.getString("yem_parentno");//总成编码
|
|
|
|
|
String bom_before_child_no = bom.getString("yem_subno");//数量
|
|
|
|
|
BigDecimal bom_before_qty = bom.getBigDecimal("yem_qty");
|
|
|
|
|
logger.info("停用_compare: {} {}, {} {}, {} {}, {} {}, {}", plm_billno, bom_billno, plm_parent, bom_parent, plm_child, bom_child, plm_qty, bom_child, bom_enablesta);
|
|
|
|
|
if (eq(plm_billno, bom_billno) && eq(plm_parent, bom_parent) && eq(plm_child, bom_child) && eq(plm_qty, bom_qty) && "B".equals(bom_enablesta)) {
|
|
|
|
|
logger.info("停用_PLM匹配到BOM,{} {}, {} {}, {} {}, {} {}", plm_billno, bom_billno, plm_parent, bom_parent, plm_child, bom_child, plm_qty, bom_qty);
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
logger.info("启用_compare:{} {}, {} {}, {} {}, {} {}, {}", plm_billno, bom_billno,plm_after_parent_now, bom_before_parent_no, plm_after_child_now, bom_before_child_no, plm_after_qty, bom_before_qty, bom_enablesta);
|
|
|
|
|
if (eq(plm_billno, bom_billno) && eq(plm_after_parent_now, bom_before_parent_no) && eq(plm_after_child_now, bom_before_child_no) && eq(plm_after_qty, bom_before_qty) && "A".equals(bom_enablesta)) {
|
|
|
|
|
logger.info("启用_PLM匹配到BOM,{} {}, {} {}, {} {}, {} {}", plm_billno, bom_billno,plm_after_parent_now, bom_before_parent_no, plm_after_child_now, bom_before_child_no, plm_after_qty, bom_before_qty);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static boolean eq(Object str1, Object str2) {
|
2024-08-29 17:01:41 +08:00
|
|
|
|
if (str1 instanceof String && str2 instanceof String) {
|
|
|
|
|
return str1.equals(str2);
|
|
|
|
|
}
|
|
|
|
|
if (str1 instanceof BigDecimal && str2 instanceof BigDecimal) {
|
|
|
|
|
return ((BigDecimal) str1).compareTo((BigDecimal) str2) == 0;
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DynamicObject[] queryPLMChange() {
|
|
|
|
|
final String formId = "yem_changecompare";
|
|
|
|
|
final String entryId = "yem_change_detail";
|
|
|
|
|
String selectfields = DynamicObjectUtil.getSelectfields(formId);
|
|
|
|
|
selectfields = DynamicObjectUtil.getEntrySelectfields(selectfields, formId, entryId);
|
|
|
|
|
QFilter qFilter = RFUtils.getBaseQFilter();
|
|
|
|
|
return BusinessDataServiceHelper.load(formId, selectfields, qFilter.toArray());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DynamicObject[] queryBOMChange() {
|
|
|
|
|
final String formId = "yem_em_bomchange";
|
|
|
|
|
final String entryId = "yem_entryentity";
|
|
|
|
|
String selectfields = DynamicObjectUtil.getSelectfields(formId);
|
|
|
|
|
selectfields = DynamicObjectUtil.getEntrySelectfields(selectfields, formId, entryId);
|
2024-09-02 15:09:25 +08:00
|
|
|
|
QFilter qFilter = new QFilter("status", "=", "C");
|
2024-08-29 17:01:41 +08:00
|
|
|
|
return BusinessDataServiceHelper.load(formId, selectfields, qFilter.toArray());
|
|
|
|
|
}
|
|
|
|
|
}
|