From 98ff94c52485dd502e10c061ae267bf24e5d1814 Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期五, 17 十一月 2023 08:26:15 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java | 135 ++++++++++++++++++++++++-------------------- 1 files changed, 74 insertions(+), 61 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java index 3bc500b..47e234e 100644 --- a/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/AgvWorkServiceImpl.java @@ -22,6 +22,7 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import java.util.ArrayList; import java.util.Date; import java.util.Iterator; import java.util.List; @@ -215,32 +216,68 @@ @Transactional public void locCheckOut(StockOutParam param, Long userId) { String station = param.getStation(); - List<AgvBasDevp> agvBasDevpList = agvBasDevpService.selectList(new EntityWrapper<AgvBasDevp>() - .eq("station_code", station) - .eq("loc_sts","O")); +// List<AgvBasDevp> agvBasDevpList = agvBasDevpService.selectList(new EntityWrapper<AgvBasDevp>() +// .eq("station_code", station) +// .eq("loc_sts","O")); +// +// if(param.getLocDetls().size() > agvBasDevpList.size()){ +// throw new CoolException("褰撳墠绔欑偣鍙敤缂撳瓨璐ф灦鏁伴噺涓�" + agvBasDevpList.size() + ",灏戜簬闇�瑕佺洏鐐瑰嚭搴撳簱浣嶆暟閲忥紝璇烽噸鏂伴�夋嫨鐩樼偣搴撲綅"); +// } - if(param.getLocDetls().size() > agvBasDevpList.size()){ - throw new CoolException("褰撳墠绔欑偣鍙敤缂撳瓨璐ф灦鏁伴噺涓�" + agvBasDevpList.size() + ",灏戜簬闇�瑕佺洏鐐瑰嚭搴撳簱浣嶆暟閲忥紝璇烽噸鏂伴�夋嫨鐩樼偣搴撲綅"); - } - + List<TaskDto> taskDtos = new ArrayList<>(); param.getLocDetls().forEach(locDetl -> { - AgvLocMast agvLocMast = agvLocMastService.selectById(locDetl.getLocNo()); - AgvLocDetl agvLocDetl = agvLocDetlService.selectOne(new EntityWrapper<AgvLocDetl>().eq("loc_no", locDetl.getLocNo())); - AgvBasDevp agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>() - .eq("station_code", station) - .eq("loc_sts","O")); - Date now = new Date(); - - //鐢熸垚宸ヤ綔鍏� - AgvWrkMast wrkMast = createWrkMast(107, 21L, locDetl.getLocNo(), agvBasDevp.getDevNo(), agvLocDetl.getSuppCode(), now, userId,false); - //鐢熸垚宸ヤ綔鏄庣粏妗� - createWrkDetlReWrite(locDetl.getMatnr(),wrkMast.getWrkNo(),null,locDetl.getBatch(),locDetl.getCount(),wrkMast.getBarcode(),now,userId,agvLocDetl.getThreeCode(),agvLocDetl.getDeadTime()); - //淇敼搴撲綅淇℃伅 - updateAgvLocMast(agvLocMast,"P"); - //淇敼绔欑偣淇℃伅 - updateAgvBasDevp(agvBasDevp,"S"); - + LocDto locDto = new LocDto(locDetl.getLocNo(),locDetl.getCount(),locDetl.getMatnr(),locDetl.getBatch(),locDetl.getThreeCode(),locDetl.getDeadTime(),locDetl.getSuppCode()); + TaskDto taskDto = new TaskDto(locDetl.getLocNo(),station,locDto); + if(TaskDto.has(taskDtos,taskDto)){ + TaskDto.find(taskDtos,taskDto).getLocDtos().add(locDto); + }else { + taskDtos.add(taskDto); + } }); + + Date now = new Date(); + taskDtos.forEach(taskDto -> { + //鐢熸垚宸ヤ綔妗� + AgvWrkMast wrkMast = createWrkMast(107, 21L,taskDto.getLocNo(),taskDto.getAgvStaNo(),taskDto.getLocDtos().get(0).getContainerCode(),now,userId,false); + //鐢熸垚宸ヤ綔妗f槑缁� + taskDto.getLocDtos().forEach(locDto -> { + //鏄庣粏妗f墍闇�鍙傛暟 + createWrkDetlReWrite(locDto.getMatnr(), + wrkMast.getWrkNo(), + locDto.getOrderNo(), + locDto.getBatch(), + locDto.getAnfme(), + locDto.getContainerCode(), + now, + userId, + locDto.getCsocode(), + locDto.getIsoseq()); + }); + updateAgvLocMast(agvLocMastService.selectById(wrkMast.getSourceLocNo()),"P"); + //鏇存柊鐩爣绔欑偣鐘舵�� + //locSts = ioType == 101 ? "S" : "Q"; + updateAgvBasDevp(agvBasDevpService.selectById(wrkMast.getLocNo()),"S"); + }); + + +// param.getLocDetls().forEach(locDetl -> { +// AgvLocMast agvLocMast = agvLocMastService.selectById(locDetl.getLocNo()); +// AgvLocDetl agvLocDetl = agvLocDetlService.selectOne(new EntityWrapper<AgvLocDetl>().eq("loc_no", locDetl.getLocNo())); +// AgvBasDevp agvBasDevp = agvBasDevpService.selectOne(new EntityWrapper<AgvBasDevp>() +// .eq("station_code", station) +// .eq("loc_sts","O")); +// Date now = new Date(); +// +// //鐢熸垚宸ヤ綔鍏� +// AgvWrkMast wrkMast = createWrkMast(107, 21L, locDetl.getLocNo(), agvBasDevp.getDevNo(), agvLocDetl.getSuppCode(), now, userId,false); +// //鐢熸垚宸ヤ綔鏄庣粏妗� +// createWrkDetlReWrite(locDetl.getMatnr(),wrkMast.getWrkNo(),null,locDetl.getBatch(),locDetl.getCount(),wrkMast.getBarcode(),now,userId,agvLocDetl.getThreeCode(),agvLocDetl.getDeadTime()); +// //淇敼搴撲綅淇℃伅 +// updateAgvLocMast(agvLocMast,"P"); +// //淇敼绔欑偣淇℃伅 +// updateAgvBasDevp(agvBasDevp,"S"); +// +// }); } @@ -648,46 +685,11 @@ throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�"); } + //鏆傚瓨浣嶄换鍔�+1 + addInQty(locNo); + wrkMast = agvWrkMastService.selectOne(new EntityWrapper<AgvWrkMast>().eq("loc_no", locNo).eq("source_loc_no",sourceLocNo)); - return wrkMast; - } - - /* - 鐢熸垚宸ヤ綔妗� - */ - @Deprecated - private AgvWrkMast createWrkMast(AgvBasDevp agvBasDevp,AgvLocMast agvLocMast, Date now, Long userId){ - AgvWrkMast wrkMast = new AgvWrkMast(); - //鐢熸垚宸ヤ綔鍙� - //int workNo = agvCommonService.getWorkNo(0); - //wrkMast.setWrkNo(workNo); - wrkMast.setIoTime(new Date()); - // 宸ヤ綔鐘舵�侊細201.鐢熸垚鍏ュ簱浠诲姟ID - wrkMast.setWrkSts(201L); - // 鍏ュ嚭搴撶姸鎬侊細1.鍏ュ簱 - wrkMast.setIoType(1); - //鐢熸垚浼樺厛绾� - wrkMast.setIoPri(300.0); - wrkMast.setSourceLocNo(agvBasDevp.getDevNo()); - wrkMast.setLocNo(agvLocMast.getLocNo()); - wrkMast.setBarcode(agvBasDevp.getBarcode()); - // 婊℃澘锛歒 - wrkMast.setFullPlt("Y"); - // 鎷f枡 - wrkMast.setPicking("N"); - // 閫�鍑� - wrkMast.setExitMk("N"); - // 绌烘澘 - wrkMast.setEmptyMk("N"); - wrkMast.setLinkMis("N"); - wrkMast.setAppeUser(userId); - wrkMast.setAppeTime(now); - wrkMast.setModiUser(userId); - wrkMast.setModiTime(now); - if (!agvWrkMastService.insert(wrkMast)) { - throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�"); - } return wrkMast; } @@ -750,4 +752,15 @@ } } + private void addInQty(String devno){ + AgvBasDevp agvBasDevp = agvBasDevpService.selectById(devno); + if(!Cools.isEmpty(agvBasDevp)){ + if(Cools.isEmpty(agvBasDevp.getInQty())){ + agvBasDevp.setInQty(1); + }else { + agvBasDevp.setInQty(agvBasDevp.getInQty() + 1); + } + } + } + } -- Gitblit v1.9.1