From 08b4403ec8d6b69528d161cfcad80b5d64dea76c Mon Sep 17 00:00:00 2001 From: Administrator <876263681@qq.com> Date: 星期三, 02 七月 2025 15:12:43 +0800 Subject: [PATCH] #优化库位检索 --- src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java | 726 ++++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 532 insertions(+), 194 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 9a0bc7f..162604f 100644 --- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java @@ -1,26 +1,24 @@ package com.zy.asrs.service.impl; -import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; -import com.core.common.*; +import com.core.common.BaseRes; +import com.core.common.Cools; +import com.core.common.R; +import com.core.common.SnowflakeIdWorker; import com.core.exception.CoolException; import com.zy.asrs.entity.*; +import com.zy.asrs.entity.param.CheckBom; import com.zy.asrs.entity.param.CombParam; import com.zy.asrs.entity.param.MobileAdjustParam; import com.zy.asrs.entity.param.OffSaleParam; -import com.zy.asrs.entity.param.OpenOrderPakinParam; import com.zy.asrs.mapper.ManLocDetlMapper; import com.zy.asrs.service.*; -import com.zy.asrs.utils.MatUtils; -import com.zy.common.CodeRes; -import com.zy.common.constant.MesConstant; -import com.zy.common.entity.Parameter; import com.zy.common.model.DetlDto; -import com.zy.common.model.MesCombParam; import com.zy.common.service.CommonService; -import com.zy.common.utils.HttpHandler; +import com.zy.common.utils.Synchro; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -77,13 +75,19 @@ private ManLocDetlService manLocDetlService; @Autowired private ManLocDetlMapper manLocDetlMapper; - + @Autowired + private DocTypeService docTypeService; + @Autowired + private MatV2Service matV2Service; @Override @Transactional public void comb(CombParam param, Long userId) { if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) { throw new CoolException(BaseRes.PARAM); + } + if(param.getCombMats().stream().anyMatch(obj -> obj.getAnfme() == null)){ + throw new CoolException("鍏ュ簱鐗╂枡鏁伴噺涓嶈兘涓虹┖"); } // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁 if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). @@ -92,15 +96,30 @@ } int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet",param.getBarcode())); - int countWrk = wrkDetlService.selectCount(new EntityWrapper<WrkDetl>().eq("zpallet",param.getBarcode())); - if (countLoc > 0 || countWrk > 0) { + WrkMast wrkMast = wrkMastService.selectByBarcode(param.getBarcode()); + if (wrkMast != null && wrkMast.getIoType() < 100){ + throw new CoolException("宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode()); + + } + if (countLoc > 0 ) { throw new CoolException("宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode()); } + + + //璁剧疆闈瀗ull鎵瑰彿锛� + for (CombParam.CombMat combMat : param.getCombMats()) { + if (combMat.getBatch() == null){ + combMat.setBatch(""); + } + } + + + Date now = new Date(); // 鏃犲崟缁勬墭 - if (Cools.isEmpty(param.getOrderNo())) { + if (Cools.isEmpty(param.getCombMats().get(0).getOrderNo())) { // 鐢熸垚鍏ュ簱閫氱煡妗� List<DetlDto> detlDtos = new ArrayList<>(); @@ -118,11 +137,17 @@ for (DetlDto detlDto : detlDtos) { Mat mat = matService.selectByMatnr(detlDto.getMatnr()); - if (Cools.isEmpty(mat)) { - throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); - } WaitPakin waitPakin = new WaitPakin(); - waitPakin.sync(mat); + if (Cools.isEmpty(mat)) { + MatV2 matV2 = matV2Service.selectOne(new EntityWrapper<MatV2>().eq("matnr", detlDto.getMatnr())); + if(Cools.isEmpty(matV2)){ + throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); + } + waitPakin.sync(matV2); + waitPakin.setBrand("缁勪欢"); + } else { + waitPakin.sync(mat); + } waitPakin.setBatch(detlDto.getBatch()); waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� @@ -138,24 +163,110 @@ } // 鍏宠仈缁勬墭 } else { - Order order = orderService.selectByNo(param.getOrderNo()); - if (order.getSettle() > 2) { - throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�"); + for (CombParam.CombMat combMat : param.getCombMats()) { + // 鐢熸垚鍏ュ簱閫氱煡妗� + Order order = orderService.selectByNo(combMat.getOrderNo()); + + //鍒ゆ柇璁㈠崟绫诲瀷鏄惁鏄叆搴� + DocType docType=docTypeService.selectById(order.getDocType()); + if(docType.getPakin()!=1 || docType.getStatus()!=1){ + throw new CoolException("璁㈠崟涓哄嚭搴撹鍗曪紝涓嶈兘缁勬墭锛�"); + } + + if (order.getSettle() > 2) { + throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�"); + } + OrderDetl orderDetl = orderDetlService.selectItem(combMat.getOrderNo(), combMat.getMatnr(), combMat.getBatch()); + if (orderDetl == null) { + throw new CoolException("鎵句笉鍒扮粍鎵樼殑鍗曟嵁鏄庣粏"); + } + //璁㈠崟鏁�-宸ヤ綔涓殑鏁伴噺-缁勬墭鏁伴噺 + if ( orderDetl.getAnfme() - orderDetl.getWorkQty() - combMat.getAnfme()<0) { + throw new CoolException("缁勬墭鏁伴噺宸茶秴鍑鸿鍗曢渶姹傞噺锛岃妫�鏌ユ槸鍚︽湁鍏朵粬鐨勭粍鎵樺凡瀹屾垚"); + } + // 淇敼璁㈠崟浣滀笟鏁伴噺 + if (!orderDetlService.increaseWorkQty(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme())) { + throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触"); + } + Mat mat = matService.selectByMatnr(combMat.getMatnr()); + if (Cools.isEmpty(mat)) { + throw new CoolException(combMat.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); + } + WaitPakin waitPakin = new WaitPakin(); + waitPakin.sync(mat); + waitPakin.setOrderNo(order.getOrderNo()); // 鍗曟嵁缂栧彿 + waitPakin.setBatch(combMat.getBatch()); // 搴忓垪鐮� + waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� + waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� + waitPakin.setAnfme(combMat.getAnfme()); // 鏁伴噺 + waitPakin.setStatus("Y"); // 鐘舵�� + waitPakin.setAppeUser(userId); + waitPakin.setAppeTime(now); + waitPakin.setModiUser(userId); + waitPakin.setModiTime(now); + if (!waitPakinService.insert(waitPakin)) { + throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); + } + +// DetlDto detlDto = new DetlDto(combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme()); +// if (DetlDto.has(detlDtos, detlDto)) { +// DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); +// assert one != null; +// one.setAnfme(one.getAnfme() + detlDto.getAnfme()); +// } else { +// } + orderService.updateSettle(order.getId(), 2L, userId); } + + } + + } + + @Override + @Transactional + public void comb2(CombParam param, Long userId) { + + if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) { + throw new CoolException(BaseRes.PARAM); + } + if(param.getCombMats().stream().anyMatch(obj -> obj.getAnfme() == null)){ + throw new CoolException("鍏ュ簱鐗╂枡鏁伴噺涓嶈兘涓虹┖"); + } + // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁 + if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). + eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) { + throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱"); + } + + int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet",param.getBarcode())); + WrkMast wrkMast = wrkMastService.selectByBarcode(param.getBarcode()); + if (wrkMast != null && wrkMast.getIoType() < 100){ + throw new CoolException("宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode()); + + } + if (countLoc > 0 ) { + throw new CoolException("宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�===>>" + param.getBarcode()); + } + + + //璁剧疆闈瀗ull鎵瑰彿锛� + for (CombParam.CombMat combMat : param.getCombMats()) { + if (combMat.getBatch() == null){ + combMat.setBatch(""); + } + } + + + + + Date now = new Date(); + + // 鏃犲崟缁勬墭 + if (Cools.isEmpty(param.getCombMats().get(0).getOrderNo())) { + // 鐢熸垚鍏ュ簱閫氱煡妗� List<DetlDto> detlDtos = new ArrayList<>(); param.getCombMats().forEach(elem -> { - - // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙 - OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), elem.getMatnr(), elem.getBatch()); - if (elem.getAnfme() > orderDetl.getEnableQty()) { - throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�"); - } - // 淇敼璁㈠崟浣滀笟鏁伴噺 - if (!orderDetlService.increaseWorkQty(order.getId(), elem.getMatnr(), elem.getBatch(), elem.getAnfme())) { - throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触"); - } - DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme()); if (DetlDto.has(detlDtos, detlDto)) { DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); @@ -165,20 +276,28 @@ detlDtos.add(detlDto); } }); + + for (DetlDto detlDto : detlDtos) { Mat mat = matService.selectByMatnr(detlDto.getMatnr()); - if (Cools.isEmpty(mat)) { - throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); - } WaitPakin waitPakin = new WaitPakin(); - waitPakin.sync(mat); - waitPakin.setOrderNo(order.getOrderNo()); // 鍗曟嵁缂栧彿 - waitPakin.setBatch(detlDto.getBatch()); // 搴忓垪鐮� + if (Cools.isEmpty(mat)) { + MatV2 matV2 = matV2Service.selectOne(new EntityWrapper<MatV2>().eq("matnr", detlDto.getMatnr())); + if(Cools.isEmpty(matV2)){ + throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); + } + waitPakin.sync(matV2); + waitPakin.setBrand("缁勪欢"); + } else { + waitPakin.sync(mat); + } + waitPakin.setBatch(detlDto.getBatch()); waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� waitPakin.setAnfme(detlDto.getAnfme()); // 鏁伴噺 waitPakin.setStatus("Y"); // 鐘舵�� waitPakin.setAppeUser(userId); + waitPakin.setBomCode(param.getBomCode()); waitPakin.setAppeTime(now); waitPakin.setModiUser(userId); waitPakin.setModiTime(now); @@ -186,9 +305,74 @@ throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); } } - orderService.updateSettle(order.getId(), 2L, userId); + // 鍏宠仈缁勬墭 + } else { + for (CombParam.CombMat combMat : param.getCombMats()) { + // 鐢熸垚鍏ュ簱閫氱煡妗� + Order order = orderService.selectByNo(combMat.getOrderNo()); + + //鍒ゆ柇璁㈠崟绫诲瀷鏄惁鏄叆搴� + DocType docType=docTypeService.selectById(order.getDocType()); + if(docType.getPakin()!=1 || docType.getStatus()!=1){ + throw new CoolException("璁㈠崟涓哄嚭搴撹鍗曪紝涓嶈兘缁勬墭锛�"); + } + + if (order.getSettle() > 2) { + throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�"); + } + OrderDetl orderDetl = orderDetlService.selectItem(combMat.getOrderNo(), combMat.getMatnr(), combMat.getBatch()); + if (orderDetl == null) { + throw new CoolException("鎵句笉鍒扮粍鎵樼殑鍗曟嵁鏄庣粏"); + } + //璁㈠崟鏁�-宸ヤ綔涓殑鏁伴噺-缁勬墭鏁伴噺 + if ( orderDetl.getAnfme() - orderDetl.getWorkQty() - combMat.getAnfme()<0) { + throw new CoolException("缁勬墭鏁伴噺宸茶秴鍑鸿鍗曢渶姹傞噺锛岃妫�鏌ユ槸鍚︽湁鍏朵粬鐨勭粍鎵樺凡瀹屾垚"); + } + // 淇敼璁㈠崟浣滀笟鏁伴噺 + if (!orderDetlService.increaseWorkQty(order.getId(), combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme())) { + throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触"); + } + Mat mat = matService.selectByMatnr(combMat.getMatnr()); + if (Cools.isEmpty(mat)) { + throw new CoolException(combMat.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); + } + WaitPakin waitPakin = new WaitPakin(); + waitPakin.sync(mat); + waitPakin.setOrderNo(order.getOrderNo()); // 鍗曟嵁缂栧彿 + waitPakin.setBatch(combMat.getBatch()); // 搴忓垪鐮� + waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� + waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� + waitPakin.setAnfme(combMat.getAnfme()); // 鏁伴噺 + waitPakin.setStatus("Y"); // 鐘舵�� + waitPakin.setAppeUser(userId); + waitPakin.setAppeTime(now); + waitPakin.setBomCode(param.getBomCode()); + waitPakin.setModiUser(userId); + waitPakin.setModiTime(now); + if (!waitPakinService.insert(waitPakin)) { + throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); + } + +// DetlDto detlDto = new DetlDto(combMat.getMatnr(), combMat.getBatch(), combMat.getAnfme()); +// if (DetlDto.has(detlDtos, detlDto)) { +// DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); +// assert one != null; +// one.setAnfme(one.getAnfme() + detlDto.getAnfme()); +// } else { +// } + orderService.updateSettle(order.getId(), 2L, userId); + } + } + } + + @Override + @Transactional + public R checkBom(CheckBom param, Long userId) { + + + return R.ok(); } // 鍟嗗搧涓婃灦 @@ -325,162 +509,162 @@ } - @Override - @Transactional - public void packComb(CombParam param, Long userId) { - if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) { - throw new CoolException(BaseRes.PARAM); - } - // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁 - if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). - eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) { - throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱"); - } - Date now = new Date(); - - boolean packDown = Parameter.get().getPackDown().equals("true"); - - // 鏃犲崟缁勬墭 - if (Cools.isEmpty(param.getOrderNo())) { - - // 鐢熸垚鍏ュ簱閫氱煡妗� - List<DetlDto> detlDtos = new ArrayList<>(); - param.getCombMats().forEach(elem -> { - // 鎵撳寘涓婄嚎鏁版嵁鏍¢獙 - if (packDown) { - Pack pack = packService.selectByBarcode(elem.getMatnr()); - if (pack == null) { - throw new CoolException(elem.getMatnr() + "鏉$爜鍐椾綑锛岃妫�鏌ワ紒"); - } - if (pack.getSettle() != 1) { - throw new CoolException(elem.getMatnr() + "鏉$爜宸蹭笅绾匡紝璇锋鏌ワ紒"); - } - } - Mat analyse = MatUtils.analyseMat(elem.getMatnr()); - // 鏉$爜銆佺墿鏂欎唬鐮併�佸簭鍒楀彿銆佹暟閲� - DetlDto detlDto = new DetlDto(elem.getMatnr(), analyse.getMatnr(), analyse.getBarcode(), elem.getAnfme()); -// DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme()); - if (DetlDto.has(detlDtos, detlDto)) { - DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); - assert one != null; - one.setAnfme(one.getAnfme() + detlDto.getAnfme()); - } else { - detlDtos.add(detlDto); - } - }); - - if (packDown) { - MesCombParam mesCombParam = new MesCombParam(); - mesCombParam.setZpallet(param.getBarcode()); - mesCombParam.setPakinTime(DateUtils.convert(now)); - mesCombParam.setLgort("5008"); - mesCombParam.setPlantCode("5000"); - mesCombParam.setFromCode("5012-20"); - mesCombParam.setStationCode("JJQ-PFZPDB-XX"); - for (DetlDto detlDto : detlDtos) { - mesCombParam.getList().add(new MesCombParam.Detl(detlDto.getOrderNo(), detlDto.getAnfme())); - } - String response = ""; - boolean success = false; - try { - response = new HttpHandler.Builder() - .setUri(MesConstant.URL) - .setPath(MesConstant.PACK_DOWN_URL) - .setJson(JSON.toJSONString(mesCombParam)) - .build() - .doPost(); - JSONObject jsonObject = JSON.parseObject(response); - if (jsonObject.getInteger("code").equals(200)) { - success = true; - } else if (jsonObject.getInteger("code").equals(500)) { - log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response); - throw new CoolException(jsonObject.getString("msg")); - } else { - log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response); - throw new CoolException("涓婃姤mes绯荤粺澶辫触"); - } - } catch (Exception e) { - log.error("fail", e); - throw new CoolException(e.getMessage()); - } finally { - try { - // 淇濆瓨鎺ュ彛鏃ュ織 - apiLogService.save( - "鎵撳寘涓嬬嚎甯墭涓婃姤", - MesConstant.URL + MesConstant.PACK_DOWN_URL, - null, - "127.0.0.1", - JSON.toJSONString(mesCombParam), - response, - success - ); - } catch (Exception e) { log.error("", e); } - } - - } - - // 鐢熸垚鍏ュ簱鍗曟嵁 - String orderNo = "PACK" + snowflakeIdWorker.nextId(); - OpenOrderPakinParam openParam = new OpenOrderPakinParam(); - openParam.setOrderNo(orderNo); - openParam.setOrderTime(DateUtils.convert(now)); - openParam.setOrderType("鎵撳寘鍏ュ簱鍗�"); - openParam.setOrderDetails(detlDtos); - openService.pakinOrderCreate(openParam); - Order order = orderService.selectByNo(orderNo); - if (null == order) { - throw new CoolException("鐢熸垚鍗曟嵁澶辫触"); - } - if (!orderService.updateSettle(order.getId(), 2L, userId)) { - throw new CoolException("淇敼鍗曟嵁鐘舵�佸け璐�"); - } - - // 鐢熸垚鍏ュ簱閫氱煡妗� - for (DetlDto detlDto : detlDtos) { - - // 淇敼浣滀笟鏁伴噺 ---------------------------------------- - // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙 - OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), detlDto.getMatnr(), detlDto.getBatch()); - if (detlDto.getAnfme() > orderDetl.getEnableQty()) { - throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�"); - } - // 淇敼璁㈠崟浣滀笟鏁伴噺 - if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) { - throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触"); - } - - // 淇濆瓨鍏ュ簱閫氱煡妗� - Mat mat = matService.selectByMatnr(detlDto.getMatnr()); - if (Cools.isEmpty(mat)) { - throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); - } - WaitPakin waitPakin = new WaitPakin(); - waitPakin.sync(mat); - waitPakin.setOrderNo(orderNo); - waitPakin.setBatch(detlDto.getBatch()); - waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� - waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� - waitPakin.setAnfme(detlDto.getAnfme()); // 鏁伴噺 - waitPakin.setStatus("Y"); // 鐘舵�� - waitPakin.setAppeUser(userId); - waitPakin.setAppeTime(now); - waitPakin.setModiUser(userId); - waitPakin.setModiTime(now); - if (!waitPakinService.insert(waitPakin)) { - throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); - } - // 淇敼鎵撳寘鏁版嵁鐘舵�� - Pack pack = packService.selectByBarcode(detlDto.getOrderNo()); - pack.setSettle(2L); - pack.setUpdateTime(now); - pack.setUpdateBy(userId); - if (!packService.updateById(pack)) { - throw new CoolException("淇敼鎵撳寘鏁版嵁寮傚父"); - } - } - - } - } +// @Override +// @Transactional +// public void packComb(CombParam param, Long userId) { +// if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) { +// throw new CoolException(BaseRes.PARAM); +// } +// // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁 +// if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). +// eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) { +// throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱"); +// } +// Date now = new Date(); +// +// boolean packDown = Parameter.get().getPackDown().equals("true"); +// +// // 鏃犲崟缁勬墭 +// if (Cools.isEmpty(param.getOrderNo())) { +// +// // 鐢熸垚鍏ュ簱閫氱煡妗� +// List<DetlDto> detlDtos = new ArrayList<>(); +// param.getCombMats().forEach(elem -> { +// // 鎵撳寘涓婄嚎鏁版嵁鏍¢獙 +// if (packDown) { +// Pack pack = packService.selectByBarcode(elem.getMatnr()); +// if (pack == null) { +// throw new CoolException(elem.getMatnr() + "鏉$爜鍐椾綑锛岃妫�鏌ワ紒"); +// } +// if (pack.getSettle() != 1) { +// throw new CoolException(elem.getMatnr() + "鏉$爜宸蹭笅绾匡紝璇锋鏌ワ紒"); +// } +// } +// Mat analyse = MatUtils.analyseMat(elem.getMatnr()); +// // 鏉$爜銆佺墿鏂欎唬鐮併�佸簭鍒楀彿銆佹暟閲� +// DetlDto detlDto = new DetlDto(elem.getMatnr(), analyse.getMatnr(), analyse.getBarcode(), elem.getAnfme()); +//// DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme()); +// if (DetlDto.has(detlDtos, detlDto)) { +// DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch()); +// assert one != null; +// one.setAnfme(one.getAnfme() + detlDto.getAnfme()); +// } else { +// detlDtos.add(detlDto); +// } +// }); +// +// if (packDown) { +// MesCombParam mesCombParam = new MesCombParam(); +// mesCombParam.setZpallet(param.getBarcode()); +// mesCombParam.setPakinTime(DateUtils.convert(now)); +// mesCombParam.setLgort("5008"); +// mesCombParam.setPlantCode("5000"); +// mesCombParam.setFromCode("5012-20"); +// mesCombParam.setStationCode("JJQ-PFZPDB-XX"); +// for (DetlDto detlDto : detlDtos) { +// mesCombParam.getList().add(new MesCombParam.Detl(detlDto.getOrderNo(), detlDto.getAnfme())); +// } +// String response = ""; +// boolean success = false; +// try { +// response = new HttpHandler.Builder() +// .setUri(MesConstant.URL) +// .setPath(MesConstant.PACK_DOWN_URL) +// .setJson(JSON.toJSONString(mesCombParam)) +// .build() +// .doPost(); +// JSONObject jsonObject = JSON.parseObject(response); +// if (jsonObject.getInteger("code").equals(200)) { +// success = true; +// } else if (jsonObject.getInteger("code").equals(500)) { +// log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response); +// throw new CoolException(jsonObject.getString("msg")); +// } else { +// log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response); +// throw new CoolException("涓婃姤mes绯荤粺澶辫触"); +// } +// } catch (Exception e) { +// log.error("fail", e); +// throw new CoolException(e.getMessage()); +// } finally { +// try { +// // 淇濆瓨鎺ュ彛鏃ュ織 +// apiLogService.save( +// "鎵撳寘涓嬬嚎甯墭涓婃姤", +// MesConstant.URL + MesConstant.PACK_DOWN_URL, +// null, +// "127.0.0.1", +// JSON.toJSONString(mesCombParam), +// response, +// success +// ); +// } catch (Exception e) { log.error("", e); } +// } +// +// } +// +// // 鐢熸垚鍏ュ簱鍗曟嵁 +// String orderNo = "PACK" + snowflakeIdWorker.nextId(); +// OpenOrderPakinParam openParam = new OpenOrderPakinParam(); +// openParam.setOrderNo(orderNo); +// openParam.setOrderTime(DateUtils.convert(now)); +// openParam.setOrderType("鎵撳寘鍏ュ簱鍗�"); +// openParam.setOrderDetails(detlDtos); +// openService.pakinOrderCreate(openParam); +// Order order = orderService.selectByNo(orderNo); +// if (null == order) { +// throw new CoolException("鐢熸垚鍗曟嵁澶辫触"); +// } +// if (!orderService.updateSettle(order.getId(), 2L, userId)) { +// throw new CoolException("淇敼鍗曟嵁鐘舵�佸け璐�"); +// } +// +// // 鐢熸垚鍏ュ簱閫氱煡妗� +// for (DetlDto detlDto : detlDtos) { +// +// // 淇敼浣滀笟鏁伴噺 ---------------------------------------- +// // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙 +// OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), detlDto.getMatnr(), detlDto.getBatch()); +// if (detlDto.getAnfme() > orderDetl.getEnableQty()) { +// throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�"); +// } +// // 淇敼璁㈠崟浣滀笟鏁伴噺 +// if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) { +// throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触"); +// } +// +// // 淇濆瓨鍏ュ簱閫氱煡妗� +// Mat mat = matService.selectByMatnr(detlDto.getMatnr()); +// if (Cools.isEmpty(mat)) { +// throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�"); +// } +// WaitPakin waitPakin = new WaitPakin(); +// waitPakin.sync(mat); +// waitPakin.setOrderNo(orderNo); +// waitPakin.setBatch(detlDto.getBatch()); +// waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� +// waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� +// waitPakin.setAnfme(detlDto.getAnfme()); // 鏁伴噺 +// waitPakin.setStatus("Y"); // 鐘舵�� +// waitPakin.setAppeUser(userId); +// waitPakin.setAppeTime(now); +// waitPakin.setModiUser(userId); +// waitPakin.setModiTime(now); +// if (!waitPakinService.insert(waitPakin)) { +// throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�"); +// } +// // 淇敼鎵撳寘鏁版嵁鐘舵�� +// Pack pack = packService.selectByBarcode(detlDto.getOrderNo()); +// pack.setSettle(2L); +// pack.setUpdateTime(now); +// pack.setUpdateBy(userId); +// if (!packService.updateById(pack)) { +// throw new CoolException("淇敼鎵撳寘鏁版嵁寮傚父"); +// } +// } +// +// } +// } @Override @Transactional @@ -619,4 +803,158 @@ throw new CoolException(locDetl.getLocNo() + "搴撲綅涓嶆槸鍦ㄥ簱鐘舵��"); } } + + + @Transactional + @Override + public R manDetlIn(JSONObject json) { + Date date = new Date(); + String jsonLocNo = (String) json.get("locNo"); + Node node = nodeService.selectOne(new EntityWrapper<Node>() + .eq("name", jsonLocNo)); + JSONArray combMats = json.getJSONArray("combMats"); + for (int i = 0; i < combMats.size(); i++) { + OrderDetl jsonOrderDetl = combMats.getObject(i, OrderDetl.class); + + //鏌ヨ鍗� + Order order = orderService.selectOne(new EntityWrapper<Order>() + .eq("order_no", jsonOrderDetl.getOrderNo())); + if (Cools.isEmpty(node, order)) { + return R.error("鍙傛暟涓虹┖"); + } + + //鍒ゆ柇璁㈠崟绫诲瀷鏄惁鏄叆搴� + DocType docType=docTypeService.selectById(order.getDocType()); + if(docType.getPakin()!=1 || docType.getStatus()!=1){ + return R.error("璇ヨ鍗曟槸鍑哄簱璁㈠崟锛屾棤娉曞叆搴�"); + } + + OrderDetl orderDetl = orderDetlService.selectItem(jsonOrderDetl.getOrderNo(),jsonOrderDetl.getMatnr(),jsonOrderDetl.getBatch()); + if (Cools.isEmpty(orderDetl)) { + return R.error("鍗曟嵁鏄庣粏鏈夎,璇锋鏌�"); + } + if (Cools.isEmpty(orderDetl.getAnfme())) { + return R.error("鏁伴噺涓虹┖锛�"); + } + if (orderDetl.getAnfme() - (jsonOrderDetl.getAnfme() + orderDetl.getWorkQty()) < 0) { + return R.error("鍏ュ簱鏁伴噺澶т簬鍙叆鏁伴噺"); + } + //鏌ヨ骞冲簱涓槸鍚︽湁涓�鏍风殑鍝佸彿锛屾湁鐨勮瘽鐩存帴澧炲姞鏁伴噺 + ManLocDetl checkManLocDetl = manLocDetlService.selectInventory(jsonLocNo,orderDetl.getMatnr(),jsonOrderDetl.getBatch()); + if (checkManLocDetl == null) { + ManLocDetl manLocDetl = new ManLocDetl(); + Synchro.Copy(orderDetl, manLocDetl); + manLocDetl.setLocNo(node.getName()); + manLocDetl.setNodeId(node.getId()); + manLocDetl.setMatnr(orderDetl.getMatnr()); + manLocDetl.setMaktx(jsonOrderDetl.getMaktx()); + manLocDetl.setAnfme(jsonOrderDetl.getAnfme()); + manLocDetl.setModiTime(date); + manLocDetl.setCreateTime(date); + manLocDetl.setBatch(jsonOrderDetl.getBatch()); + if(!manLocDetlService.insert(manLocDetl)){ + return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�"); + } + } else { + if(manLocDetlService.increase(checkManLocDetl.getAnfme() + jsonOrderDetl.getAnfme(), jsonOrderDetl.getOrderNo(), jsonOrderDetl.getMaktx(), jsonOrderDetl.getBatch())<=0){ + return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�"); + } + } + orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme()); + orderDetl.setWorkQty(orderDetl.getWorkQty() + jsonOrderDetl.getAnfme()); + orderDetl.setUpdateTime(date); + orderDetlService.updateById(orderDetl); + //鏇存柊璁㈠崟鐘舵�� + List<OrderDetl> orderDetls=orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",order.getOrderNo())); + order.setSettle(2L); + boolean log=true; + for (OrderDetl orderDetl1: orderDetls) { + //宸ヤ綔涓殑鏁伴噺灏忎簬鎬昏鍗曟暟鏃讹紝璁㈠崟鐘舵�佹敼涓�2锛屼綔涓氫腑 + if(orderDetl1.getQty() < orderDetl.getAnfme()){ + log=false; + } + } + if(log){ + order.setSettle(4L); + } + if(!orderService.updateById(order)){ + return R.error("鏇存柊璁㈠崟鐘舵�佸け璐�"); + } + orderService.checkComplete(order.getOrderNo()); + } + return R.ok("涓婃灦瀹屾垚"); + } + + @Transactional + @Override + public R manDetlOut(JSONObject json) { + Date date = new Date(); + String jsonLocNo = (String) json.get("locNo"); + Node node = nodeService.selectOne(new EntityWrapper<Node>() + .eq("name", jsonLocNo)); + JSONArray combMats = json.getJSONArray("combMats"); + for (int i = 0; i < combMats.size(); i++) { + OrderDetl jsonOrderDetl = combMats.getObject(i, OrderDetl.class); + Order order = orderService.selectOne(new EntityWrapper<Order>() + .eq("order_no", jsonOrderDetl.getOrderNo())); + + //鍒ゆ柇璁㈠崟绫诲瀷鏄惁鏄嚭搴� + DocType docType=docTypeService.selectById(order.getDocType()); + if(docType.getPakout()!=1 || docType.getStatus()!=1){ + return R.error("璇ヨ鍗曟槸鍏ュ簱璁㈠崟锛屾棤娉曞嚭搴�"); + } + if (Cools.isEmpty(node, order)) { + return R.error("鍙傛暟涓虹┖"); + } + OrderDetl orderDetl = orderDetlService.selectItem(jsonOrderDetl.getOrderNo(),jsonOrderDetl.getMatnr(),jsonOrderDetl.getBatch()); + if (Cools.isEmpty(orderDetl)) { + return R.error("鍗曟嵁鏄庣粏鏈夎,璇锋鏌�"); + } + if (jsonOrderDetl.getAnfme() > (orderDetl.getAnfme() - orderDetl.getWorkQty())) { + return R.error("鍑哄簱鏁伴噺澶т簬鍗曟嵁鍙嚭鏁伴噺"); + } + //鏌ヨ骞冲簱涓槸鍚︽湁涓�鏍风殑鍝佸彿 + ManLocDetl checkManLocDetl = manLocDetlService.selectInventory(jsonLocNo,orderDetl.getMatnr(),orderDetl.getBatch()); + if (checkManLocDetl == null) { + return R.error("璇ュ簱浣嶆病鏈夊嚭搴撶殑鐗╂枡淇℃伅"); + } + if (jsonOrderDetl.getAnfme() > checkManLocDetl.getAnfme()) { + return R.error("鍑哄簱鏁伴噺澶т簬鍙嚭鏁伴噺"); + } + Double finalQty = checkManLocDetl.getAnfme() - jsonOrderDetl.getAnfme(); + if (finalQty <= 0){ + if(manLocDetlService.deleteDatailed(jsonLocNo, jsonOrderDetl.getMatnr(), jsonOrderDetl.getBatch())<=0){ + return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�"); + } + }else { + if(manLocDetlService.increase(finalQty, jsonLocNo, jsonOrderDetl.getMatnr(), jsonOrderDetl.getBatch())<=0){ + return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�"); + } + } + orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme()); + orderDetl.setWorkQty(orderDetl.getWorkQty() + jsonOrderDetl.getAnfme()); + orderDetl.setUpdateTime(date); + orderDetlService.updateById(orderDetl); + //鏇存柊璁㈠崟鐘舵�� + List<OrderDetl> orderDetls=orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",order.getOrderNo())); + order.setSettle(2L); + boolean log=true; + for (OrderDetl orderDetl1: orderDetls) { + //宸ヤ綔涓殑鏁伴噺灏忎簬鎬昏鍗曟暟鏃讹紝璁㈠崟鐘舵�佹敼涓�2锛屼綔涓氫腑 + if(orderDetl1.getQty() < orderDetl.getAnfme()){ + log=false; + } + } + if(log){ + order.setSettle(4L); + } + if(!orderService.updateById(order)){ + return R.error("鏇存柊璁㈠崟鐘舵�佸け璐�"); + } + orderService.checkComplete(order.getOrderNo()); + } + return R.ok("涓嬫灦瀹屾垚"); + } + + } -- Gitblit v1.9.1