From 5ea5d085cc7c9a1aea3d4ee7e3a9c93ea05a2eb1 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期四, 17 七月 2025 16:35:16 +0800 Subject: [PATCH] 盘点功能优化 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java | 38 ++++++++++++++++++++++++++++++++++++++ 1 files changed, 38 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 e94be30..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 @@ -319,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