From c0a87b9244e1521c76b8a0dc70b922f6fc3e30a1 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期四, 17 七月 2025 16:35:23 +0800 Subject: [PATCH] Merge branch 'devlop' of http://47.97.1.152:5880/r/wms-master into devlop --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 43 insertions(+), 0 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java index 88ee4ef..e2893b3 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java @@ -48,6 +48,8 @@ private LocServiceImpl locService; @Autowired private TaskItemServiceImpl taskItemService; + @Autowired + private CheckOrderService checkOrderService; /** * @author Ryan @@ -281,7 +283,12 @@ List<CheckOrderItemParams> itemParams = listMap.get(key); CheckOrderItemParams checkItem = itemParams.stream().findFirst().get(); Task task = new Task(); + String ruleCode = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_TASK_CODE, null); + if (StringUtils.isBlank(ruleCode)) { + throw new CoolException("浠诲姟鍙蜂笉鑳戒负绌猴紒锛�"); + } task.setOrgLoc(loc.getCode()) + .setTaskCode(ruleCode) .setTargSite(checkItem.getSiteNo()) .setResource(TaskResouceType.TASK_RESOUCE_CHECK_TYPE.val) .setTaskType(TaskType.TASK_TYPE_CHECK_OUT.type) @@ -314,10 +321,46 @@ .setCreateTime(new Date()) .setPlatItemId(checkParam.getPlatItemId()); items.add(taskItem); + + if (!checkOrderItemService.update(new LambdaUpdateWrapper<WkOrderItem>() + .eq(WkOrderItem::getId, checkParam.getId()) + .setSql("work_qty = work_qty + " + item.getAnfme()) + .set(WkOrderItem::getWorkQty, checkItem.getAnfme()))) { + throw new CoolException("鐩樼偣鏄庣粏淇敼澶辫触锛侊紒"); + } }); if (!taskItemService.saveBatch(items)) { throw new CoolException("浠诲姟鏄庣粏淇濆瓨澶辫触锛侊紒"); } + + loc.setUseStatus(LocStsType.LOC_STS_TYPE_R.type); + if (!locService.updateById(loc)) { + throw new CoolException("搴撲綅棰勭害鍑哄簱澶辫触锛侊紒"); + } + + }); + + Set<Long> checkItemIds = checkParams.stream().map(CheckOrderParams::getOrderId).collect(Collectors.toSet()); + checkItemIds.forEach(orderId -> { + WkOrder order = this.getById(orderId); + if (Objects.isNull(order)) { + throw new CoolException("鏁版嵁閿欒锛氬崟鎹笉瀛樺湪锛侊紒"); + } + List<WkOrderItem> orderItems = checkOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>().eq(WkOrderItem::getOrderId, orderId)); + if (orderItems.isEmpty()) { + throw new CoolException("鏁版嵁閿欒锛氬崟鎹槑缁嗕笉瀛樺湪锛侊紒"); + } + Double sum = orderItems.stream().mapToDouble(WkOrderItem::getWorkQty).sum(); + + if (order.getAnfme().compareTo(sum) <= 0) { + order.setWorkQty(sum).setExceStatus(CheckExceStatus.CHECK_ORDER_STATUS_EXCE_DONE.val); + } else { + order.setWorkQty(sum).setExceStatus(CheckExceStatus.CHECK_ORDER_STATUS_EXCE_ING.val); + } + + if (!this.updateById(order)) { + throw new CoolException("鐩樼偣鍗曚俊鎭慨鏀瑰け璐ワ紒锛�"); + } }); } return R.ok(); -- Gitblit v1.9.1