Merge remote-tracking branch 'origin/main'

This commit is contained in:
lihao 2025-09-25 08:52:05 +08:00
commit fe1fb5afd6
3 changed files with 172 additions and 73 deletions

View File

@ -6,6 +6,7 @@ import java.util.List;
import java.util.Map;
import nc.bs.mmpac.pmo.pac0002.bp.rule.AfterPmoSyncJmQMSRule;
import nc.bs.mmpac.pmo.pac0002.bp.rule.PutBeforeCheckStatusRule;
import nc.bs.mmpac.pmo.pac0002.bp.service.PMOBPService;
import nc.bs.mmpac.pmo.pac0002.bp.util.PMOBPUtil;
import nc.bs.mmpac.pmo.pac0002.pluginpoint.PMOPluginPoint;
@ -118,6 +119,7 @@ public class PMORowPutBP {
processer.addBeforeRule(new PMOFillPutValueRule(false));
processer.addBeforeRule(new PMOFillBatchCodeRule());
processer.addBeforeRule(new putBeforeCheckRule());
processer.addBeforeRule(new PutBeforeCheckStatusRule());
}
private void addRowPutAfterRule(CompareAroundProcesser<PMOAggVO> processer) {

View File

@ -0,0 +1,97 @@
package nc.bs.mmpac.pmo.pac0002.bp.rule;
import nc.bs.framework.common.NCLocator;
import nc.bs.uapbd.util.MyHelper;
import nc.impl.pubapp.pattern.rule.IRule;
import nc.itf.uif.pub.IUifService;
import nc.vo.mmpac.pmo.pac0002.entity.PMOAggVO;
import nc.vo.mmpac.pmo.pac0002.entity.PMOHeadVO;
import nc.vo.mmpac.pmo.pac0002.entity.PMOItemVO;
import nc.vo.org.DeptVO;
import nc.vo.org.OrgVO;
import nc.vo.pub.BusinessException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* 电力电子-流程生产订单投放前检查艾普MES的传输状态
*
* @author mzr
* @date 2025/9/24
*/
public class PutBeforeCheckStatusRule implements IRule<PMOAggVO> {
private static IUifService service = (IUifService) NCLocator.getInstance().lookup(IUifService.class.getName());
private Map<String, String> configParams;
private Map<String, String> deptParams;
@Override
public void process(PMOAggVO[] vos) {
try {
configParams = MyHelper.getConfigParams("Dldz-config", null);
if (configParams.isEmpty()) {
return;
}
deptParams = MyHelper.getConfigParams("Dldz-dept", null);
if (deptParams.isEmpty()) {
return;
}
String deptRange = String.join(",", deptParams.keySet());
configParams.put("deptRange", deptRange);
List<PMOAggVO> filteredOrders = checkAndFilterBillSrcOrg(vos);
if (filteredOrders.isEmpty()) {
return;
}
for (PMOAggVO vo : vos) {
PMOItemVO[] itemVOS = vo.getChildrenVO();
for (PMOItemVO itemVO : itemVOS) {
Object vdef34 = itemVO.getAttributeValue("vdef34");
if (!"Y".equals(vdef34)) {
throw new BusinessException("请先将流程生产订单推送艾普MES成功后再投放");
}
}
}
} catch (BusinessException e) {
throw new RuntimeException(e);
}
}
/**
* 检查并筛选需要同步的单据
*/
private List<PMOAggVO> checkAndFilterBillSrcOrg(PMOAggVO[] pmoAggVOS) throws BusinessException {
Set<String> billTypeCodes = Set.of(
"55A2-Cxx-01", "55A2-Cxx-18"
);
List<PMOAggVO> aggvoList = new ArrayList<>();
for (PMOAggVO aggVo : pmoAggVOS) {
PMOHeadVO headVO = aggVo.getParentVO();
// 判断订单类型,期初订单不处理
String vtrantypecode = headVO.getVtrantypecode();
if (billTypeCodes.contains(vtrantypecode)) {
continue;
}
String pkOrg = headVO.getPk_org();
String orgCode = MyHelper.transferField(OrgVO.getDefaultTableName(), OrgVO.CODE, OrgVO.PK_ORG, pkOrg);
// 检查当前组织是否为电力电子
if (MyHelper.checkIfDldzOrg(orgCode, configParams)) {
continue;
}
// 按照部门筛选生产订单只传消弧车间电容车间成套车间部门是配置项
PMOItemVO childrenVO = aggVo.getChildrenVO()[0];
String cdeptid = childrenVO.getCdeptid();
String deptCode = MyHelper.transferField(DeptVO.getDefaultTableName(), DeptVO.CODE, DeptVO.PK_DEPT, cdeptid);
// 如果部门不在范围内则跳过本次循环
String deptRange = configParams.get("deptRange");
if (deptCode == null || !deptRange.contains(deptCode)) {
continue;
}
aggvoList.add(aggVo);
}
return aggvoList;
}
}

View File

@ -189,13 +189,13 @@ public class MaterialToEpicMesListener implements IBusinessListener {
String[] orgItem = targetCode.split(",");
String inStr = SqlUtils.getInStr("b.code", orgItem, Boolean.TRUE);
// 物料-库存信息-物料类型 DR=分销补货;FR=工厂补货;MR=制造件;PR=采购件;OT=委外件;ET=其他
// mes物料类型 制造1 其它0(ERP多个组织中如果有一个是制造件就传1)
// mes物料类型 制造1 其它0(ERP多个组织中如果有一个是制造件或虚拟件(其他)就传1)
String mesType = "0";
// String martype = MyHelper.transferField(MaterialStockVO.getDefaultTableName(), MaterialStockVO.MARTYPE, MaterialStockVO.PK_MATERIAL, pkMaterial);
String countSql = "SELECT count(1)" +
" FROM bd_materialstock a" +
" LEFT JOIN org_stockorg b ON a.pk_org = b.pk_stockorg" +
" WHERE a.dr = 0 AND a.martype = 'MR' " +
" WHERE a.dr = 0 AND a.martype IN ('MR','ET') " +
" AND a.pk_material = '[pkMaterial]'" +
" AND " + inStr;
countSql = countSql.replace("[pkMaterial]", pkMaterial);