From d391cb25460566aac81548c28c673912048caff3 Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期四, 23 四月 2026 15:43:37 +0800
Subject: [PATCH] feat(production): 更新工艺路线数据结构并实现反向新增功能

---
 src/main/java/com/ruoyi/production/service/impl/ProcessRouteServiceImpl.java |   53 +++++++++++++++++++++++++----------------------------
 1 files changed, 25 insertions(+), 28 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProcessRouteServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProcessRouteServiceImpl.java
index fe2b037..6d4692e 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProcessRouteServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProcessRouteServiceImpl.java
@@ -82,15 +82,16 @@
     }
 
 
-
     /**
-     * 宸ヨ壓璺嚎鍙嶅悜鏂板  鍙柊澧炰簡bom bom瀛愯〃  宸ヨ壓璺嚎  宸ヨ壓璺嚎瀛愯〃
-     * @param processRouteAnticlockwiseDtos  宸ヨ壓瀛愯〃
-     * @param productModelId 鎴愬搧瑙勬牸鍨嬪彿id
-     * @param productOrderId 鐢熶骇璁㈠崟id
+     * 宸ヨ壓璺嚎鍙嶅悜鏂板  鏂板浜哹om bom瀛愯〃  宸ヨ壓璺嚎  宸ヨ壓璺嚎瀛愯〃 鐢熶骇宸ヨ壓璺嚎涓昏〃  鐢熶骇宸ヨ壓璺嚎瀛愯〃 宸ュ崟琛�
+     *
+     * @param processRouteAnticlockwiseDtos 宸ヨ壓瀛愯〃
+     * @param productModelId                鎴愬搧瑙勬牸鍨嬪彿id
+     * @param productOrderId                鐢熶骇璁㈠崟id
      * @return
      */
     @Transactional(rollbackFor = Exception.class)
+    @Override
     public Long processRouteAnticlockwise(List<ProcessRouteAnticlockwiseDto> processRouteAnticlockwiseDtos, Long productModelId, Long productOrderId) {
         ProductOrder byId = productOrderService.getById(productOrderId);
         // 1. 鏂板BOM
@@ -107,24 +108,11 @@
         List<ProcessRouteItem> processRouteItems = buildProcessRouteItems(processRouteAnticlockwiseDtos, processRoute.getId(), productModelId);
         processRouteItemService.saveBatch(processRouteItems);
 
-//        // 5. 鏂板鐢熶骇宸ヨ壓璺嚎
-//        ProductProcessRoute productProcessRoute = createProductProcessRoute(productModelId, productOrderId, productBom.getId(), processRoute.getProcessRouteCode());
-//
-//        // 6. 鏂板鐢熶骇宸ヨ壓璺嚎瀛愯〃
-//        List<ProductProcessRouteItem> productProcessRouteItems = buildProductProcessRouteItems(processRouteAnticlockwiseDtos, productProcessRoute.getId(), productModelId);
-//        productProcessRouteItemService.saveBatch(productProcessRouteItems);
-//        for (ProductProcessRouteItem item : productProcessRouteItems) {
-//            ProductProcess productProcess = productProcessService.getById(item.getProcessId());
-//            ProductWorkOrder productWorkOrder = new ProductWorkOrder();
-//            productWorkOrder.setProductProcessRouteItemId(item.getId());
-//            productWorkOrder.setProductOrderId(productOrderId);
-//            ProductOrder order = productOrderMapper.selectById(productOrderId);
-//            productWorkOrder.setPlanQuantity(order.getQuantity());
-//            productWorkOrder.setWorkOrderNo(productWorkOrderService.generateProductWorkOrder(null, productProcess.getName(), byId.getNpsNo()));
-//            productWorkOrder.setStatus(1);
-//            productWorkOrderService.save(productWorkOrder);
-//        }
+        // 5. 鏂板鐢熶骇宸ヨ壓璺嚎
+        ProductProcessRoute productProcessRoute = createProductProcessRoute(productModelId, productOrderId, productBom.getId(), processRoute.getProcessRouteCode());
 
+        // 6. 鏂板鐢熶骇宸ヨ壓璺嚎瀛愯〃
+        buildProductProcessRouteItems(processRouteAnticlockwiseDtos, productProcessRoute.getId(), productModelId,productOrderId);
         return processRoute.getId();
     }
 
@@ -216,8 +204,8 @@
     /**
      * 鏋勫缓鐢熶骇宸ヨ壓璺嚎瀛愰」鍒楄〃
      */
-    private List<ProductProcessRouteItem> buildProductProcessRouteItems(List<ProcessRouteAnticlockwiseDto> dtos, Long productRouteId, Long productModelId) {
-        List<ProductProcessRouteItem> items = new ArrayList<>(dtos.size());
+    private void buildProductProcessRouteItems(List<ProcessRouteAnticlockwiseDto> dtos, Long productRouteId, Long productModelId,Long productOrderId) {
+        ProductOrder byId = productOrderService.getById(productOrderId);
         for (ProcessRouteAnticlockwiseDto dto : dtos) {
             ProductProcessRouteItem item = new ProductProcessRouteItem();
             item.setProductRouteId(productRouteId);
@@ -228,10 +216,19 @@
             item.setProcessRouteNum(dto.getProcessRouteNum());
             item.setProcessRouteAddNum(dto.getProcessRouteAddNum());
             item.setProcessRouteRequire(dto.getProcessRouteRequire());
-            items.add(item);
-
-
+            productProcessRouteItemService.save(item);
+            ProductProcess productProcess = productProcessService.getById(item.getProcessId());
+            //鍚屾鏂板鐢熶骇宸ュ崟
+            ProductWorkOrder productWorkOrder = new ProductWorkOrder();
+            productWorkOrder.setProductProcessRouteItemId(item.getId());
+            productWorkOrder.setProductOrderId(productOrderId);
+            ProductOrder order = productOrderMapper.selectById(productOrderId);
+            productWorkOrder.setPlanQuantity(order.getQuantity());
+            productWorkOrder.setDeviceId(dto.getDeviceId());
+            productWorkOrder.setUserIds(dto.getUserIds());
+            productWorkOrder.setWorkOrderNo(productWorkOrderService.generateProductWorkOrder(null, productProcess.getName(), byId.getNpsNo()));
+            productWorkOrder.setStatus(1);
+            productWorkOrderService.save(productWorkOrder);
         }
-        return items;
     }
 }

--
Gitblit v1.9.3