From 0a0aca0ce4696a228b55d4957f9cb634279970e0 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期六, 17 一月 2026 14:56:01 +0800
Subject: [PATCH] 工序新增bug+工序bom工艺路线删除的时候校验

---
 src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java |   16 +++++-----------
 1 files changed, 5 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
index 1dadd18..4f65d1f 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
@@ -702,9 +702,10 @@
                 productOrder.setCompleteQuantity(BigDecimal.ZERO);//瀹屾垚鏁伴噺
                 productOrderMapper.insert(productOrder);
 
-                ProcessRoute processRoute = processRouteMapper.selectOne(new QueryWrapper<ProcessRoute>().lambda().eq(ProcessRoute::getProductModelId, salesLedgerProduct.getProductModelId()));
-                List<ProductStructureDto> productStructureDtos = productStructureMapper.listBybomId(processRoute.getBomId());
-                if (processRoute != null) {
+                ProcessRoute processRoute = processRouteMapper.selectList(new QueryWrapper<ProcessRoute>().lambda()
+                        .eq(ProcessRoute::getProductModelId, salesLedgerProduct.getProductModelId())
+                        .orderByDesc(ProcessRoute::getCreateTime)).get(0);
+                if (ObjectUtils.isNotNull(processRoute)) {
                     //鏂板鐢熶骇璁㈠崟宸ヨ壓璺嚎涓昏〃
                     ProductProcessRoute productProcessRoute = new ProductProcessRoute();
                     productProcessRoute.setProductModelId(processRoute.getProductModelId());
@@ -748,14 +749,7 @@
                             // 鐢熸垚瀹屾暣鐨勫伐鍗曞彿
                             String workOrderNoStr = String.format("%s%03d", datePrefix, sequenceNumber);
                             ProductWorkOrder productWorkOrder = new ProductWorkOrder();
-                            productStructureDtos.stream().forEach(productStructureDto -> {
-                                if (productStructureDto.getProductModelId().equals(productProcessRouteItem.getProductModelId())){
-                                    productWorkOrder.setPlanQuantity(productWorkOrder.getPlanQuantity());
-                                }
-                            });
-                            if (Objects.equals(productProcessRouteItem.getProductModelId(), salesLedgerProduct.getProductModelId())) {
-                                productWorkOrder.setPlanQuantity(salesLedgerProduct.getQuantity());
-                            }
+                            productWorkOrder.setPlanQuantity(salesLedgerProduct.getQuantity());
                             productWorkOrder.setProductProcessRouteItemId(productProcessRouteItem.getId());
                             productWorkOrder.setProductOrderId(productOrder.getId());
                             productWorkOrder.setWorkOrderNo(workOrderNoStr);

--
Gitblit v1.9.3