From 89255f6e9692026ffe4ce20bf4454c963a35ad69 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期一, 26 五月 2025 12:56:30 +0800 Subject: [PATCH] 移库任务优化 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java | 44 +++++++++++---------- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java | 8 +++ rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CompanysController.java | 1 rsf-admin/src/page/task/TaskList.jsx | 2 rsf-server/src/main/java/com/vincent/rsf/server/api/service/WcsService.java | 2 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/WcsServiceImpl.java | 9 +++- 6 files changed, 39 insertions(+), 27 deletions(-) diff --git a/rsf-admin/src/page/task/TaskList.jsx b/rsf-admin/src/page/task/TaskList.jsx index b8bb98a..56a3dc8 100644 --- a/rsf-admin/src/page/task/TaskList.jsx +++ b/rsf-admin/src/page/task/TaskList.jsx @@ -273,7 +273,7 @@ } } return ( - record.taskStatus === 1 ? + (record.taskStatus >= 1 && record.taskType < 50) || (record.taskStatus == 101) ? <Button onClick={clickCancel} label="toolbar.cancel"> diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/WcsService.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/WcsService.java index d80943f..5d0444f 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/WcsService.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/WcsService.java @@ -8,5 +8,5 @@ void agvTaskPickUpComplete(TaskInParam param); - InTaskMsgDto getLocNo(TaskInParam param); + InTaskMsgDto getLocNo(TaskInParam param) throws Exception; } diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/WcsServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/WcsServiceImpl.java index 57b0eb8..8d97ef5 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/WcsServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/WcsServiceImpl.java @@ -95,7 +95,12 @@ String ruleCode = generateTaskCode(); // 鑾峰彇搴撲綅鍙� - InTaskMsgDto locNo = getLocNo(param); + InTaskMsgDto locNo = null; + try { + locNo = getLocNo(param); + } catch (Exception e) { + throw new RuntimeException(e); + } // 鍒涘缓骞朵繚瀛樹换鍔� Task task = createTask(ruleCode, locNo.getLocNo(), waitPakin.getBarcode(), @@ -329,7 +334,7 @@ // return locNo; // } @Override - public InTaskMsgDto getLocNo(TaskInParam param) { + public InTaskMsgDto getLocNo(TaskInParam param) throws Exception{ String matnr = null; String batch = null; List<WaitPakin> waitPakins = waitPakinService.list(new LambdaQueryWrapper<WaitPakin>().eq(WaitPakin::getBarcode, param.getBarcode())); diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CompanysController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CompanysController.java index be38f07..b75b092 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CompanysController.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/CompanysController.java @@ -114,7 +114,6 @@ if (Objects.isNull(companys.getType())) { throw new CoolException("绫诲瀷涓嶈兘涓虹┖锛侊紒"); } - companys.setUpdateTime(null); companys.setUpdateBy(getLoginUserId()); if (!companysService.updateById(companys)) { diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java index 9c58464..d817edc 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocItemServiceImpl.java @@ -226,7 +226,13 @@ param.setIoType(TaskType.TASK_TYPE_OUT.type) .setSourceStaNo(Integer.parseInt(deviceSite.getSite())) .setLocType1(Integer.parseInt(orgLoc.getType())); - InTaskMsgDto locNo = wcsService.getLocNo(param); + InTaskMsgDto locNo = null; + try { + locNo = wcsService.getLocNo(param); + } catch (Exception e) { + log.error("<UNK>", e); + throw new CoolException(e.getMessage()); + } targetLoc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, locNo.getLocNo())); } else { targetLoc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, map.get("tarLoc").toString())); diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java index ff45705..42555f0 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java @@ -414,7 +414,7 @@ Loc orgLoc = locService.getOne(new LambdaQueryWrapper<Loc>().eq(Loc::getCode, task.getOrgLoc())); if (Objects.isNull(orgLoc)) { - throw new CoolException("鐩爣搴撲綅涓嶅瓨鍦紒"); + throw new CoolException("婧愬簱浣嶄笉瀛樺湪锛�"); } if (!loc.getUseStatus().equals(LocStsType.LOC_STS_TYPE_S.type)) { @@ -444,12 +444,21 @@ // throw new CoolException(e.getMessage()); // } /**淇敼搴撲綅鐘舵�佷负F.鍦ㄥ簱*/ - if (!locService.update(new LambdaUpdateWrapper<Loc>().set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_F.type).eq(Loc::getCode, task.getTargLoc()))) { + if (!locService.update(new LambdaUpdateWrapper<Loc>() + .set(Loc::getBarcode, task.getBarcode()) + .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_F.type) + .eq(Loc::getCode, task.getTargLoc()))) { throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } - if (!locService.update(new LambdaUpdateWrapper<Loc>().set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type).eq(Loc::getCode, task.getOrgLoc()))) { + if (!locService.update(new LambdaUpdateWrapper<Loc>() + .set(Loc::getBarcode, null) + .set(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_O.type).eq(Loc::getCode, task.getOrgLoc()))) { throw new CoolException("搴撲綅鐘舵�佷慨鏀瑰け璐ワ紒锛�"); + } + + if (!locItemService.remove(new LambdaQueryWrapper<LocItem>().eq(LocItem::getLocCode, task.getOrgLoc()))) { + throw new CoolException("婧愬簱浣嶆槑缁嗗垹闄ゅけ璐ワ紒"); } if (!this.update(new LambdaUpdateWrapper<Task>().eq(Task::getId, task.getId()).set(Task::getTaskStatus, TaskStsType.UPDATED_IN.id))) { @@ -524,18 +533,10 @@ throw new CoolException("鏁版嵁閿欒锛屼綔涓氫腑搴撳瓨鏁版嵁涓㈠け锛侊紒"); } if (task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type)) { - locWorking.setWorkQty(0.0); locWorking.setAnfme(taskItem.getAnfme()); - } else { - if (locWorking.getAnfme().compareTo(taskItem.getAnfme()) >= 0) { - locWorking.setWorkQty(0.0); - locWorking.setAnfme(Math.round((locWorking.getAnfme() - taskItem.getAnfme()) * 10000) / 10000.0); - } else { - continue; - } } BeanUtils.copyProperties(locWorking, locItem); - locItem.setLocCode(loc.getCode()).setLocId(loc.getId()).setId(null); + locItem.setWorkQty(0.0).setLocCode(loc.getCode()).setLocId(loc.getId()).setId(null); items.add(locItem); } @@ -547,13 +548,11 @@ //淇濆瓨鍏ュ嚭搴撴祦姘� saveStockItems(taskItems, task, null, null, taskItem.getWkType(), taskItem.getOrderType()); - if (!locItemWorkingService.remove(new LambdaQueryWrapper<LocItemWorking>().eq(LocItemWorking::getTaskId, task.getId()))) { throw new CoolException("浣滀笟涓簱瀛樺垹闄ゅけ璐ワ紒锛�"); } - task.setTaskStatus(TaskStsType.UPDATED_IN.id); - + task.setTaskStatus(TaskStsType.UPDATED_IN.id).setUpdateTime(null); if (!taskService.updateById(task)) { throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�"); } @@ -569,7 +568,10 @@ @Override public R removeTask(Long[] ids) { List<Integer> longs = Arrays.asList(TaskStsType.GENERATE_IN.id, TaskStsType.GENERATE_OUT.id); - List<Task> tasks = this.list(new LambdaQueryWrapper<Task>().in(Task::getId, ids).in(Task::getTaskStatus, longs)); + List<Integer> list = Arrays.asList(TaskType.TASK_TYPE_IN.type, TaskType.TASK_TYPE_OUT.type, TaskType.TASK_TYPE_EMPITY_IN.type, TaskType.TASK_TYPE_EMPITY_OUT.type, TaskType.TASK_TYPE_MERGE_OUT.type); + List<Task> tasks = this.list(new LambdaQueryWrapper<Task>() + .in(Task::getTaskType, list) + .in(Task::getId, ids).in(Task::getTaskStatus, longs)); if (tasks.isEmpty()) { throw new CoolException("浠诲姟宸插鎵ц鐘舵�佷笉鍙彇娑堬紒锛�"); } @@ -831,9 +833,9 @@ } //鍏ㄦ澘鍑哄簱锛屽垹闄や复鏃跺簱瀛� - if (!locItemWorkingService.remove(new LambdaQueryWrapper<LocItemWorking>().eq(LocItemWorking::getTaskId, task.getId()))) { - throw new CoolException("涓存椂搴撳瓨娓呴櫎澶辫触锛侊紒"); - } + if (!locItemWorkingService.remove(new LambdaQueryWrapper<LocItemWorking>().eq(LocItemWorking::getTaskId, task.getId()))) { + throw new CoolException("涓存椂搴撳瓨娓呴櫎澶辫触锛侊紒"); + } } @@ -938,7 +940,7 @@ List<TaskItem> items = orderMap.get(key); try { //淇濆瓨搴撳瓨鏄庣粏 - saveStockItems(items, task, pakinItem.getId(), pakinItem.getAsnCode(), pakinItem.getWkType(), pakinItem.getType()); + saveStockItems(items, task, pakinItem.getId(), pakinItem.getAsnCode(), pakinItem.getWkType(), pakinItem.getType()); //绉诲嚭鏀惰揣鍖哄簱瀛橈紝 淇敼缁勬墭鐘舵�� removeReceiptStock(pakinItem); } catch (Exception e) { @@ -1045,7 +1047,7 @@ task.getTaskType().equals(TaskType.TASK_TYPE_MERGE_IN.type) || task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type) || task.getTaskType().equals(TaskType.TASK_TYPE_EMPITY_IN.type) || - task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type) ) { + task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type)) { stock.setLocCode(task.getTargLoc()); } else { stock.setLocCode(task.getOrgLoc()); -- Gitblit v1.9.1