From 5cabba0016c61d51204c7e28bf0613b1cd335327 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期三, 25 三月 2026 15:05:34 +0800
Subject: [PATCH] 工序不合格处理为隔离后,后续工序不继续报工

---
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |   37 ++++++++++++++++++++++++++-----------
 1 files changed, 26 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
index 7a0a9c6..7cf30f3 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -3,6 +3,7 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -100,24 +101,38 @@
         if (productProcessRouteItem == null) {
             throw new RuntimeException("宸ヨ壓璺嚎椤逛笉瀛樺湪");
         }
+        // 鏄惁鑳芥姤宸ワ細 1. 绗竴涓伐搴忚兘鎶ュ伐 2. 涓婁竴涓伐搴忓凡鎶ュ伐 3. 涔嬪墠鐨勫伐搴忔湭琚殧绂�
         //妫�鏌ヤ笂涓�涓伐搴忔槸鍚﹀凡鎶ュ伐
         Integer currentDragSort = productProcessRouteItem.getDragSort();
         if (currentDragSort != null && currentDragSort > 1) {
-            ProductProcessRouteItem previousItem = productProcessRouteItemMapper.selectOne(
+            boolean isPreviousReported = productionProductMainMapper.checkPreviousProcessReported(
+                    productProcessRouteItem.getProductRouteId(),
+                    currentDragSort
+            );
+            if (isPreviousReported) {
+                throw new RuntimeException("涓婁竴涓伐搴忓皻鏈姤宸ワ紝涓嶈兘杩涜褰撳墠宸ュ簭鎶ュ伐");
+            }
+
+            // 鏌ヨ鎵�鏈変箣鍓嶇殑宸ュ簭锛堟帓搴忓彿灏忎簬褰撳墠宸ュ簭锛�
+            List<ProductProcessRouteItem> previousItems = productProcessRouteItemMapper.selectList(
                     Wrappers.<ProductProcessRouteItem>lambdaQuery()
                             .eq(ProductProcessRouteItem::getProductRouteId, productProcessRouteItem.getProductRouteId())
-                            .eq(ProductProcessRouteItem::getDragSort, currentDragSort - 1)
+                            .lt(ProductProcessRouteItem::getDragSort, currentDragSort)
             );
+            if (CollectionUtils.isNotEmpty(previousItems)) {
+                // 鎻愬彇涔嬪墠宸ュ簭鐨勫悕绉板垪琛�
+                List<String> previousProcessNames = new ArrayList<>();
+                for (ProductProcessRouteItem item : previousItems) {
+                    ProductProcess process = productProcessMapper.selectById(item.getProcessId());
+                    if (process != null) {
+                        previousProcessNames.add(process.getName());
+                    }
+                }
 
-            if (previousItem != null) {
-                //妫�鏌ヤ笂涓�涓伐搴忔槸鍚︽湁鎶ュ伐璁板綍
-                Long count = productionProductMainMapper.selectCount(
-                        Wrappers.<ProductionProductMain>lambdaQuery()
-                                .eq(ProductionProductMain::getProductProcessRouteItemId, previousItem.getId())
-                );
-
-                if (count == 0) {
-                    throw new RuntimeException("涓婁竴涓伐搴忓皻鏈姤宸ワ紝涓嶈兘杩涜褰撳墠宸ュ簭鎶ュ伐");
+                // 妫�鏌ヤ箣鍓嶇殑宸ュ簭鏄惁鏈夎闅旂鐨勪笉鍚堟牸璁板綍
+                List<QualityUnqualified> unqualifiedList = qualityUnqualifiedMapper.selectUnqualifiedByProcessNames(previousProcessNames);
+                if (CollectionUtils.isNotEmpty(unqualifiedList)) {
+                    throw new RuntimeException("涔嬪墠鐨勫伐搴忓凡琚殧绂伙紝涓嶈兘杩涜褰撳墠宸ュ簭鎶ュ伐");
                 }
             }
         }

--
Gitblit v1.9.3