#
luxiaotao1123
2021-03-01 a2317309f11921582fb59e7ad2545a94f84720bf
#
3个文件已修改
56 ■■■■ 已修改文件
src/main/java/zy/cloud/wms/common/service/MainScheduler.java 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/zy/cloud/wms/common/service/MainService.java 36 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/zy/cloud/wms/common/utils/VersionUtils.java 18 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/zy/cloud/wms/common/service/MainScheduler.java
@@ -32,7 +32,7 @@
        if (Cools.isEmpty(custOrders)){
            return;
        }
        mainService.stockOutProcess(custOrders);
    }
}
src/main/java/zy/cloud/wms/common/service/MainService.java
@@ -2,24 +2,26 @@
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.core.common.Cools;
import com.core.common.SnowflakeIdWorker;
import com.core.exception.CoolException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import zy.cloud.wms.manager.entity.CustOrder;
import zy.cloud.wms.manager.entity.LocDetl;
import zy.cloud.wms.manager.entity.Mat;
import zy.cloud.wms.manager.entity.Prior;
import zy.cloud.wms.common.utils.VersionUtils;
import zy.cloud.wms.manager.entity.*;
import zy.cloud.wms.manager.service.LocDetlService;
import zy.cloud.wms.manager.service.MatService;
import zy.cloud.wms.manager.service.PakoutService;
import zy.cloud.wms.manager.service.PriorService;
import java.util.Date;
import java.util.List;
/**
 * Created by vincent on 2021/3/1
 */
@Slf4j
@Service("mainService")
public class MainService {
@@ -31,24 +33,42 @@
    private PakoutService pakoutService;
    @Autowired
    private PriorService priorService;
    @Autowired
    private SnowflakeIdWorker snowflakeIdWorker;
    @Transactional
    public void stockOutProcess(List<CustOrder> list) {
        if (Cools.isEmpty(list)) {
            return;
        }
        for (CustOrder data : list) {
        Date now = new Date();
        for (CustOrder custOrder : list) {
            // 判断物料是否存在
            Mat mat = matService.selectByMatnr(data.getUserCode());
            Mat mat = matService.selectByMatnr(custOrder.getUserCode());
            if (null == mat) {
                throw new CoolException(data.getUserCode() + "物料尚未更新。" + data.getNumber() +"单据因此中断!");
                throw new CoolException(custOrder.getUserCode() + "物料尚未更新。" + custOrder.getNumber() +"单据因此中断!");
            }
            // 根据推荐库位查找库存
            List<Prior> priors = priorService.selectList(new EntityWrapper<Prior>().eq("matnr", mat.getMatnr()).orderBy("prio"));
            if (!Cools.isEmpty(priors)) {
                for (Prior prior : priors) {
                    LocDetl locDetl = locDetlService.getLocDetl(prior.getNodeId(), prior.getMatnr());
                    if (null != locDetl) {
                    if (null != locDetl && locDetl.getAnfme() > 0) {
                        // 保存出库通知单
                        Pakout pakout = new Pakout();
                        pakout.setWrkSts(1L);
//                        pakout.setAnfme();
                        pakout.setZpallet(locDetl.getZpallet());
                        pakout.setLocNo(locDetl.getLocNo());
                        pakout.setNodeId(locDetl.getNodeId());
                        pakout.setWrkNo(String.valueOf(snowflakeIdWorker.nextId()));
                        VersionUtils.setPakout(pakout, mat);
                        pakout.setCreateTime(now);
                        pakout.setUpdateTime(now);
                        pakout.setStatus(1);
                        if (!pakoutService.insert(pakout)) {
                            throw new CoolException("保存出库通知单失败");
                        }
                    }
                }
src/main/java/zy/cloud/wms/common/utils/VersionUtils.java
@@ -3,6 +3,7 @@
import zy.cloud.wms.manager.entity.Comb;
import zy.cloud.wms.manager.entity.LocDetl;
import zy.cloud.wms.manager.entity.Mat;
import zy.cloud.wms.manager.entity.Pakout;
/**
 * Created by vincent on 2020/7/14
@@ -45,6 +46,23 @@
        locDetl.setWeight(comb.getWeight());
    }
    public static void setPakout(Pakout pakout, Mat mat) {
        pakout.setMatnr(mat.getMatnr());
        pakout.setMaktx(mat.getMaktx());
        pakout.setName(mat.getName());
        pakout.setSpecs(mat.getSpecs());
        pakout.setModel(mat.getModel());
        pakout.setBatch(mat.getBatch());
        pakout.setUnit(mat.getUnit());
        pakout.setBarcode(mat.getBarcode());
        pakout.setDocId(mat.getDocId());
        pakout.setDocNum(mat.getDocNum());
        pakout.setCustName(mat.getCustName());
        pakout.setItemNum(mat.getItemNum());
        pakout.setCount(mat.getCount());
        pakout.setWeight(mat.getWeight());
    }
}