optimize(ebom): 导入到SAP时F项不需要提层,只需要把空的直发包丢弃
This commit is contained in:
parent
b9f37aea55
commit
65d71b8e69
|
|
@ -4,7 +4,6 @@ import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.hutool.core.convert.Convert;
|
import cn.hutool.core.convert.Convert;
|
||||||
import cn.hutool.core.date.DateUtil;
|
import cn.hutool.core.date.DateUtil;
|
||||||
import cn.hutool.core.util.RandomUtil;
|
import cn.hutool.core.util.RandomUtil;
|
||||||
import cn.hutool.core.util.StrUtil;
|
|
||||||
import cn.hutool.extra.spring.SpringUtil;
|
import cn.hutool.extra.spring.SpringUtil;
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
|
|
@ -23,7 +22,6 @@ import nflg.product.common.constant.STATE;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
@ -37,7 +35,6 @@ public class BomNewEbomExportToSAP {
|
||||||
private final static String TAG = "Ebom导入到SAP";
|
private final static String TAG = "Ebom导入到SAP";
|
||||||
|
|
||||||
private final String dateYMD = DateUtil.format(new Date(), "yyyyMMdd");
|
private final String dateYMD = DateUtil.format(new Date(), "yyyyMMdd");
|
||||||
private final Map<String, List<T1ExtDTO>> cmap = new HashMap<>();
|
|
||||||
private final List<T1ExtDTO> children = new ArrayList<>();
|
private final List<T1ExtDTO> children = new ArrayList<>();
|
||||||
|
|
||||||
private final static Logger LOGGER = LoggerFactory.getLogger(BomNewEbomExportToSAP.class);
|
private final static Logger LOGGER = LoggerFactory.getLogger(BomNewEbomExportToSAP.class);
|
||||||
|
|
@ -57,13 +54,15 @@ public class BomNewEbomExportToSAP {
|
||||||
updateSapState(rootBomRowId, SapStatusEnum.PUB_RUNNING);
|
updateSapState(rootBomRowId, SapStatusEnum.PUB_RUNNING);
|
||||||
SapStatusEnum state = SapStatusEnum.PUB_ERROR_ALL;
|
SapStatusEnum state = SapStatusEnum.PUB_ERROR_ALL;
|
||||||
try {
|
try {
|
||||||
buildChildrenForSap(null, root, false);
|
buildChildrenForSap(root);
|
||||||
//移除空的直发包
|
//移除空的直发包
|
||||||
cmap.forEach((k, v) -> {
|
Set<String> zfbMaterialNos = this.children.stream().filter(T1ExtDTO::isZFB).map(T1ExtDTO::getIDNRK).collect(Collectors.toSet());
|
||||||
if (v.isEmpty()) {
|
if (CollUtil.isNotEmpty(zfbMaterialNos)) {
|
||||||
children.removeIf(it -> it.isZFB() && StrUtil.equals(it.getIDNRK(), k));
|
Set<String> allMaterialNos = this.children.stream().map(T1ExtDTO::getMATNR).collect(Collectors.toSet());
|
||||||
}
|
zfbMaterialNos.removeAll(allMaterialNos);
|
||||||
});
|
LOGGER.debug("{} 移除空的直发包:{}", TAG, String.join(",", zfbMaterialNos));
|
||||||
|
this.children.removeIf(c -> c.isZFB() && zfbMaterialNos.contains(c.getIDNRK()));
|
||||||
|
}
|
||||||
|
|
||||||
ImportSapParamDTO sapDto = new ImportSapParamDTO();
|
ImportSapParamDTO sapDto = new ImportSapParamDTO();
|
||||||
sapDto.setZID(RandomUtil.randomNumbers(5));
|
sapDto.setZID(RandomUtil.randomNumbers(5));
|
||||||
|
|
@ -91,65 +90,23 @@ public class BomNewEbomExportToSAP {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 构建child数据
|
* 构建child数据发包编号
|
||||||
* @param zfbMaterialNo 上层的直发包编号
|
|
||||||
* @param p 上级节点的parent
|
* @param p 上级节点的parent
|
||||||
*/
|
*/
|
||||||
private void buildChildrenForSap(String zfbMaterialNo, BomNewEbomParentEntity p, boolean ignore) {
|
private void buildChildrenForSap(BomNewEbomParentEntity p) {
|
||||||
List<BomNewEbomChildEntity> cc = getChildren(p);
|
List<BomNewEbomChildEntity> cc = getChildren(p);
|
||||||
for (BomNewEbomChildEntity it : cc) {
|
for (BomNewEbomChildEntity it : cc) {
|
||||||
handlerItem(zfbMaterialNo, it, p, ignore);
|
handlerItem(it, p);
|
||||||
}
|
}
|
||||||
LOGGER.debug("children数量:" + children.size());
|
LOGGER.debug("children数量:" + children.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handlerItem(String zfbMaterialNo, BomNewEbomChildEntity it, BomNewEbomParentEntity p, boolean ignore) {
|
private void handlerItem(BomNewEbomChildEntity it, BomNewEbomParentEntity p) {
|
||||||
if (StrUtil.equals(it.getProjectType(), ProjectTypeInputTypeEnum.ProjectTypeEnum.TYPE_F.getValue())) {
|
LOGGER.debug("{} 添加物料 编号:{},父级编号:{},数量:{},描述:{}", TAG, it.getMaterialNo(), p.getMaterialNo(), it.getNum().toString(), it.getMaterialDesc());
|
||||||
if (StrUtil.isNotBlank(zfbMaterialNo)) {
|
children.add(convert(it, p.getMaterialNo(), Objects.equals(it.getVirtualPartType(), VirtualPackageTypeEnum.DIRECT_DELIVERY_PACKAGE.getValue())));
|
||||||
T1ExtDTO cct = cmap.get(zfbMaterialNo).stream()
|
|
||||||
.filter(ct -> (StrUtil.equals(ct.getPOSTP(), BomConstant.PROJECT_TYPE_TEMPORARY, true) && StrUtil.equals(ct.getPOTX1(), it.getMaterialDesc()))
|
|
||||||
|| (!StrUtil.equals(ct.getPOSTP(), BomConstant.PROJECT_TYPE_TEMPORARY, true) && StrUtil.equals(ct.getIDNRK(), it.getMaterialNo())))
|
|
||||||
.findFirst()
|
|
||||||
.orElse(null);
|
|
||||||
if (Objects.isNull(cct)) {
|
|
||||||
LOGGER.debug("{} 物料提层到上级直发包 编号:{},父级编号:{},数量:{},描述:{}", TAG, it.getMaterialNo(), p.getMaterialNo(), it.getNum().toString(), it.getMaterialDesc());
|
|
||||||
cct = convert(it, p.getMaterialNo(), false, false);
|
|
||||||
cmap.get(zfbMaterialNo).add(cct);
|
|
||||||
children.add(cct);
|
|
||||||
} else {
|
|
||||||
//合并计算数量
|
|
||||||
cct.setMENGE(new BigDecimal(cct.getMENGE()).add(it.getNum()).toString());
|
|
||||||
LOGGER.debug("{} 物料提层到上级直发包且合并 编号:{},父级编号:{},数量:{},合并后总数:{},描述:{}", TAG, it.getMaterialNo(), p.getMaterialNo(), it.getNum().toString(), cct.getMENGE(), it.getMaterialDesc());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
LOGGER.debug("{} 添加物料 编号:{},父级编号:{},数量:{},描述:{}", TAG, it.getMaterialNo(), p.getMaterialNo(), it.getNum().toString(), it.getMaterialDesc());
|
|
||||||
children.add(convert(it, p.getMaterialNo(), ignore, Objects.equals(it.getVirtualPartType(), VirtualPackageTypeEnum.DIRECT_DELIVERY_PACKAGE.getValue())));
|
|
||||||
}
|
|
||||||
if (it.getVirtualPartType() > VirtualPackageTypeEnum.UN_VIRTUAL_PACKAGE.getValue()
|
|
||||||
&& !Objects.equals(it.getVirtualPartType(), VirtualPackageTypeEnum.MAKING_PACKAGE.getValue())) {
|
|
||||||
zfbMaterialNo = null;
|
|
||||||
}
|
|
||||||
BomNewEbomParentEntity cp = getParent(it);
|
BomNewEbomParentEntity cp = getParent(it);
|
||||||
if (Objects.nonNull(cp)) {
|
if (Objects.nonNull(cp)) {
|
||||||
List<BomNewEbomChildEntity> pcs = getChildren(cp);
|
buildChildrenForSap(cp);
|
||||||
if (CollUtil.isNotEmpty(pcs)) {
|
|
||||||
BomNewEbomChildEntity zfc = pcs.stream()
|
|
||||||
.filter(pt -> Objects.equals(pt.getVirtualPartType(), VirtualPackageTypeEnum.DIRECT_DELIVERY_PACKAGE.getValue()))
|
|
||||||
.findFirst()
|
|
||||||
.orElse(null);
|
|
||||||
if (Objects.nonNull(zfc)) {
|
|
||||||
BomNewEbomParentEntity zfp = getParent(zfc);
|
|
||||||
VUtils.isTure(Objects.isNull(zfp)).throwMessage(StrUtil.format("直发包({})对应的parent丢失", zfc.getMaterialNo()));
|
|
||||||
zfbMaterialNo = zfp.getMaterialNo();
|
|
||||||
cmap.put(zfbMaterialNo, new ArrayList<>());
|
|
||||||
LOGGER.debug("{} 直发包 编号:{},子物料编号:{},描述:{}", TAG, zfbMaterialNo, zfc.getMaterialNo(), zfc.getMaterialDesc());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!ignore && cp.getUserRootIs() == 1) {
|
|
||||||
ignore = true;
|
|
||||||
}
|
|
||||||
buildChildrenForSap(zfbMaterialNo, cp, ignore);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -168,7 +125,7 @@ public class BomNewEbomExportToSAP {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private T1ExtDTO convert(BomNewEbomChildEntity child, String parentMaterialNo, boolean ignore, boolean isZFB) {
|
private T1ExtDTO convert(BomNewEbomChildEntity child, String parentMaterialNo, boolean isZFB) {
|
||||||
T1ExtDTO t = new T1ExtDTO();
|
T1ExtDTO t = new T1ExtDTO();
|
||||||
t.setID(RandomUtil.randomNumbers(5));
|
t.setID(RandomUtil.randomNumbers(5));
|
||||||
t.setMATNR(parentMaterialNo);
|
t.setMATNR(parentMaterialNo);
|
||||||
|
|
@ -177,7 +134,7 @@ public class BomNewEbomExportToSAP {
|
||||||
t.setDATUM(dateYMD);
|
t.setDATUM(dateYMD);
|
||||||
t.setMEINS(child.getMaterialUnit());
|
t.setMEINS(child.getMaterialUnit());
|
||||||
t.setIDNRK(child.getMaterialNo());
|
t.setIDNRK(child.getMaterialNo());
|
||||||
t.setIgnore(ignore);
|
t.setIgnore(false);
|
||||||
t.setZFB(isZFB);
|
t.setZFB(isZFB);
|
||||||
if (BomConstant.PROJECT_TYPE_TEMPORARY.equals(child.getProjectType())) {
|
if (BomConstant.PROJECT_TYPE_TEMPORARY.equals(child.getProjectType())) {
|
||||||
t.setIDNRK("");
|
t.setIDNRK("");
|
||||||
|
|
@ -191,6 +148,7 @@ public class BomNewEbomExportToSAP {
|
||||||
.select(BomNewEbomParentEntity::getRowId, BomNewEbomParentEntity::getMaterialNo
|
.select(BomNewEbomParentEntity::getRowId, BomNewEbomParentEntity::getMaterialNo
|
||||||
, BomNewEbomParentEntity::getMaterialDesc, BomNewEbomParentEntity::getUserRootIs)
|
, BomNewEbomParentEntity::getMaterialDesc, BomNewEbomParentEntity::getUserRootIs)
|
||||||
.eq(BomNewEbomParentEntity::getMaterialNo, c.getMaterialNo())
|
.eq(BomNewEbomParentEntity::getMaterialNo, c.getMaterialNo())
|
||||||
|
.eq(BomNewEbomParentEntity::getUserRootIs, 0)
|
||||||
.eq(BomNewEbomParentEntity::getStatus, EBomStatusEnum.PUBLISHED.getValue())
|
.eq(BomNewEbomParentEntity::getStatus, EBomStatusEnum.PUBLISHED.getValue())
|
||||||
.ne(BomNewEbomParentEntity::getSource, EBomSourceEnum.FROM_SAP.getValue())
|
.ne(BomNewEbomParentEntity::getSource, EBomSourceEnum.FROM_SAP.getValue())
|
||||||
.orderByDesc(BomNewEbomParentEntity::getCurrentVersion)
|
.orderByDesc(BomNewEbomParentEntity::getCurrentVersion)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue