From 6298f178c71f1eb95d4066ffe88d4becd6fc6bfc Mon Sep 17 00:00:00 2001 From: zyx <zyx123456> Date: 星期四, 11 七月 2024 08:34:42 +0800 Subject: [PATCH] #MES上报 --- src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java | 52 +++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 51 insertions(+), 1 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java index 58d4ffb..f555a82 100644 --- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java @@ -15,8 +15,11 @@ import com.zy.asrs.service.*; import com.zy.asrs.utils.MatUtils; import com.zy.common.model.DetlDto; +import com.zy.common.model.LocDetlDto; import com.zy.common.utils.NodeUtils; +import lombok.Synchronized; import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -59,6 +62,10 @@ private WrkDetlService wrkDetlService; @Autowired private ReportQueryMapper reportQueryMapper; + @Autowired + private AgvLocMastService agvLocMastService; + @Autowired + private AgvLocDetlService agvLocDetlService; @Override @Transactional @@ -918,6 +925,49 @@ return true; } + @Override + @Transactional + @Synchronized + public boolean checkAndAdjustLocDetl(CheckParam params) { + + //鍒ゆ柇搴撲綅鏄惁瀛樺湪 + AgvLocMast agvLocMast = agvLocMastService.selectById(params.getLocNo()); + if(Cools.isEmpty(agvLocMast)){ + throw new CoolException("搴撲綅鍙蜂笉瀛樺湪"); + } + + if(!Cools.eq("O",agvLocMast.getLocSts()) && !Cools.eq("F",agvLocMast.getLocSts())){ + throw new CoolException("褰撳墠搴撲綅姝e湪浣滀笟涓紝鏃犳硶鐩樼偣璋冩暣"); + } + + if(Cools.isEmpty(params.getLocDetls())){ + agvLocMast.setLocSts("O"); + }else { + agvLocMast.setLocSts("F"); + } + + agvLocMastService.updateById(agvLocMast); + + //鍒犻櫎鏃у簱瀛� + agvLocDetlService.delete(new EntityWrapper<AgvLocDetl>().eq("loc_no",params.getLocNo())); + + //鏂板鐩樼偣搴撳瓨 + for (DetlDto detlDto : params.getLocDetls()){ + AgvLocDetl agvLocDetl = new AgvLocDetl(); + Mat mat = matService.selectByMatnr(detlDto.getMatnr()); + BeanUtils.copyProperties(mat,agvLocDetl); + agvLocDetl.setLocNo(params.getLocNo()); + agvLocDetl.setSuppCode(params.getContainerCode()); + agvLocDetl.setAnfme(detlDto.getAnfme()); + agvLocDetl.setBatch(detlDto.getBatch()); + agvLocDetl.setThreeCode(detlDto.getCsocode()); + agvLocDetl.setDeadTime(detlDto.getIsoseq()); + agvLocDetlService.insert(agvLocDetl); + } + + return true; + } + private Order orderMapping(OrderSyncParam param, Date now, boolean pakin, String docName){ Order order = new Order(); //uuid @@ -975,7 +1025,7 @@ //鑷敱椤� od.setDeadTime(odParam.getBFree1()); //IDs - od.setSku(odParam.getID()); + od.setSku(odParam.getId()); od.setLength(odParam.getINum()); -- Gitblit v1.9.1