From 3b28a3183baf6c4d864405dcfd5d8e7a52a3f046 Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 05 二月 2026 17:51:37 +0800
Subject: [PATCH] 生产管控相关页面增加图纸编号

---
 src/views/productionManagement/processRoute/processRouteItem/index.vue |   41 +++++++++++++++++++++++++++++++++++++----
 1 files changed, 37 insertions(+), 4 deletions(-)

diff --git a/src/views/productionManagement/processRoute/processRouteItem/index.vue b/src/views/productionManagement/processRoute/processRouteItem/index.vue
index 18e21e8..f61afe9 100644
--- a/src/views/productionManagement/processRoute/processRouteItem/index.vue
+++ b/src/views/productionManagement/processRoute/processRouteItem/index.vue
@@ -23,6 +23,14 @@
         </div>
         <div class="info-item">
           <div class="info-label-wrapper">
+            <span class="info-label">浜у搧鍥剧焊缂栧彿</span>
+          </div>
+          <div class="info-value-wrapper">
+            <span class="info-value">{{ routeInfo.drawingNumber || '-' }}</span>
+          </div>
+        </div>
+        <div class="info-item">
+          <div class="info-label-wrapper">
             <span class="info-label">瑙勬牸鍚嶇О</span>
           </div>
           <div class="info-value-wrapper">
@@ -80,12 +88,18 @@
         </template>
       </el-table-column>
       <el-table-column label="浜у搧鍚嶇О" prop="productName" min-width="160" />
+      <el-table-column label="鍥剧焊缂栧彿" prop="drawingNumber" min-width="160" />
       <el-table-column label="瑙勬牸鍚嶇О" prop="model" min-width="140" />
       <el-table-column label="鍗曚綅" prop="unit" width="100" />
+      <el-table-column label="鏄惁璐ㄦ" prop="isQuality" width="100">
+        <template #default="scope">
+          {{scope.row.isQuality ? "鏄�" : "鍚�"}}
+        </template>
+      </el-table-column>
       <el-table-column label="鎿嶄綔" align="center" fixed="right" width="150">
         <template #default="scope">
-          <el-button type="primary" link size="small" @click="handleEdit(scope.row)">缂栬緫</el-button>
-          <el-button type="danger" link size="small" @click="handleDelete(scope.row)">鍒犻櫎</el-button>
+          <el-button type="primary" link size="small" @click="handleEdit(scope.row)" :disabled="scope.row.isComplete">缂栬緫</el-button>
+          <el-button type="danger" link size="small" @click="handleDelete(scope.row)" :disabled="scope.row.isComplete">鍒犻櫎</el-button>
         </template>
       </el-table-column>
     </el-table>
@@ -126,18 +140,20 @@
           <div class="card-content">
             <div v-if="item.productName" class="product-info">
               <div class="product-name">{{ item.productName }}</div>
+              <div class="product-model">{{ item.drawingNumber || '-' }}</div>
               <div v-if="item.model" class="product-model">
                 {{ item.model }}
                 <!-- <span v-if="item.unit" class="product-unit">{{ item.unit }}</span> -->
               </div>
+              <el-tag type="primary" class="product-tag" v-if="item.isQuality">璐ㄦ</el-tag>
             </div>
             <div v-else class="product-info empty">鏆傛棤浜у搧淇℃伅</div>
           </div>
           
           <!-- 鎿嶄綔鎸夐挳 -->
           <div class="card-footer">
-            <el-button type="primary" link size="small" @click="handleEdit(item)">缂栬緫</el-button>
-            <el-button type="danger" link size="small" @click="handleDelete(item)">鍒犻櫎</el-button>
+            <el-button type="primary" link size="small" @click="handleEdit(item)" :disabled="item.isComplete">缂栬緫</el-button>
+            <el-button type="danger" link size="small" @click="handleDelete(item)" :disabled="item.isComplete">鍒犻櫎</el-button>
           </div>
         </div>
       </div>
@@ -189,6 +205,10 @@
               :disabled="true" 
           />
         </el-form-item>
+
+        <el-form-item label="鏄惁璐ㄦ" prop="isQuality">
+          <el-switch v-model="form.isQuality" :active-value="true" inactive-value="false"/>
+        </el-form-item>
       </el-form>
 
       <template #footer>
@@ -235,6 +255,7 @@
 const routeInfo = ref({
   processRouteCode: '',
   productName: '',
+  drawingNumber: '',
   model: '',
   bomNo: '',
   description: ''
@@ -262,6 +283,7 @@
   productName: "",
   model: "",
   unit: "",
+  isQuality: false,
 });
 
 const rules = {
@@ -288,6 +310,7 @@
     .then(res => {
       tableData.value = res.data || [];
       tableLoading.value = false;
+      routeInfo.value = tableData.value[0] || {}
       // 鍒楄〃鍔犺浇瀹屾垚鍚庡垵濮嬪寲鎷栨嫿鎺掑簭
       nextTick(() => {
         initSortable();
@@ -316,6 +339,7 @@
   routeInfo.value = {
     processRouteCode: route.query.processRouteCode || '',
     productName: route.query.productName || '',
+    drawingNumber: route.query.drawingNumber || '',
     model: route.query.model || '',
     bomNo: route.query.bomNo || '',
     description: route.query.description || ''
@@ -340,6 +364,7 @@
     productName: row.productName || "",
     model: row.model || "",
     unit: row.unit || "",
+    isQuality: row.isQuality,
   };
   dialogVisible.value = true;
 };
@@ -402,12 +427,14 @@
               productRouteId: routeId.value,
               processId: form.value.processId,
               productModelId: form.value.productModelId,
+              isQuality: form.value.isQuality,
               dragSort,
             })
           : addOrUpdateProcessRouteItem({
               routeId: routeId.value,
               processId: form.value.processId,
               productModelId: form.value.productModelId,
+              isQuality: form.value.isQuality,
               dragSort,
             });
 
@@ -432,12 +459,14 @@
               id: form.value.id,
               processId: form.value.processId,
               productModelId: form.value.productModelId,
+              isQuality: form.value.isQuality,
             })
           : addOrUpdateProcessRouteItem({
               routeId: routeId.value,
               processId: form.value.processId,
               productModelId: form.value.productModelId,
               id: form.value.id,
+              isQuality: form.value.isQuality,
             });
 
         updatePromise
@@ -733,6 +762,10 @@
   color: #409eff;
 }
 
+.product-tag {
+  margin: 10px 0;
+}
+
 .card-footer {
   display: flex;
   justify-content: space-around;

--
Gitblit v1.9.3