|
|
|
@ -123,14 +123,14 @@ public class MesAssemblyGeneratePartNoStepService extends BaseStepService {
|
|
|
|
|
//搜集装配件条码
|
|
|
|
|
String assemblySn = equipVariableCollectContextList.stream().filter(o -> null != o).map(MesEquipVariableCollectContext::getEquipVariableValue).collect(Collectors.toList()).toString();
|
|
|
|
|
|
|
|
|
|
//未知腔数配置【工位参数】, 不验证装配件条码的个数
|
|
|
|
|
String cavityUnknownCfg = getCavityUnknownCfg(reqBean);
|
|
|
|
|
//未知腔数配置【工位参数】, 不验证装配件条码的个数, 默认非未知腔数=2
|
|
|
|
|
Boolean cavityUnknownCfg = checkWcpcMapIsMatch(reqBean, MesPcnExtConstWords.CAVITY_UNKNOWN_CFG);
|
|
|
|
|
|
|
|
|
|
//根据设备代码获取可复用条码的个数
|
|
|
|
|
Integer repeatAssemblySnCount = productionCustomContextStepService.getRepeatAssemblySnCount(reqBean.getOrganizeCode(), reqBean.getWorkCenterCode(), reqBean.getWorkCellCode(), cellEquipContext.getEquipmentCode());
|
|
|
|
|
Integer repeatAssemblySnAmount = repeatAssemblySnCount * (!CollectionUtils.isEmpty(curProductionPsInContextList) ? curProductionPsInContextList.size() : 1);
|
|
|
|
|
//非未知腔数,验证装配件条码个数是否匹配 腔数或者未匹配的主条码个数*每腔个数
|
|
|
|
|
if (StringUtils.isEmpty(cavityUnknownCfg) && (equipVariableCollectContextList.size() + repeatAssemblySnAmount) != (!CollectionUtils.isEmpty(curProductionPsInContextList) ? curProductionPsInContextList.size() : cellEquipContext.getCavity()) * cellEquipContext.getBindQty()) {
|
|
|
|
|
if (!cavityUnknownCfg && (equipVariableCollectContextList.size() + repeatAssemblySnAmount) != (!CollectionUtils.isEmpty(curProductionPsInContextList) ? curProductionPsInContextList.size() : cellEquipContext.getCavity()) * cellEquipContext.getBindQty()) {
|
|
|
|
|
String suffix = repeatAssemblySnAmount == 0 ? MesPcnExtConstWords.EMPTY : String.format(",可复用个数[%s]", repeatAssemblySnAmount);
|
|
|
|
|
if (!CollectionUtils.isEmpty(curProductionPsInContextList)) {
|
|
|
|
|
productionDispatchContextStepService.dispatchProductionPsInContext(reqBean, productionPsInContextList.stream().filter(o -> (null != o && !StringUtils.isEmpty(o.getForeignKey()))).collect(Collectors.toList()));
|
|
|
|
@ -166,10 +166,10 @@ public class MesAssemblyGeneratePartNoStepService extends BaseStepService {
|
|
|
|
|
MesPcnEnumUtil.STATION_BUSI_TYPE.RUNNING_INFO, MesPcnEnumUtil.STATION_DATA_TYPE.EXP_TEXT);
|
|
|
|
|
|
|
|
|
|
stepResult.msg(String.format("%s%s", suffix, !StringUtils.isEmpty(stepResult.getMsg()) ? stepResult.getMsg() : (
|
|
|
|
|
StringUtils.isEmpty(stepResult.getObj()) ? MesPcnExtConstWords.EMPTY : (
|
|
|
|
|
(!stepResult.getObj().toString().contains(MesPcnExtConstWords.EXCLAMATION) ||
|
|
|
|
|
stepResult.getObj().toString().indexOf(MesPcnExtConstWords.EXCLAMATION) != stepResult.getObj().toString().lastIndexOf(MesPcnExtConstWords.EXCLAMATION)
|
|
|
|
|
) ? MesPcnExtConstWords.EMPTY : stepResult.getObj()))
|
|
|
|
|
(StringUtils.isEmpty(stepResult.getObj()) || !checkWcpcMapIsMatch(reqBean, MesPcnExtConstWords.ASSEMBLY_SHOW_MR_CFG)) ? MesPcnExtConstWords.EMPTY : (
|
|
|
|
|
(!stepResult.getObj().toString().contains(MesPcnExtConstWords.EXCLAMATION) ||
|
|
|
|
|
stepResult.getObj().toString().indexOf(MesPcnExtConstWords.EXCLAMATION) != stepResult.getObj().toString().lastIndexOf(MesPcnExtConstWords.EXCLAMATION)
|
|
|
|
|
) ? MesPcnExtConstWords.EMPTY : stepResult.getObj()))
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
@ -206,10 +206,9 @@ public class MesAssemblyGeneratePartNoStepService extends BaseStepService {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//未知腔数配置【工位参数】
|
|
|
|
|
private String getCavityUnknownCfg(StationRequestBean reqBean) {
|
|
|
|
|
String cavityUnknownCfg = fsmCommonService.handleFsmWcpcMapDataForDoScan(reqBean).get(MesPcnExtConstWords.CAVITY_UNKNOWN_CFG);
|
|
|
|
|
return (!StringUtils.isEmpty(cavityUnknownCfg) && cavityUnknownCfg.equals(CommonEnumUtil.TRUE_OR_FALSE.TRUE.getValueStr())) ? cavityUnknownCfg : null;
|
|
|
|
|
//【工位参数】
|
|
|
|
|
private Boolean checkWcpcMapIsMatch(StationRequestBean reqBean, String paramCode) {
|
|
|
|
|
return fsmCommonService.checkWcpcMapIsMatch(reqBean, paramCode, CommonEnumUtil.TRUE_OR_FALSE.TRUE.getValueStr());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//获取设备下所有的装配件规则清单, 根据非排序加工规则ID分组
|
|
|
|
@ -238,7 +237,7 @@ public class MesAssemblyGeneratePartNoStepService extends BaseStepService {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//生成零件号业务处理
|
|
|
|
|
private List<MesProdRuleContext> doHandleAssemblyGeneratePartNo(StationRequestBean reqBean, StationResultBean resultBean, StepResult stepResult, MesCellEquipContext cellEquipContext, String cavityUnknownCfg,
|
|
|
|
|
private List<MesProdRuleContext> doHandleAssemblyGeneratePartNo(StationRequestBean reqBean, StationResultBean resultBean, StepResult stepResult, MesCellEquipContext cellEquipContext, Boolean cavityUnknownCfg,
|
|
|
|
|
MesProductionProcessContext productionProcessContext, List<MesProductionPsInContext> productionPsInContextList, List<MesProdRuleContext> prodRuleContextList,
|
|
|
|
|
Map<Long, List<MesProductionAssemblyNosortContext>> assemblyNosortCfgMap, List<MesEquipVariableCollectContext> equipVariableCollectContextList,
|
|
|
|
|
Map<String, List<MesProdRuleIgnoreCfg>> prodRuleIgnoreCfgMap) {
|
|
|
|
@ -263,7 +262,7 @@ public class MesAssemblyGeneratePartNoStepService extends BaseStepService {
|
|
|
|
|
if (CollectionUtils.isEmpty(productionAssemblyNosortContextList)) continue;
|
|
|
|
|
|
|
|
|
|
//没有未知腔数配置, 剔除装配件规则个数不等于每腔个数的数据
|
|
|
|
|
if (StringUtils.isEmpty(cavityUnknownCfg) && cellEquipContext.getBindQty().compareTo(productionAssemblyNosortContextList.size()) != 0) continue;
|
|
|
|
|
if (!cavityUnknownCfg && cellEquipContext.getBindQty().compareTo(productionAssemblyNosortContextList.size()) != 0) continue;
|
|
|
|
|
|
|
|
|
|
//收集未消费的临时数据
|
|
|
|
|
List<MesEquipVariableCollectContext> equipVariableCollectContextListTemp = DeepCloneUtil.deepCloneList(unConsumeList);
|
|
|
|
|