From 462a8c41fb4043017d75148873f9aa0559722ae3 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期五, 06 六月 2025 16:25:34 +0800 Subject: [PATCH] 添加下发执行功能 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/OutStockServiceImpl.java | 46 ++++++++++++++++++++++------------------------ 1 files changed, 22 insertions(+), 24 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 70e07a5..d0e8a20 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 @@ -80,7 +80,7 @@ }); List<AsnOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<AsnOrderItem>() .eq(AsnOrderItem::getAsnId, params.getOrders().getId())); - double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum(); + Double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum(); orders.setAnfme(sum); if (!this.updateById(orders)) { throw new CoolException("璁″垝鏀惰揣鏁伴噺淇敼澶辫触锛侊紒"); @@ -120,30 +120,25 @@ if (!deliveryItemService.updateById(deliveryItem)) { throw new CoolException("DO鍗曟槑缁嗘洿鏂板け璐ワ紒锛�"); } + + Delivery delivery = deliveryService.getOne(new LambdaQueryWrapper<Delivery>().eq(Delivery::getCode, orderItem.getPoCode())); + if (!Objects.isNull(delivery)) { + Double wkQty = Math.round((delivery.getWorkQty() - delivery.getAnfme()) * 10000) / 10000.0; + delivery.setWorkQty(wkQty.compareTo(0.0) >= 0 ? wkQty : 0).setExceStatus(POExceStatus.PO_EXCE_STATUS_UN_EXCE.val); + if (!deliveryService.updateById(delivery)) { + throw new CoolException("DO鍗曟嵁淇敼澶辫触锛侊紒"); + } + } } } } - if (!Objects.isNull(order.getPoId())) { - Delivery delivery = deliveryService.getById(order.getPoId()); - if (!Objects.isNull(delivery)) { - Double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum(); - Double workQty = Math.round((delivery.getWorkQty() - sum) * 10000) / 10000.0; - delivery.setWorkQty(workQty.compareTo(0.0) >= 0 ? workQty : 0).setExceStatus(POExceStatus.PO_EXCE_STATUS_UN_EXCE.val); - if (!deliveryService.updateById(delivery)) { - throw new CoolException("DO鍗曟嵁淇敼澶辫触锛侊紒"); - } - } - } if (!this.remove(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getId, id))) { throw new CoolException("涓诲崟鍒犻櫎澶辫触锛侊紒"); } if (!outStockItemService.remove(new LambdaQueryWrapper<AsnOrderItem>().eq(AsnOrderItem::getAsnId, id))) { throw new CoolException("鍗曟嵁鏄庣粏鍒犻櫎澶辫触锛侊紒"); } -// if (!this.saveOrUpdate(order)) { -// throw new CoolException("鍗曟嵁鍙栨秷澶辫触锛侊紒"); -// } return R.ok("鎿嶄綔鎴愬姛"); } @@ -193,12 +188,15 @@ List<AsnOrderItem> orderItems = new ArrayList<>(); listMap.get(key).forEach(item -> { AsnOrderItem orderItem = new AsnOrderItem(); + Double anfme = Math.round((item.getAnfme() - item.getWorkQty() - item.getQty()) * 10000) / 10000.0; BeanUtils.copyProperties(item, orderItem); orderItem.setId(null) .setPoCode(order.getPoCode()) .setMaktx(item.getMaktx()) .setMatnrCode(item.getMatnrCode()) .setFieldsIndex(item.getFieldsIndex()) + .setAnfme(anfme) + .setWorkQty(0.0) .setAsnId(order.getId()) .setAsnCode(order.getCode()) .setStockUnit(item.getUnit()) @@ -221,7 +219,7 @@ Double sum = orderItems.stream().mapToDouble(AsnOrderItem::getAnfme).sum(); //淇敼璁″垝鏁伴噺 - order.setAnfme(sum); + order.setAnfme(sum).setWorkQty(0.0); if (!this.saveOrUpdate(order)) { throw new CoolException("涓诲崟鏁伴噺淇敼澶辫触锛侊紒"); } @@ -229,8 +227,13 @@ throw new CoolException("鏄庣粏淇濆瓨澶辫触锛侊紒"); } + Short exceStatus = POExceStatus.PO_EXCE_STATUS_SECTION_DONE.val; + if (delivery.getAnfme().compareTo(order.getAnfme()) <= 0) { + exceStatus = AsnExceStatus.ASN_EXCE_STATUS_TASK_DONE.val; + } + if (!deliveryService.update(new LambdaUpdateWrapper<Delivery>() - .set(Delivery::getExceStatus, POExceStatus.PO_EXCE_STATUS_EXCE_ING.val) + .set(Delivery::getExceStatus, exceStatus) .set(Delivery::getWorkQty, sum) .eq(Delivery::getId, key))) { throw new CoolException("涓诲崟淇敼澶辫触锛侊紒"); @@ -352,11 +355,8 @@ } catch (Exception e) { throw new CoolException(e.getMessage()); } - return R.ok(); } - - /** * @param * @return @@ -377,16 +377,14 @@ throw new CoolException("涓诲崟淇敼澶辫触锛侊紒"); } if (Objects.isNull(params.getItems()) || params.getItems().isEmpty()) { - return R.ok("鏄庣粏鍙傛暟涓嶈兘涓虹┖锛侊紒"); + throw new CoolException("鏄庣粏鍙傛暟涓嶈兘涓虹┖锛侊紒"); } - try { svaeOrUpdateOrderItem(params, loginUserId); } catch (Exception e) { throw new CoolException(e.getMessage()); } - - return null; + return R.ok(); } /** -- Gitblit v1.9.1