From 8b75fe61a3eefe36761aa0f82a79b59342aa6709 Mon Sep 17 00:00:00 2001 From: 1 <1> Date: 星期一, 20 十月 2025 16:10:31 +0800 Subject: [PATCH] # --- src/main/java/com/zy/common/web/WcsController.java | 45 +++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 43 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/zy/common/web/WcsController.java b/src/main/java/com/zy/common/web/WcsController.java index ab15718..b01636e 100644 --- a/src/main/java/com/zy/common/web/WcsController.java +++ b/src/main/java/com/zy/common/web/WcsController.java @@ -31,7 +31,8 @@ @RestController @RequestMapping("/rpc") public class WcsController { - + @Autowired + private WrkLastnoService wrkLastnoService; @Autowired private WrkMastService wrkMastService; @Autowired @@ -74,7 +75,7 @@ } return R.parse(CodeRes.NO_COMB_700); } - int countLoc = locDetlService.selectCount(new EntityWrapper<LocDetl>().eq("zpallet",param.getBarcode())); + 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) { return R.error(CodeRes.EXIST_500); @@ -178,6 +179,45 @@ } + /** + * 鐢熸垚宸ヤ綔鍙� + * + * @param wrkMk + * @return workNo(宸ヤ綔鍙�) + */ + public int getWorkNo(Integer wrkMk) { + WrkLastno wrkLastno = wrkLastnoService.selectById(wrkMk); + if (Cools.isEmpty(wrkLastno)) { + throw new CoolException("鏁版嵁寮傚父锛岃鑱旂郴绠$悊鍛�"); + } + + int workNo = wrkLastno.getWrkNo(); + int sNo = wrkLastno.getSNo(); + int eNo = wrkLastno.getENo(); + workNo = workNo >= eNo ? sNo : workNo + 1; + while (true) { + WrkMast wrkMast = wrkMastService.selectById(workNo); + if (null != wrkMast) { + workNo = workNo >= eNo ? sNo : workNo + 1; + } else { + break; + } + } + // 淇敼搴忓彿璁板綍 + if (workNo > 0) { + wrkLastno.setWrkNo(workNo); + wrkLastnoService.updateById(wrkLastno); + } + // 妫�楠� + if (workNo == 0) { + throw new CoolException("鐢熸垚宸ヤ綔鍙峰け璐ワ紝璇疯仈绯荤鐞嗗憳"); + } else { + if (wrkMastService.selectById(workNo) != null) { + throw new CoolException("鐢熸垚宸ヤ綔鍙�" + workNo + "鍦ㄥ伐浣滄。涓凡瀛樺湪"); + } + } + return workNo; + } @PostMapping("/auto/TransplantingOut/v1") @ResponseBody public R autoTransplantingOut(@RequestBody TransplantWork transplantWork){ @@ -194,6 +234,7 @@ Date now = new Date(); // 鐢熸垚宸ヤ綔妗� WrkMast wrkMast = new WrkMast(); + int workNo = getWorkNo(0); wrkMast.setWrkNo(9997); wrkMast.setIoTime(now); wrkMast.setWrkSts(11L); -- Gitblit v1.9.1