From 06bea42e538d820b1837c14ba87691a63bf51936 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期四, 19 三月 2026 17:42:22 +0800
Subject: [PATCH] 军泰伟业 1.修改生产模块的图纸编号和规格型号字段

---
 src/views/productionManagement/productStructure/Detail/index.vue |   72 +++++++++++++++++++++--------------
 1 files changed, 43 insertions(+), 29 deletions(-)

diff --git a/src/views/productionManagement/productStructure/Detail/index.vue b/src/views/productionManagement/productStructure/Detail/index.vue
index 3a76e48..8f05214 100644
--- a/src/views/productionManagement/productStructure/Detail/index.vue
+++ b/src/views/productionManagement/productStructure/Detail/index.vue
@@ -34,25 +34,27 @@
                       style="width: 100%">
               <el-table-column prop="productName"
                                label="浜у搧" />
-              <el-table-column prop="model"
-                               label="瑙勬牸">
-                <template #default="{ row, $index }">
-                  <el-form-item v-if="dataValue.isEdit"
-                                :rules="[{ required: true, message: '璇烽�夋嫨瑙勬牸', trigger: ['blur','change'] }]"
-                                style="margin: 0">
-                    <el-select v-model="row.model"
-                               placeholder="璇烽�夋嫨瑙勬牸"
-                               clearable
-                               :disabled="!dataValue.isEdit || dataValue.dataList.some(item => (item as any).tempId === row.tempId)"
-                               style="width: 100%"
-                               @visible-change="(v) => { if (v) openDialog(row.tempId) }">
-                      <el-option v-if="row.model"
-                                 :label="row.model"
-                                 :value="row.model" />
-                    </el-select>
-                  </el-form-item>
-                </template>
-              </el-table-column>
+							<el-table-column prop="model"
+															 label="鍥剧焊缂栧彿">
+								<template #default="{ row, $index }">
+									<el-form-item v-if="dataValue.isEdit"
+																:rules="[{ required: true, message: '璇烽�夋嫨瑙勬牸', trigger: ['blur','change'] }]"
+																style="margin: 0">
+										<el-select v-model="row.model"
+															 placeholder="璇烽�夋嫨瑙勬牸"
+															 clearable
+															 :disabled="!dataValue.isEdit || dataValue.dataList.some(item => (item as any).tempId === row.tempId)"
+															 style="width: 100%"
+															 @visible-change="(v) => { if (v) openDialog(row.tempId) }">
+											<el-option v-if="row.model"
+																 :label="row.model"
+																 :value="row.model" />
+										</el-select>
+									</el-form-item>
+								</template>
+							</el-table-column>
+              <el-table-column prop="drawingNumber"
+                               label="瑙勬牸鍨嬪彿" />
               <el-table-column prop="processName"
                                label="娑堣�楀伐搴�">
                 <template #default="{ row, $index }">
@@ -115,7 +117,7 @@
                     <el-input v-model="row.unit"
                               placeholder="璇疯緭鍏ュ崟浣�"
                               clearable
-                               :disabled="!dataValue.isEdit || dataValue.dataList.some(item => (item as any).tempId === row.tempId)" />
+                              :disabled="!dataValue.isEdit || dataValue.dataList.some(item => (item as any).tempId === row.tempId)" />
                   </el-form-item>
                 </template>
               </el-table-column>
@@ -143,8 +145,10 @@
                        prop="bomNo" />
       <el-table-column label="浜у搧鍚嶇О"
                        prop="productName" />
+			<el-table-column label="鍥剧焊缂栧彿"
+											 prop="model" />
       <el-table-column label="瑙勬牸鍨嬪彿"
-                       prop="model" />
+                       prop="drawingNumber" />
     </el-table>
     <product-select-dialog v-if="dataValue.showProductDialog"
                            v-model:model-value="dataValue.showProductDialog"
@@ -192,6 +196,7 @@
   // 浠庤矾鐢卞弬鏁拌幏鍙栦骇鍝佷俊鎭�
   const routeBomNo = computed(() => route.query.bomNo || "");
   const routeProductName = computed(() => route.query.productName || "");
+  const routeDrawingNumber = computed(() => route.query.drawingNumber || "");
   const routeProductModelName = computed(
     () => route.query.productModelName || ""
   );
@@ -215,6 +220,7 @@
   const tableData = reactive([
     {
       productName: "",
+      drawingNumber: "",
       model: "",
       bomNo: "",
     },
@@ -264,15 +270,20 @@
     const productData = row[0];
 
     //  鏈�澶栧眰缁勪欢涓紝涓庡綋鍓嶄骇鍝佺浉鍚岀殑浜у搧鍙兘鏈変竴涓�
-    const isTopLevel = dataValue.dataList.some(item => (item as any).tempId === dataValue.currentRowName);
+    const isTopLevel = dataValue.dataList.some(
+      item => (item as any).tempId === dataValue.currentRowName
+    );
     if (isTopLevel) {
-      if (productData.productName === tableData[0].productName &&
-        productData.model === tableData[0].model) {
+      if (
+        productData.productName === tableData[0].productName &&
+        productData.model === tableData[0].model
+      ) {
         //  鏌ユ壘鏄惁宸茬粡鏈夊叾浠栭《灞傝宸茬粡鏄繖涓骇鍝�
-        const hasOther = dataValue.dataList.some(item =>
-          (item as any).tempId !== dataValue.currentRowName &&
-          (item as any).productName === tableData[0].productName &&
-          (item as any).model === tableData[0].model
+        const hasOther = dataValue.dataList.some(
+          item =>
+            (item as any).tempId !== dataValue.currentRowName &&
+            (item as any).productName === tableData[0].productName &&
+            (item as any).model === tableData[0].model
         );
         if (hasOther) {
           ElMessage.warning("鏈�澶栧眰鍜屽綋鍓嶄骇鍝佷竴鏍风殑涓�绾у彧鑳芥湁涓�涓�");
@@ -288,6 +299,7 @@
     dataValue.dataList.map(item => {
       if (item.tempId === dataValue.currentRowName) {
         item.productName = productData.productName;
+        item.drawingNumber = productData.drawingNumber || "";
         item.model = productData.model;
         item.productModelId = productData.id;
         item.unit = productData.unit || "";
@@ -300,6 +312,7 @@
   const childItem = (item: any, tempId: any, productData: any) => {
     if (item.tempId === tempId) {
       item.productName = productData.productName;
+      item.drawingNumber = productData.drawingNumber || "";
       item.model = productData.model;
       item.productModelId = productData.id;
       item.unit = productData.unit || "";
@@ -390,7 +403,7 @@
     }
   };
 
-  const removeItem = (tempId:string) => {
+  const removeItem = (tempId: string) => {
     // 鍏堝皾璇曚粠椤跺眰鍒犻櫎
     const topIndex = dataValue.dataList.findIndex(item => item.tempId === tempId);
     if (topIndex !== -1) {
@@ -501,6 +514,7 @@
   onMounted(async () => {
     // 浠庤矾鐢卞弬鏁板洖鏄炬暟鎹�
     tableData[0].productName = routeProductName.value as string;
+    tableData[0].drawingNumber = routeDrawingNumber.value as string;
     tableData[0].model = routeProductModelName.value as string;
     tableData[0].bomNo = routeBomNo.value as string;
 

--
Gitblit v1.9.3