From c05d4037b04f5182088fcf07835409a6eda83362 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期二, 10 六月 2025 14:44:45 +0800 Subject: [PATCH] 下发执行功能优化 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java | 41 +++++++++++++++++++++++++++++++++++++---- 1 files changed, 37 insertions(+), 4 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java index 705b509..def395e 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java @@ -1,7 +1,6 @@ package com.vincent.rsf.server.manager.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; -import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.vincent.rsf.framework.common.Cools; @@ -429,15 +428,15 @@ * 鐢熸垚鍑哄簱浠诲姟 * * @param params + * @param outId * @return */ @Override @Transactional(rollbackFor = Exception.class) - public R genOutStockTask(List<OutStockToTaskParams> params, Long loginUserId) { + public R genOutStockTask(List<OutStockToTaskParams> params, Long loginUserId, Long outId) { if (params.isEmpty()) { throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒"); } - //浼樺厛鐢熸垚娴呭簱浣嶄换鍔� List<OutStockToTaskParams> Items = params.stream().sorted(Comparator.comparing(OutStockToTaskParams::getLocCode).thenComparing(item -> { return LocUtils.isShallowLoc(item.getLocCode()) ? 1 : 0; @@ -455,19 +454,53 @@ locItems.add(locItem); LocToTaskParams taskParams = new LocToTaskParams(); - taskParams.setType(Constants.TASK_TYPE_OUT_STOCK) + taskParams.setType(Constants.TASK_TYPE_ORDER_OUT_STOCK) .setOrgLoc(loc.getCode()) .setItems(locItems) + .setSourceId(outId) .setSiteNo(param.getSiteNo()); try { + //鐢熸垚鍑哄簱浠诲姟 locItemService.generateTask(taskParams, loginUserId); } catch (Exception e) { logger.error("UNK", e); throw new CoolException(e.getMessage()); } + + AsnOrderItem orderItem = outStockItemService.getOne(new LambdaQueryWrapper<AsnOrderItem>() + .eq(AsnOrderItem::getAsnId, outId) + .eq(StringUtils.isNotBlank(locItem.getBatch()), AsnOrderItem::getSplrBatch, locItem.getBatch()) + .eq(StringUtils.isNotBlank(locItem.getFieldsIndex()), AsnOrderItem::getFieldsIndex, locItem.getFieldsIndex()) + .eq(AsnOrderItem::getMatnrId, locItem.getMatnrId())); + + if (Objects.isNull(orderItem)) { + throw new CoolException("鍗曟嵁鏄庣粏涓嶅瓨鍦紒锛�"); + } + + Double workQty = Math.round((orderItem.getWorkQty() + locItem.getOutQty()) * 10000) / 10000.0; + + orderItem.setUpdateBy(loginUserId).setUpdateTime(new Date()).setWorkQty(workQty); + + if (!outStockItemService.updateById(orderItem)) { + throw new CoolException("鍗曟嵁鏄庣粏淇敼澶辫触锛侊紒"); + } } } + Double sum = Items.stream().mapToDouble(OutStockToTaskParams::getOutQty).sum(); + //鏇存柊鍑哄簱鍗曟槑缁嗗強涓诲崟 + AsnOrder outOrder = outStockService.getById(outId); + if (Objects.isNull(outOrder)) { + throw new CoolException("鍑哄簱鍗曟嵁涓嶅瓨鍦紒锛�"); + } + Double workQty = Math.round((outOrder.getWorkQty() + sum) * 10000) / 10000.0; + + outOrder.setWorkQty(workQty).setExceStatus( AsnExceStatus.OUT_STOCK_STATUS_TASK_CREATE.val); + + if (!outStockService.updateById(outOrder)) { + throw new CoolException("鍑哄簱鍗曠姸鎬佷慨鏀瑰け璐ワ紒锛�"); + } + return R.ok(); } -- Gitblit v1.9.1