ensign/src/main/java/com/yem/em/task/MatchingPLMChangeUpdateTaskEdit.java

126 lines
7.0 KiB
Java
Raw Normal View History

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;
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();
for (DynamicObject plmObj : plms) {
DynamicObjectCollection plm_entry = plmObj.getDynamicObjectCollection("yem_change_detail");
2024-09-09 11:45:33 +08:00
String plm_billno = plmObj.getString("yem_gybg_no");//PLM工艺变更单号
2024-08-29 17:01:41 +08:00
for (DynamicObject plm : plm_entry) {
2024-09-09 11:45:33 +08:00
String plm_parent = plm.getString("yem_textfield");//总成编码
String plm_child = plm.getString("yem_child_before");//子项零件编码
2024-08-29 17:01:41 +08:00
BigDecimal plm_qty = plm.getBigDecimal("yem_qty_before");//子件数量
2024-09-09 11:45:33 +08:00
String invokstatus = plm.getString("yem_invokstatus");
if ("B".equals(invokstatus)) {
logger.info("执行状态为已完成,跳过:{},父项编码:{}", plm_billno, plm_parent);
continue;
}
2024-08-29 17:01:41 +08:00
for (DynamicObject bomObj : boms) {
DynamicObjectCollection bom_entry = bomObj.getDynamicObjectCollection("yem_entryentity");
for (DynamicObject bom : bom_entry) {
String bom_billno = bom.getString("yem_changeno");//更改单号
2024-09-09 11:45:33 +08:00
String bom_parent = bom.getString("yem_parentno");//父件编码
2024-08-29 17:01:41 +08:00
String bom_child = bom.getString("yem_subno");//子项零件编码
BigDecimal bom_qty = bom.getBigDecimal("yem_qty");//数量
2024-09-09 11:45:33 +08:00
String bom_enablesta = bom.getString("yem_enablesta");//启用停用状态
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);
plm.set("yem_enablesta", bom_enablesta);
plm.set("yem_stoptime", new Date());
plm.set("yem_invokstatus", "B");
plm.set("yem_invoktime", new Date());
}
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_after_parent_no = bom.getString("yem_enableparno");//替换后总成编码
String bom_after_child_no = bom.getString("yem_enablesubno");//替换子件编码
BigDecimal bom_after_qty = bom.getBigDecimal("yem_enablesubqty");
logger.info("启用_compare{} {}, {} {}, {} {}, {} {}, {}", plm_billno, bom_billno,plm_after_parent_now, bom_after_parent_no, plm_after_child_now, bom_after_child_no, plm_after_qty, bom_after_qty, bom_enablesta);
if (eq(plm_billno, bom_billno) && eq(plm_after_parent_now, bom_after_parent_no) && eq(plm_after_child_now, bom_after_child_no) && eq(plm_after_qty, bom_after_qty) && "A".equals(bom_enablesta)) {
logger.info("启用_PLM匹配到BOM{} {}, {} {}, {} {}, {} {}", plm_billno, bom_billno,plm_after_parent_now, bom_after_parent_no, plm_after_child_now, bom_after_child_no, plm_after_qty, bom_after_qty);
plm.set("yem_enablesta", bom_enablesta);
plm.set("yem_starttime", new Date());
plm.set("yem_invokstatus", "B");
plm.set("yem_invoktime", new Date());
2024-08-29 17:01:41 +08:00
}
}
}
}
}
SaveServiceHelper.save(plms);
}
private boolean eq(Object str1, Object str2) {
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());
}
}