From 1607086231421efad1dae82c00f044b0b9070532 Mon Sep 17 00:00:00 2001 From: lsh <1> Date: 星期五, 19 一月 2024 18:08:44 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java | 273 ++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 211 insertions(+), 62 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 2b64deb..40387db 100644 --- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java @@ -1,8 +1,10 @@ package com.zy.asrs.service.impl; import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.baomidou.mybatisplus.mapper.Wrapper; import com.core.common.Cools; import com.core.common.DateUtils; +import com.core.common.R; import com.core.common.SnowflakeIdWorker; import com.core.exception.CoolException; import com.zy.asrs.entity.*; @@ -11,11 +13,17 @@ import com.zy.asrs.entity.result.StockVo; import com.zy.asrs.mapper.TagMapper; import com.zy.asrs.service.*; +import com.zy.asrs.task.core.ReturnT; import com.zy.asrs.utils.MatUtils; +import com.zy.asrs.utils.PostMesDataUtils; import com.zy.common.model.DetlDto; +import com.zy.common.model.LocTypeDto; +import com.zy.common.model.StartupDto; import com.zy.common.model.enums.WorkNoType; import com.zy.common.service.CommonService; import com.zy.common.utils.NodeUtils; +import com.zy.common.web.WcsController; +import com.zy.common.web.param.SearchLocParam; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -60,6 +68,18 @@ private WaitPakinService waitPakinService; @Autowired private CommonService commonService; + @Autowired + private LocDetlRullUpDetailService locDetlRullUpDetailService; + @Autowired + private WrkDetlSingleService wrkDetlSingleService; + @Autowired + private WrkMastStaService wrkMastStaService; + @Autowired + private WrkMastStaLogService wrkMastStaLogService; + @Autowired + private StaDescService staDescService; + @Autowired + private LocMastService locMastService; @Override @Transactional @@ -654,11 +674,12 @@ if (param.getLabResult().equals("OK")){ wrkMast.setWrkSts(54L); + wrkMast.setStaNo(144); if (!wrkMastService.updateById(wrkMast)){ throw new CoolException("寮傚父锛岃閲嶆柊鐢宠"); } }else if (param.getLabResult().equals("NG")){ - wrkMast.setWrkSts(52L); + wrkMast.setWrkSts(52L);//閲嶆柊璐存爣 if (!wrkMastService.updateById(wrkMast)){ throw new CoolException("寮傚父锛岃閲嶆柊鐢宠"); } @@ -673,7 +694,7 @@ * */ @Override @Transactional - public void palletizingComplete(PalletizingCompleteParam param) { + public void palletizingComplete(PalletizingCompleteParam2 param) { Long userId = 7777L;//涓帶 //鍒ゆ柇param鍙傛暟 if (Cools.isEmpty(param.getBarcode())){ @@ -689,7 +710,7 @@ ArrayList<String> positions = new ArrayList<>(); //鏈ㄧ浣嶇疆鏌ラ噸 (orgin) ArrayList<String> boxNos = new ArrayList<>(); //鏈ㄧ鍞竴缂栫爜鏌ラ噸 锛坆atch锛� //鍒ゆ柇matLists鍙傛暟 - for (PalletizingCompleteParam.MatList matList:param.getMatLists()){ + for (PalletizingCompleteParam2.MatList matList:param.getMatLists()){ if (Cools.isEmpty(matList.getMatnr())){ throw new CoolException("鍙傛暟锛氱墿鏂欑紪鐮� matnr涓虹┖"); }else if (Cools.isEmpty(matList.getPosition())){ @@ -738,7 +759,8 @@ Date now = new Date(); - for (PalletizingCompleteParam.MatList matList:param.getMatLists()){ + for (PalletizingCompleteParam2.MatList matList:param.getMatLists()){ + long rollUp = new Date().getTime(); Mat mat = matService.selectByMatnr(matList.getMatnr()); if (Cools.isEmpty(mat)) { throw new CoolException(matList.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); @@ -758,11 +780,59 @@ waitPakin.setAppeTime(now); waitPakin.setModiUser(userId); waitPakin.setModiTime(now); + waitPakin.setRollUp(rollUp); + if (!Cools.isEmpty(matList.getMatDetlList())){ + for (PalletizingCompleteParam2.MatDetlList matDetlList:matList.getMatDetlList()){ + LocDetlRullUpDetail locDetlRullUpDetail = new LocDetlRullUpDetail(); + locDetlRullUpDetail.setUuid(rollUp); + locDetlRullUpDetail.setRollNo(matDetlList.getBoxNoDetl()); + locDetlRullUpDetail.setRollWeight(matDetlList.getWeightDetl().toString()); + locDetlRullUpDetailService.insert(locDetlRullUpDetail); + } + } if (!waitPakinService.insert(waitPakin)) { throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); } } + } + + /* + * 鏉剧洓(1妤�)锛氱爜鍨涘畬鎴愪笅鍙戝叆搴撲俊鎭� + * */ + @Override + @Transactional + public void palletizingCompleteS(PalletizingCompleteParam param) { + //鍒ゆ柇param鍙傛暟 + if (Cools.isEmpty(param.getBarcode())){ + throw new CoolException("鍙傛暟锛氭墭鐩樼爜 barcode涓虹┖"); + } + + WrkMast wrkMast = wrkMastService.selectByBarcode(param.getBarcode()); + if (Cools.isEmpty(wrkMast) || wrkMast.getWrkSts()!=2){ + log.error("閫�搴撶爜鍨涘畬鎴愶紝杩斿洖鎵樼洏鐮佹湭鏌ヨ鍒板伐浣滄。妗堬紒"); + throw new CoolException("鍙傛暟锛氭墭鐩樼爜 barcode鏈煡璇㈠埌宸ヤ綔妗f"); + } + wrkMast.setSheetNo("4"); + wrkMastService.updateById(wrkMast); + } + + + /* + *涓帶锛氬嚭搴撳畬鎴愭湀鍙扮浉鍏� + * */ + @Override + @Transactional + public void balconyComplete(LabellerMatParam param) { + if (Cools.isEmpty(param.getWrkNo())){ + throw new CoolException("宸ヤ綔鍙蜂负绌猴紒"); + } + WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("wrk_no", param.getWrkNo())); + if (Cools.isEmpty(wrkMast)){ + throw new CoolException("宸ヤ綔鍙蜂负绌猴紒"); + } + wrkMast.setWrkSts(57L); + wrkMastService.updateById(wrkMast); } /* @@ -773,33 +843,29 @@ public void singleUnstackingComplete(SingleUnstackingCompleteParam param) { Long userId = 8888L;//妗佹灦涓婁綅杞欢 //鍒ゆ柇param鍙傛暟 - if (Cools.isEmpty(param.getBarcode())){ - throw new CoolException("鍙傛暟锛氭墭鐩樼爜 barcode涓虹┖"); - }else if (Cools.isEmpty(param.getPalletizingNo())){ + if (Cools.isEmpty(param.getPalletizingNo())){ throw new CoolException("鍙傛暟锛氱爜鍨涗綅缂栧彿 palletizingNo涓虹┖"); - }else if (Cools.isEmpty(param.getMatLists()) || param.getMatLists().size()==0){ + }else if (Cools.isEmpty(param.getMatList()) || param.getMatList().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<>(); + ArrayList<WrkDetlSingle> wrkDetlsOld = new ArrayList<>(); //鍒ゆ柇matLists鍙傛暟 - for (SingleUnstackingCompleteParam.MatList matList:param.getMatLists()){ + for (SingleUnstackingCompleteParam.MatList matList:param.getMatList()){ if (Cools.isEmpty(matList.getPosition())){ throw new CoolException("鍙傛暟锛氱爜鍨涗綅缃� position涓虹┖"); }else if (Cools.isEmpty(matList.getBoxNo())){ throw new CoolException("鍙傛暟锛氭湪绠辩紪鍙� boxNo涓虹┖"); } + List<WrkDetlSingle> wrkDetlSingles = wrkDetlSingleService.selectList(new EntityWrapper<WrkDetlSingle>().eq("batch", matList.getBoxNo())); 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())); + for (WrkDetlSingle wrkDetlSingle:wrkDetlSingles){ + if (wrkDetlSingle.getBatch().equals(matList.getBoxNo())){//鏈ㄧ缂栫爜 + WrkDetl wrkDetl = new WrkDetl(); + wrkDetl.sync(wrkDetlSingle); wrkDetlsNew.add(wrkDetl); + wrkDetlsOld.add(wrkDetlSingle); sign=false; break; } @@ -819,9 +885,9 @@ wrkMast.setIoTime(now); wrkMast.setWrkSts(51L); // 宸ヤ綔鐘舵�侊細鐢熸垚鍏ュ簱ID wrkMast.setIoType(202); // 鍏ュ嚭搴撶姸鎬侊細202.鎷嗗灈鍚庡嚭搴� - wrkMast.setIoPri(13D); // 浼樺厛绾� + wrkMast.setIoPri(99D); // 浼樺厛绾� wrkMast.setSourceStaNo(param.getDevNo$()); - wrkMast.setStaNo(140); //璐存爣绔欑偣 + wrkMast.setStaNo(144); //璐存爣绔欑偣 鐩存帴鍒板熬绔� // 鎿嶄綔浜哄憳鏁版嵁 wrkMast.setAppeUser(userId); wrkMast.setAppeTime(now); @@ -841,6 +907,13 @@ } } + for (WrkDetlSingle wrkDetlSingle : wrkDetlsOld) { + wrkDetlSingleService.delete(new EntityWrapper<WrkDetlSingle>() + .eq("batch",wrkDetlSingle.getBatch()) + .eq("wrk_no",wrkDetlSingle.getWrkNo()) + .eq("io_time",wrkDetlSingle.getIoTime())); + } + } /* @@ -853,49 +926,50 @@ //鍒ゆ柇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.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()+"鏈煡璇㈠埌瀵瑰簲鐨勫伐浣滄槑缁嗭紒"); - } - } - } +// if (wrkMastMatrix.getIoType().equals(103)){ +// 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"); + wrkMastMatrix.setSheetNo("2"); if (!wrkMastService.updateById(wrkMastMatrix)){ throw new CoolException("鏇存柊宸ヤ綔妗eけ璐�==銆嬫鏋朵笂浣嶈蒋浠讹細鍗曟墭鎷嗗灈瀹屾垚閫氱煡"); } @@ -919,19 +993,94 @@ @Override @Transactional public void cs2() { - BasDevp basDevp = basDevpService.selectById(216); - basDevp.setWrkNo(0); - basDevp.setBarcode(""); - basDevpService.updateById(basDevp); +// int[] staNos =new int[]{122}; +// for (Integer staNo:staNos){ +// int[] crnNos =new int[]{6}; +// for (Integer crnNo:crnNos){ +// descSta(staNo,crnNo); +// } +// } + } - /* + private void descSta(Integer staNo,Integer crnNo){ +// int[] typeNos =new int[]{1,10,53,101,103,110}; + int[] typeNos =new int[]{10,110}; + for (Integer typeNo:typeNos){ + descSta3(staNo,crnNo,typeNo); + } + } + + private void descSta3(Integer staNo,Integer crnNo,Integer typeNo){ + StaDesc staDesc = new StaDesc(); + staDesc.setTypeNo(typeNo); + staDesc.setStnNo(staNo); + staDesc.setCrnNo(crnNo); + staDesc.setCrnStn(CrnNoRC(crnNo,staDesc.getTypeNo()>100)); + descSta2(staDesc); + } + + private void descSta2(StaDesc staDesc){ + Date now = new Date(); + //鍏ュ簱 + int sameRes = staDescService.selectCount(new EntityWrapper<StaDesc>() + .eq("type_no", staDesc.getTypeNo()) + .eq("stn_no", staDesc.getStnNo()) + .eq("crn_no", staDesc.getCrnNo()) + .eq("crn_stn", staDesc.getCrnStn())); + if (sameRes == 0) { + staDesc.setModiUser(9527L); + staDesc.setModiTime(now); + staDesc.setAppeUser(9527L); + staDesc.setAppeTime(now); + staDescService.insert(staDesc); + } + } + + private Integer CrnNoRC(Integer crnNo,boolean sign){ + Integer crnStn = 0; + switch (crnNo){ + case 1: + crnStn = 102; + break; + case 2: + crnStn = 105; + break; + case 3: + crnStn = 108; + break; + case 4: + crnStn = 111; + break; + case 5: + crnStn = 114; + break; + case 6: + crnStn = 117; + break; + } + if (sign){ + return crnStn-2; + } + return crnStn; + } + + + /* * * */ @Override @Transactional public void cs3() { - + //鎷嗙洏 +// WrkMastSta wrkMastSta1 = new WrkMastSta(new Date(),119); +// wrkMastSta1.setType(2); +// wrkMastSta1.setWrkType(2); +// wrkMastStaService.insert(wrkMastSta1); +// WrkMastSta wrkMastSta2 = new WrkMastSta(new Date(),121); +// wrkMastSta2.setType(2); +// wrkMastSta2.setWrkType(2); +// wrkMastStaService.insert(wrkMastSta2); } /*...........................涓婇ザ姹熼摐..............浠ヤ笂.............寰愬伐姹変簯...........................*/ -- Gitblit v1.9.1