From 21d0e7ab9d5c7316225a3e9eecf465cd37c9bd85 Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期四, 05 六月 2025 14:15:07 +0800 Subject: [PATCH] 123 --- src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java | 91 +++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 83 insertions(+), 8 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java index 3d42664..0a50dce 100644 --- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java @@ -3,10 +3,7 @@ import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; -import com.core.common.BaseRes; -import com.core.common.Cools; -import com.core.common.DateUtils; -import com.core.common.SnowflakeIdWorker; +import com.core.common.*; import com.core.exception.CoolException; import com.zy.asrs.entity.*; import com.zy.asrs.entity.param.CombParam; @@ -122,7 +119,7 @@ } if (Cools.isEmpty(detlDto.getOwner())){ - detlDto.setOwner(0L); + detlDto.setOwner(1L); } if (DetlDto.has(detlDtos, detlDto)) { @@ -157,6 +154,7 @@ waitPakin.setFrozen(param.getFrozen()); // 鏄惁鍐荤粨 waitPakin.setManu(detlDto.getCstmr()); waitPakin.setMatType(mat.getMatType());//鐗╂枡绫诲瀷 + waitPakin.setMatTypeIn(param.getMatTypeIn());//寮哄埗鐗╂枡绫诲瀷 if (Cools.isEmpty(mat.getMatType())){ throw new CoolException("鐗╂枡绫诲瀷寮傚父"+mat.getMatnr()); }else { @@ -179,7 +177,7 @@ // 鐢熸垚鍏ュ簱閫氱煡妗� List<DetlDto> detlDtos = new ArrayList<>(); param.getCombMats().forEach(elem -> { - elem.setBatch(""); + //elem.setBatch(""); // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙 OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), elem.getMatnr(), elem.getBatch()); if (elem.getAnfme() > orderDetl.getEnableQty()) { @@ -193,7 +191,7 @@ DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme(),elem.getOwner()); if (Cools.isEmpty(detlDto.getOwner())){ - detlDto.setOwner(0L); + detlDto.setOwner(1L); } if (DetlDto.has(detlDtos, detlDto)) { @@ -212,7 +210,7 @@ WaitPakin waitPakin = new WaitPakin(); waitPakin.sync(mat); waitPakin.setOrderNo(order.getOrderNo()); // 鍗曟嵁缂栧彿 - waitPakin.setBatch(""); // 搴忓垪鐮� + //waitPakin.setBatch(""); // 搴忓垪鐮� waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� waitPakin.setAnfme(detlDto.getAnfme()); // 鏁伴噺 @@ -223,6 +221,7 @@ waitPakin.setModiTime(now); waitPakin.setOwner(detlDto.getOwner()); waitPakin.setMatType(mat.getMatType());//鐗╂枡绫诲瀷 + waitPakin.setMatTypeIn(param.getMatTypeIn()); //寮哄埗鐗╂枡绫诲瀷 // if (Cools.isEmpty(mat.getMatType())){ // throw new CoolException("鐗╂枡绫诲瀷寮傚父"+mat.getMatnr()); // }else { @@ -557,4 +556,80 @@ public void pikingToFull(String barcode) { wrkMastService.selectByBarcode(barcode); } + + @Override + @Transactional + public List<WrkDetl> pikingToFull2(Integer wrkNo) { + List<WrkDetl> wrkDetlsNew= new ArrayList<WrkDetl>(); + List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkNo); + for (WrkDetl wrkDetl:wrkDetls){ + String[] orderNos = GetOrderNo(wrkDetl.getOrderNo()); + if (!Cools.isEmpty(orderNos) && orderNos.length!=0) { + Double anfme = wrkDetl.getAnfme(); + for (String orderNo : orderNos) { + OrderDetl orderDetl = orderDetlService.selectItem(orderNo, wrkDetl.getMatnr(), wrkDetl.getBatch()); + if (orderDetl == null) { + orderDetl = orderDetlService.selectItem(orderNo, wrkDetl.getMatnr(), null); + if (orderDetl == null) { + log.error("ww"); + return wrkDetlsNew; + } + } + if (orderDetl.getAnfme() <= anfme) { + WrkDetl wrkDetl1 = new WrkDetl(); + wrkDetl1.sync(wrkDetl); + wrkDetl1.setOrderNo(orderNo); + wrkDetl1.setAnfme(anfme); + wrkDetlsNew.add(wrkDetl1); + anfme = anfme - orderDetl.getAnfme(); + } else { + WrkDetl wrkDetl1 = new WrkDetl(); + wrkDetl1.sync(wrkDetl); + wrkDetl1.setOrderNo(orderNo); + wrkDetl1.setAnfme(anfme); + wrkDetlsNew.add(wrkDetl1); + } + } + }else { + wrkDetlsNew.add(wrkDetl); + } + } + return wrkDetlsNew; + } + + private static String[] GetOrderNo(String orderNo) { + String[] s3 = orderNo.split("\""); + String[] s = new String[(s3.length - 1) / 6]; + if (!Cools.isEmpty(s3)){ + int i = 0; + int j = 0; + for (String ss : s3) { + if (ss.equals("orderNo")) { + s[i] = s3[j + 2]; + i++; + } + j++; + } + }else { + s=null; + } + return s; + } + + private String[] GetAnfme(String orderNo) { + String[] s3 = orderNo.split("\""); + String[] s = new String[(s3.length - 1) / 6]; + int i = 0; + int j = 0; + for (String ss : s3) { + if (ss.equals("anfme")) { + String[] s4 = s3[j + 1].split(":"); + String[] s5 = s4[1].split("\\."); + s[i] = s5[0]; + i++; + } + j++; + } + return s; + } } -- Gitblit v1.9.1