From b8212145b46bd55d44c2190df05c3805b59e6816 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期二, 30 六月 2020 15:17:41 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java | 102 +++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 79 insertions(+), 23 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java index 9185303..aab1e09 100644 --- a/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/WorkServiceImpl.java @@ -46,6 +46,8 @@ private LocDetlService locDetlService; @Autowired private MatCodeService matCodeService; + @Autowired + private AdjDetlService adjDetlService; @Override @Transactional @@ -91,7 +93,7 @@ param.getList().forEach(elem -> { matDtos.add(new MatCodeCountDto(elem.getMatNo(), elem.getCount())); }); - wrkDetlService.createWorkDetail(workNo, matDtos, userId); + wrkDetlService.createWorkDetail(workNo, matDtos, param.getBarcode(), userId); // 鏇存柊婧愮珯鐐逛俊鎭� sourceStaNo.setWrkNo(workNo); sourceStaNo.setModiUser(userId); @@ -121,18 +123,18 @@ BasDevp staNo = basDevpService.checkSiteStatus(param.getOutSite()); // 鑾峰彇搴撲綅鏄庣粏 List<LocDetlDto> locDetlDtos = new ArrayList<>(); - for (StockOutParam.LocDetl locDetl : param.getLocDetls()) { - if (!Cools.isEmpty(locDetl.getLocNo(), locDetl.getMatnr(), locDetl.getCount())) { + for (StockOutParam.LocDetl paramLocDetl : param.getLocDetls()) { + if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr(), paramLocDetl.getCount())) { LocDetl sqlParam = new LocDetl(); - sqlParam.setLocNo(locDetl.getLocNo()); - sqlParam.setMatnr(locDetl.getMatnr()); + sqlParam.setLocNo(paramLocDetl.getLocNo()); + sqlParam.setMatnr(paramLocDetl.getMatnr()); LocDetl one = locDetlService.selectOne(new EntityWrapper<>(sqlParam)); - if (null != one) locDetlDtos.add(new LocDetlDto(one, locDetl.getCount())); + if (null != one) locDetlDtos.add(new LocDetlDto(one, paramLocDetl.getCount())); } } if (!locDetlDtos.isEmpty()) { - // 鍚姩鍑哄簱寮�濮� - stockOut(staNo, locDetlDtos, userId); + // 鍚姩鍑哄簱寮�濮� 101.鍑哄簱 + stockOut(staNo, locDetlDtos, 101, userId); } else { throw new CoolException("搴撲綅鐗╂枡涓嶅瓨鍦�"); } @@ -140,9 +142,7 @@ @Override @Transactional - public void stockOut(BasDevp staNo, List<LocDetlDto> locDetlDtos, Long userId) { - // 鐢熸垚宸ヤ綔鍙� - int workNo = commonService.getWorkNo(DEFAULT_WORK_NO_TYPE); + public void stockOut(BasDevp staNo, List<LocDetlDto> locDetlDtos, Integer ioType, Long userId) { // 鍚堝苟鍚岀被椤� Set<String> locNos = new HashSet<>(); locDetlDtos.forEach(dto -> locNos.add(dto.getLocDetl().getLocNo())); @@ -165,19 +165,21 @@ LocMast locMast = locMastService.selectById(dto.getLocNo()); // 鑾峰彇璺緞 Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() - .eq("type_no", 101) + .eq("type_no", ioType) .eq("stn_no", staNo.getDevNo()) .eq("crn_no", locMast.getCrnNo()); StaDesc staDesc = staDescService.selectOne(wrapper); if (Cools.isEmpty(staDesc)) { throw new CoolException("鍑哄簱璺緞涓嶅瓨鍦�"); } + // 鐢熸垚宸ヤ綔鍙� + int workNo = commonService.getWorkNo(DEFAULT_WORK_NO_TYPE); // 鐢熸垚宸ヤ綔妗� WrkMast wrkMast = new WrkMast(); wrkMast.setWrkNo(workNo); wrkMast.setIoTime(new Date()); wrkMast.setWrkSts(11L); // 宸ヤ綔鐘舵�侊細11.鐢熸垚鍑哄簱ID - wrkMast.setIoType(101); // 鍏ュ嚭搴撶姸鎬侊細101.鍑哄簱 + wrkMast.setIoType(ioType); // 鍏ュ嚭搴撶姸鎬侊細101.鍑哄簱 wrkMast.setIoPri(13D); // 浼樺厛绾э細13 wrkMast.setCrnNo(locMast.getCrnNo()); wrkMast.setSourceStaNo(staDesc.getCrnStn()); // 婧愮珯 @@ -197,12 +199,14 @@ } // 鐢熸垚宸ヤ綔妗f槑缁� for (LocDetlDto detlDto : dto.getLocDetlDtos()) { - if (detlDto.getCount() <= 0.0D) {continue;} + // 鍑哄簱鏃讹紝鏁伴噺涓�0鐨勭洿鎺ュ拷鐣� + if (detlDto.getCount()==null || detlDto.getCount() <= 0.0D) {continue;} WrkDetl wrkDetl = new WrkDetl(); wrkDetl.setWrkNo(workNo); wrkDetl.setIoTime(new Date()); wrkDetl.setMatnr(detlDto.getLocDetl().getMatnr()); - wrkDetl.setAnfme(detlDto.getCount()); // 鏁伴噺 + Double anfme = ioType==101?detlDto.getCount():detlDto.getLocDetl().getAnfme(); + wrkDetl.setAnfme(anfme); // 鏁伴噺 wrkDetl.setZmatid(detlDto.getLocDetl().getZmatid()); wrkDetl.setTbpos(detlDto.getLocDetl().getTbpos()); wrkDetl.setTbnum(detlDto.getLocDetl().getTbnum()); @@ -353,6 +357,30 @@ @Override @Transactional + public void locCheckOut(StockOutParam param, Long userId) { + // 鐩爣绔欑偣鐘舵�佹娴� + BasDevp staNo = basDevpService.checkSiteStatus(param.getOutSite()); + // 鑾峰彇搴撲綅鏄庣粏 + List<LocDetlDto> locDetlDtos = new ArrayList<>(); + for (StockOutParam.LocDetl paramLocDetl : param.getLocDetls()) { + if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr())) { + LocDetl sqlParam = new LocDetl(); + sqlParam.setLocNo(paramLocDetl.getLocNo()); + sqlParam.setMatnr(paramLocDetl.getMatnr()); + LocDetl one = locDetlService.selectOne(new EntityWrapper<>(sqlParam)); + if (null != one) locDetlDtos.add(new LocDetlDto(one, one.getAnfme())); + } + } + if (!locDetlDtos.isEmpty()) { + // 鍚姩鍑哄簱寮�濮� 107.鐩樼偣鍑哄簱 + stockOut(staNo, locDetlDtos, 107, userId); + } else { + throw new CoolException("搴撲綅鐗╂枡涓嶅瓨鍦�"); + } + } + + @Override + @Transactional public void locMove(String sourceLocNo, String locNo, Long userId) { LocMast sourceLoc = locMastService.selectById(sourceLocNo); if (Cools.isEmpty(sourceLoc)){ @@ -422,7 +450,7 @@ throw new CoolException("鏇存柊婧愬簱浣嶇姸鎬佸け璐�"); } } else { - throw new CoolException("棰勭害婧愬簱浣嶅嚭搴撳け璐ワ紝鐘舵�侊細"+sourceLoc.getLocType$()); + throw new CoolException("婧愬簱浣嶅嚭搴撳け璐ワ紝鐘舵�侊細"+sourceLoc.getLocType$()); } // 淇敼鐩爣搴撲綅鐘舵�� if (loc.getLocType().equals("O")) { @@ -469,13 +497,19 @@ throw new CoolException("搴撲綅涓嶅瓨鍦�"); } for (LocDetlAdjustParam.LocDetlAdjust adjust : param.getList()) { + if (Cools.isEmpty(adjust.getMatnr())) { + throw new CoolException(BaseRes.PARAM); + } LocDetl sqlParam = new LocDetl(); sqlParam.setLocNo(locMast.getLocNo()); - sqlParam.setMatnr(adjust.getMatNo()); + sqlParam.setMatnr(adjust.getMatnr()); LocDetl one = locDetlService.selectOne(new EntityWrapper<>(sqlParam)); // 淇濆瓨鏂板簱瀛樻槑缁� if (Cools.isEmpty(one)) { - MatCode matCode = matCodeService.selectById(adjust.getMatNo()); + if (adjust.getCount() == 0){ + continue; + } + MatCode matCode = matCodeService.selectById(adjust.getMatnr()); LocDetl locDetl = new LocDetl(); locDetl.setLocNo(locMast.getLocNo()); locDetl.setMatnr(matCode.getMatNo()); @@ -483,6 +517,12 @@ locDetl.setAnfme(adjust.getCount()); // 鏁伴噺 locDetl.setAltme(matCode.getStr1()); // 鍗曚綅 // todo:luxiaoao + locDetl.setLgnum("寰呭畾"); // 浠撳簱鍙� + locDetl.setTbnum(0); // 杞偍璇锋眰缂栧彿 + locDetl.setTbpos(0); // 琛岄」鐩� + locDetl.setZmatid("寰呭畾"); // 鐗╂枡鏍囩ID + locDetl.setZpallet("寰呭畾"); // 鎵樼洏鏉$爜 + locDetl.setModiUser(userId); // 鎿嶄綔浜哄憳淇℃伅 locDetl.setModiTime(new Date()); locDetl.setAppeUser(userId); @@ -490,6 +530,13 @@ if (!locDetlService.insert(locDetl)) { throw new CoolException("淇濆瓨搴撳瓨鏄庣粏澶辫触"); } + // 淇濆瓨璋冩暣璁板綍 + AdjDetl adjDetl = new AdjDetl(); + adjDetl.setLocNo(locDetl.getLocNo()); + adjDetl.setMatNo(locDetl.getMatnr()); + adjDetl.setOriQty(0.0D); + adjDetl.setAdjQty(adjust.getCount()); + adjDetlService.save(adjDetl, userId); // 淇敼鍘熷簱瀛樻槑缁� } else { // 濡傛灉鏁伴噺淇敼锛屽垯鏇存柊搴撳瓨鏄庣粏 @@ -500,16 +547,25 @@ throw new CoolException("娓呴櫎搴撳瓨鏄庣粏澶辫触"); } } else { - one.setAnfme(adjust.getCount()); - one.setModiTime(new Date()); - one.setModiUser(userId); - if (!locDetlService.updateById(one)) { + LocDetl sqlParam1 = new LocDetl(); + sqlParam1.setAnfme(adjust.getCount()); + sqlParam1.setModiTime(new Date()); + sqlParam1.setModiUser(userId); + if (!locDetlService.update(sqlParam1, new EntityWrapper<LocDetl>() + .eq("loc_no", locMast.getLocNo()) + .eq("matnr", adjust.getMatnr()))) { throw new CoolException("淇敼搴撳瓨鏄庣粏澶辫触"); } } + // 淇濆瓨璋冩暣璁板綍 + AdjDetl adjDetl = new AdjDetl(); + adjDetl.setLocNo(locMast.getLocNo()); + adjDetl.setMatNo(adjust.getMatnr()); + adjDetl.setOriQty(one.getAnfme()); + adjDetl.setAdjQty(adjust.getCount()); + adjDetlService.save(adjDetl, userId); } } - } } -- Gitblit v1.9.1