From 11972d7f05a60a2e117665ef4900f5f3ad43607d Mon Sep 17 00:00:00 2001 From: LSH Date: 星期日, 17 九月 2023 13:47:49 +0800 Subject: [PATCH] #贴标机修改完成 --- src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java | 318 ++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 305 insertions(+), 13 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 c55bc31..2b64deb 100644 --- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java @@ -13,6 +13,8 @@ import com.zy.asrs.service.*; import com.zy.asrs.utils.MatUtils; import com.zy.common.model.DetlDto; +import com.zy.common.model.enums.WorkNoType; +import com.zy.common.service.CommonService; import com.zy.common.utils.NodeUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; @@ -54,6 +56,10 @@ private BasDevpService basDevpService; @Autowired private WrkDetlService wrkDetlService; + @Autowired + private WaitPakinService waitPakinService; + @Autowired + private CommonService commonService; @Override @Transactional @@ -586,19 +592,28 @@ LabellerMatParam labellerMatParam = new LabellerMatParam(); labellerMatParam.setDevNo(param.getDevNo()); labellerMatParam.setLabNo(param.getLabNo()); - ArrayList<LabellerMatParam.CombMat> combMats = new ArrayList<>(); - String orderNo = ""; - for (WrkDetl wrkDetl:wrkDetls){ - LabellerMatParam.CombMat combMat = new LabellerMatParam.CombMat(wrkDetl); - orderNo=wrkDetl.getOrderNo(); - combMat.setTemp1("1"); - combMats.add(combMat); - } - labellerMatParam.setCombMats(combMats); - labellerMatParam.setLabellingTime(DateUtils.convert(new Date())); labellerMatParam.setWrkNo(basDevp.getWrkNo().toString()); - labellerMatParam.setLabTemplate("1"); - labellerMatParam.setOrderNo(orderNo); +// ArrayList<LabellerMatParam.CombMat> combMats = new ArrayList<>(); + ArrayList<LabellerMatParam.BoxNo> boxNos = new ArrayList<>(); +// String orderNo = ""; + + for (WrkDetl wrkDetl:wrkDetls){ + LabellerMatParam.BoxNo boxNo = new LabellerMatParam.BoxNo(); + boxNo.setBoxNo(wrkDetl.getBatch()); + boxNos.add(boxNo); + } + labellerMatParam.setBoxNos(boxNos); +// for (WrkDetl wrkDetl:wrkDetls){ +// LabellerMatParam.CombMat combMat = new LabellerMatParam.CombMat(wrkDetl); +// orderNo=wrkDetl.getOrderNo(); +// combMat.setTemp1("1"); +// combMats.add(combMat); +// } + +// labellerMatParam.setCombMats(combMats); +// labellerMatParam.setLabellingTime(DateUtils.convert(new Date())); +// labellerMatParam.setLabTemplate("1"); +// labellerMatParam.setOrderNo(orderNo); wrkMast.setWrkSts(53L); if (!wrkMastService.updateById(wrkMast)){ throw new CoolException("寮傚父锛岃閲嶆柊鐢宠"); @@ -612,7 +627,45 @@ @Override @Transactional public void labellerComplete(LabellerCompleteParam param) { - // + if (Cools.isEmpty(param.getDevNo())){ + throw new CoolException("鍙傛暟锛氱珯鐐瑰彿 devNo涓虹┖"); + }else if (Cools.isEmpty(param.getLabNo())){ + throw new CoolException("鍙傛暟锛氳创鏍囨満鍙� labNo涓虹┖"); + }else if (Cools.isEmpty(param.getLabResult())){ + throw new CoolException("鍙傛暟锛氳创鏍囩粨鏋� labResult涓虹┖"); + }else if (Cools.isEmpty(param.getWrkNo())){ + throw new CoolException("鍙傛暟锛氳创鏍囦换鍔″彿 wrkNo涓虹┖"); + } + BasDevp basDevp = basDevpService.selectById(param.getDevNo()); + if (Cools.isEmpty(basDevp)){ + throw new CoolException("鍙傛暟锛氱珯鐐瑰彿 devNo="+param.getDevNo()+"涓嶅瓨鍦�"); + }else if (Cools.isEmpty(basDevp.getWrkNo()) || basDevp.getWrkNo()==0 ){ + throw new CoolException("绔欑偣:"+param.getDevNo()+" 涓嶅瓨鍦ㄥ伐浣滀腑浠诲姟"); + }else if(!basDevp.getWrkNo().toString().equals(param.getWrkNo())){ + throw new CoolException("绔欑偣:"+param.getDevNo()+" 杩涜涓换鍔″彿="+basDevp.getWrkNo()+" 涓庤创鏍囩粨鏋滆繑鍥炰换鍔″彿="+param.getWrkNo()+" 涓嶄竴鑷�"); + } + + WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("wrk_no", basDevp.getWrkNo())); + if (Cools.isEmpty(wrkMast)){ + throw new CoolException("绔欑偣:"+param.getDevNo()+" 宸ヤ綔涓换鍔′笉瀛樺湪,浠诲姟鍙凤細"+basDevp.getWrkNo()); + }else if (!wrkMast.getWrkSts().equals(53L)){ + throw new CoolException("绔欑偣:"+param.getDevNo()+" 宸ヤ綔涓换鍔$姸鎬佸凡鍙樻洿锛岃鍕块噸澶嶇敵璇�,浠诲姟鍙凤細"+basDevp.getWrkNo()+",浠诲姟鐘舵��:"+wrkMast.getWrkSts$()); + } + + if (param.getLabResult().equals("OK")){ + wrkMast.setWrkSts(54L); + if (!wrkMastService.updateById(wrkMast)){ + throw new CoolException("寮傚父锛岃閲嶆柊鐢宠"); + } + }else if (param.getLabResult().equals("NG")){ + wrkMast.setWrkSts(52L); + if (!wrkMastService.updateById(wrkMast)){ + throw new CoolException("寮傚父锛岃閲嶆柊鐢宠"); + } + }else { + throw new CoolException("鍙傛暟锛氳创鏍囩粨鏋�:labResult"+param.getLabResult()+";璇锋寜瑙勫垯鍙戦�侊細鎴愬姛锛歄K 銆佸け璐�:NG"); + } + } /* @@ -621,6 +674,94 @@ @Override @Transactional public void palletizingComplete(PalletizingCompleteParam param) { + Long userId = 7777L;//涓帶 + //鍒ゆ柇param鍙傛暟 + if (Cools.isEmpty(param.getBarcode())){ + throw new CoolException("鍙傛暟锛氭墭鐩樼爜 barcode涓虹┖"); + }else if (Cools.isEmpty(param.getPalletizingNo())){ + throw new CoolException("鍙傛暟锛氱爜鍨涗綅缂栧彿 palletizingNo涓虹┖"); + }else if (Cools.isEmpty(param.getBoxType())){ + throw new CoolException("鍙傛暟锛氭湪绠辩被鍨� boxType涓虹┖"); + }else if (Cools.isEmpty(param.getMatLists()) || param.getMatLists().size()==0){ + throw new CoolException("鍙傛暟锛氱墿鏂欐槑缁� matLists涓虹┖"); + } + + ArrayList<String> positions = new ArrayList<>(); //鏈ㄧ浣嶇疆鏌ラ噸 (orgin) + ArrayList<String> boxNos = new ArrayList<>(); //鏈ㄧ鍞竴缂栫爜鏌ラ噸 锛坆atch锛� + //鍒ゆ柇matLists鍙傛暟 + for (PalletizingCompleteParam.MatList matList:param.getMatLists()){ + if (Cools.isEmpty(matList.getMatnr())){ + throw new CoolException("鍙傛暟锛氱墿鏂欑紪鐮� matnr涓虹┖"); + }else if (Cools.isEmpty(matList.getPosition())){ + throw new CoolException("鐗╂枡缂栫爜锛�"+matList.getMatnr()+"銆佸弬鏁帮細鐮佸灈浣嶇疆 position涓虹┖"); + }else if (Cools.isEmpty(matList.getBoxNo())){ + throw new CoolException("鐗╂枡缂栫爜锛�"+matList.getMatnr()+"銆佸弬鏁帮細鏈ㄧ缂栧彿 boxNo涓虹┖"); + }else if (Cools.isEmpty(matList.getAnfme()) || matList.getAnfme().equals(0)){ + throw new CoolException("鐗╂枡缂栫爜锛�"+matList.getMatnr()+"銆佸弬鏁帮細鏈ㄧ涓摐绠旀暟閲� anfme涓虹┖"); + }else if (Cools.isEmpty(matList.getWeight()) || matList.getWeight().equals(0D)){ + throw new CoolException("鐗╂枡缂栫爜锛�"+matList.getMatnr()+"銆佸弬鏁帮細閲嶉噺 weight涓虹┖"); + } + + if (!positions.contains(matList.getPosition())){ + positions.add(matList.getPosition()); + }else { + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo:"+matList.getBoxNo()+",鏈ㄧ浣嶇疆瀛樺湪閲嶅锛�"+matList.getPosition()); + } + + if (!boxNos.contains(matList.getBoxNo())){ + boxNos.add(matList.getBoxNo()); + }else { + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo:"+matList.getBoxNo()+",鏈ㄧ缂栫爜瀛樺湪閲嶅"); + } + } + +// BasDevp basDevp = basDevpService.selectById(Integer.parseInt(param.getDevNo$())); +// if (Cools.isEmpty(basDevp)){ +// throw new CoolException("鍙傛暟锛氱爜鍨涗綅缂栧彿 palletizingNo="+param.getPalletizingNo()+"涓嶅瓨鍦�"); +// } +// if (Cools.isEmpty(basDevp.getAutoing()) || !basDevp.getAutoing().equals("Y")){ +// throw new CoolException("鐮佸灈浣嶇紪鍙� palletizingNo="+param.getPalletizingNo()+" 鎵�澶勭珯鐐逛笉鏄嚜鍔ㄧ姸鎬�"); +// } +// if (Cools.isEmpty(basDevp.getLoading()) || !basDevp.getLoading().equals("Y")){ +// throw new CoolException("鐮佸灈浣嶇紪鍙� palletizingNo="+param.getPalletizingNo()+" 鎵�澶勭珯鐐逛笉鏄湁鐗╃姸鎬�"); +// } +// if (Cools.isEmpty(basDevp.getCanining()) || !basDevp.getCanining().equals("Y")){ +// throw new CoolException("鐮佸灈浣嶇紪鍙� palletizingNo="+param.getPalletizingNo()+" 鎵�澶勭珯鐐逛笉鏄兘鍏ョ姸鎬�"); +// } + + + if (locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet", param.getBarcode()))!=0 + || wrkDetlService.selectCount(new EntityWrapper<WrkDetl>().eq("zpallet", param.getBarcode()))!=0 + || waitPakinService.selectCount(new EntityWrapper<WaitPakin>().eq("zpallet", param.getBarcode()))!=0){ + throw new CoolException("鎵樼洏鏉$爜锛�"+param.getBarcode()+"宸插瓨鍦紝璇峰嬁閲嶅缁勬墭"); + } + + + Date now = new Date(); + for (PalletizingCompleteParam.MatList matList:param.getMatLists()){ + Mat mat = matService.selectByMatnr(matList.getMatnr()); + if (Cools.isEmpty(mat)) { + throw new CoolException(matList.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); + } + WaitPakin waitPakin = new WaitPakin(); + waitPakin.sync(mat); + waitPakin.setModel(matList.getBatch()); //鎵规 + waitPakin.setSpecs(matList.getSpecs()); //瑙勬牸 + waitPakin.setBatch(matList.getBoxNo()); //鏈ㄧ缂栫爜 + waitPakin.setBrand(param.getBoxType()); //鏈ㄧ绫诲瀷 + waitPakin.setZpallet(param.getBarcode()); //鎵樼洏鐮� + waitPakin.setOrigin(matList.getPosition()); //鏈ㄧ鍦ㄦ墭鐩樹笂鐨勪綅缃� + waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� + waitPakin.setAnfme(matList.getAnfme().doubleValue()); // 鏈ㄧ涓摐绠旀暟閲� + waitPakin.setStatus("Y"); // 鐘舵�� + waitPakin.setAppeUser(userId); + waitPakin.setAppeTime(now); + waitPakin.setModiUser(userId); + waitPakin.setModiTime(now); + if (!waitPakinService.insert(waitPakin)) { + throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); + } + } } @@ -630,6 +771,75 @@ @Override @Transactional public void singleUnstackingComplete(SingleUnstackingCompleteParam param) { + Long userId = 8888L;//妗佹灦涓婁綅杞欢 + //鍒ゆ柇param鍙傛暟 + if (Cools.isEmpty(param.getBarcode())){ + throw new CoolException("鍙傛暟锛氭墭鐩樼爜 barcode涓虹┖"); + }else if (Cools.isEmpty(param.getPalletizingNo())){ + throw new CoolException("鍙傛暟锛氱爜鍨涗綅缂栧彿 palletizingNo涓虹┖"); + }else if (Cools.isEmpty(param.getMatLists()) || param.getMatLists().size()==0){ + throw new CoolException("鍙傛暟锛氱墿鏂欐槑缁� matLists涓虹┖"); + } + WrkMast wrkMastMatrix = wrkMastService.selectByBarcode(param.getBarcode()); + if (Cools.isEmpty(wrkMastMatrix)){ + throw new CoolException("鍙傛暟锛氭墭鐩樼爜鏌ヨ宸ヤ綔妗eけ璐ワ細"+param.getBarcode()); + } + + List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNoUnstacking(wrkMastMatrix.getWrkNo()); + ArrayList<WrkDetl> wrkDetlsNew = new ArrayList<>(); + //鍒ゆ柇matLists鍙傛暟 + for (SingleUnstackingCompleteParam.MatList matList:param.getMatLists()){ + if (Cools.isEmpty(matList.getPosition())){ + throw new CoolException("鍙傛暟锛氱爜鍨涗綅缃� position涓虹┖"); + }else if (Cools.isEmpty(matList.getBoxNo())){ + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo涓虹┖"); + } + boolean sign=true; + for (WrkDetl wrkDetl:wrkDetls){ + if (wrkDetl.getBatch().equals(matList.getBoxNo())){//鏈ㄧ缂栫爜 + wrkDetl.setInspect(1); + wrkDetlService.update(wrkDetl,new EntityWrapper<WrkDetl>().eq("batch",wrkDetl.getBatch())); + wrkDetlsNew.add(wrkDetl); + sign=false; + break; + } + } + if (sign){ + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo鏈煡璇㈠埌瀵瑰簲鐨勫伐浣滄槑缁嗭紒"); + } + } + + // 鐢熸垚宸ヤ綔鍙� + int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(202)); + Date now = new Date(); + + // 鐢熸垚宸ヤ綔妗� + WrkMast wrkMast = new WrkMast(); + wrkMast.setWrkNo(workNo); + wrkMast.setIoTime(now); + wrkMast.setWrkSts(51L); // 宸ヤ綔鐘舵�侊細鐢熸垚鍏ュ簱ID + wrkMast.setIoType(202); // 鍏ュ嚭搴撶姸鎬侊細202.鎷嗗灈鍚庡嚭搴� + wrkMast.setIoPri(13D); // 浼樺厛绾� + wrkMast.setSourceStaNo(param.getDevNo$()); + wrkMast.setStaNo(140); //璐存爣绔欑偣 + // 鎿嶄綔浜哄憳鏁版嵁 + wrkMast.setAppeUser(userId); + wrkMast.setAppeTime(now); + wrkMast.setModiUser(userId); + wrkMast.setModiTime(now); + if (!wrkMastService.insert(wrkMast)) { + throw new CoolException("鐢熸垚宸ヤ綔妗eけ璐�==銆嬫鏋朵笂浣嶈蒋浠讹細鍗曟鎷嗗灈瀹屾垚閫氱煡"); + } + + for (WrkDetl wrkDetl : wrkDetlsNew){ + wrkDetl.setWrkNo(wrkMast.getWrkNo()); + wrkDetl.setIoTime(wrkMast.getIoTime()); + wrkDetl.setAppeTime(now); + wrkDetl.setModiTime(now); + if (!wrkDetlService.insert(wrkDetl)) { + throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触==銆嬫鏋朵笂浣嶈蒋浠讹細鍗曟鎷嗗灈瀹屾垚閫氱煡"); + } + } } @@ -639,6 +849,88 @@ @Override @Transactional public void singleMountUnstackingComplete(SingleMountUnstackingCompleteParam param) { + Long userId = 8888L;//妗佹灦涓婁綅杞欢 + //鍒ゆ柇param鍙傛暟 + if (Cools.isEmpty(param.getBarcode())){ + throw new CoolException("鍙傛暟锛氭墭鐩樼爜 barcode涓虹┖"); + }else if (Cools.isEmpty(param.getPalletizingNo())){ + throw new CoolException("鍙傛暟锛氱爜鍨涗綅缂栧彿 palletizingNo涓虹┖"); + } + WrkMast wrkMastMatrix = wrkMastService.selectByBarcode(param.getBarcode()); + if (Cools.isEmpty(wrkMastMatrix)){ + throw new CoolException("鍙傛暟锛氭墭鐩樼爜鏌ヨ宸ヤ綔妗eけ璐ワ細"+param.getBarcode()); + }else { + if (!wrkMastMatrix.getIoType().equals(101)){ + List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNoUnstacking(wrkMastMatrix.getWrkNo()); + if (Cools.isEmpty(param.getMatLists()) || param.getMatLists().size()==0 || param.getMatLists().size()!=wrkDetls.size()){ + throw new CoolException("杩斿洖鐗╂枡鏄庣粏鏁颁负"+param.getMatLists().size()+",鎵樼洏鐮侊細"+param.getBarcode()+"搴斿墿浣欑墿鏂欐暟锛�"+wrkDetls.size()); + } + + ArrayList<String> orgin = new ArrayList<>(); + //鍒ゆ柇matLists鍙傛暟 + for (SingleMountUnstackingCompleteParam.MatList matList : param.getMatLists()){ + if (Cools.isEmpty(matList.getPosition())){ + throw new CoolException("鍙傛暟锛氱爜鍨涗綅缃� position涓虹┖"); + }else if (Cools.isEmpty(matList.getBoxNo())){ + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo涓虹┖"); + } + if (!orgin.contains(matList.getPosition())){ + orgin.add(matList.getPosition()); + }else { + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo:"+matList.getBoxNo()+",鏈ㄧ浣嶇疆瀛樺湪閲嶅"); + } + boolean sign=true; + for (WrkDetl wrkDetl:wrkDetls){ + if (wrkDetl.getBatch().equals(matList.getBoxNo())){//鏈ㄧ缂栫爜 + wrkDetl.setOrigin(matList.getPosition()); + wrkDetlService.update(wrkDetl,new EntityWrapper<WrkDetl>().eq("batch",wrkDetl.getBatch())); + sign=false; + break; + } + } + if (sign){ + throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo:"+matList.getBoxNo()+"鏈煡璇㈠埌瀵瑰簲鐨勫伐浣滄槑缁嗭紒"); + } + } + } + } + + wrkMastMatrix.setSheetNo("1"); + if (!wrkMastService.updateById(wrkMastMatrix)){ + throw new CoolException("鏇存柊宸ヤ綔妗eけ璐�==銆嬫鏋朵笂浣嶈蒋浠讹細鍗曟墭鎷嗗灈瀹屾垚閫氱煡"); + } + } + + /* + * + * */ + @Override + @Transactional + public void cs1(String barcode) { + BasDevp basDevp = basDevpService.selectById(216); + basDevp.setWrkNo(9992); + basDevp.setBarcode(barcode); + basDevpService.updateById(basDevp); + } + + /* + * + * */ + @Override + @Transactional + public void cs2() { + BasDevp basDevp = basDevpService.selectById(216); + basDevp.setWrkNo(0); + basDevp.setBarcode(""); + basDevpService.updateById(basDevp); + } + + /* + * + * */ + @Override + @Transactional + public void cs3() { } -- Gitblit v1.9.1