From 08e38ede28f7cf8c971f84bff3a03102882a8a4b Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期三, 01 四月 2026 11:32:13 +0800
Subject: [PATCH] 增加料号显示

---
 src/views/qualityManagement/finalInspection/components/formDia.vue |   81 +++++++++++++++++++++++++++++++++-------
 1 files changed, 67 insertions(+), 14 deletions(-)

diff --git a/src/views/qualityManagement/finalInspection/components/formDia.vue b/src/views/qualityManagement/finalInspection/components/formDia.vue
index 5f4c975..a6a28ae 100644
--- a/src/views/qualityManagement/finalInspection/components/formDia.vue
+++ b/src/views/qualityManagement/finalInspection/components/formDia.vue
@@ -2,7 +2,7 @@
   <div>
     <el-dialog
         v-model="dialogFormVisible"
-        :title="operationType === 'add' ? '鏂板鍑哄巶妫�楠�' : '缂栬緫鍑哄巶妫�楠�'"
+        :title="operationType === 'add' ? '鏂板鎴愬搧妫�楠�' : '缂栬緫鎴愬搧妫�楠�'"
         width="70%"
         @close="closeDia"
     >
@@ -49,13 +49,6 @@
               </el-select>
             </el-form-item>
           </el-col>
-        </el-row>
-        <el-row :gutter="30">
-          <el-col :span="12">
-            <el-form-item label="鍗曚綅锛�" prop="unit">
-              <el-input v-model="form.unit" placeholder="璇疯緭鍏�" disabled/>
-            </el-form-item>
-          </el-col>
           <el-col :span="12">
             <el-form-item label="鏁伴噺锛�" prop="quantity">
               <el-input-number :step="0.01" :min="0" style="width: 100%" v-model="form.quantity" placeholder="璇疯緭鍏�" clearable :precision="2" :disabled="quantityDisabled"/>
@@ -63,6 +56,37 @@
           </el-col>
         </el-row>
         <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鏂欏彿锛�" prop="materialCode">
+              <el-input v-model="form.materialCode" placeholder="璇疯緭鍏�" disabled/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="涓嶈壇鏁伴噺锛�" prop="defectiveQuantity">
+              <el-input v-model="form.defectiveQuantity" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鍗曚綅锛�" prop="unit">
+              <el-input v-model="form.unit" placeholder="璇疯緭鍏�" disabled/>
+            </el-form-item>
+          </el-col>
+
+          <el-col :span="12">
+            <el-form-item label="鍚堟牸鏁伴噺锛�" prop="qualifiedQuantity">
+              <el-input-number :step="0.01" :min="0" style="width: 100%" v-model="form.qualifiedQuantity" placeholder="璇疯緭鍏�" clearable :precision="2" disabled/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="涓嶈壇鍘熷洜锛�" prop="defectiveReason">
+              <el-select v-model="form.defectiveReason" placeholder="璇烽�夋嫨" clearable style="width: 100%">
+                <el-option :label="item.label" :value="item.value" v-for="(item,index) in defective_reason" :key="index" />
+              </el-select>
+            </el-form-item>
+          </el-col>
+
           <el-col :span="12">
             <el-form-item label="妫�娴嬪崟浣嶏細" prop="checkCompany">
               <el-input v-model="form.checkCompany" placeholder="璇疯緭鍏�" clearable/>
@@ -76,14 +100,13 @@
               </el-select>
             </el-form-item>
           </el-col>
-        </el-row>
-        <el-row :gutter="30">
+
           <el-col :span="12">
             <el-form-item label="妫�楠屽憳锛�" prop="checkName">
-							<el-select v-model="form.checkName" placeholder="璇烽�夋嫨" clearable>
-								<el-option v-for="item in userList" :key="item.nickName" :label="item.nickName"
-													 :value="item.nickName"/>
-							</el-select>
+              <el-select v-model="form.checkName" placeholder="璇烽�夋嫨" clearable>
+                <el-option v-for="item in userList" :key="item.nickName" :label="item.nickName"
+                           :value="item.nickName"/>
+              </el-select>
             </el-form-item>
           </el-col>
           <el-col :span="12">
@@ -145,7 +168,10 @@
     productModelId: "",
     model: "",
     testStandardId: "",
+    defectiveReason: undefined,
     unit: "",
+    materialCode: "",
+    qualifiedQuantity: "",
     quantity: "",
     checkCompany: "",
     checkResult: "",
@@ -171,6 +197,7 @@
 });
 const supplierList = ref([]);
 const productOptions = ref([]);
+const { defective_reason } = proxy.useDict("defective_reason");
 const tableColumn = ref([
 	{
 		label: "鎸囨爣",
@@ -201,6 +228,29 @@
 const currentProductId = ref(0);
 const testStandardOptions = ref([]); // 鎸囨爣閫夋嫨涓嬫媺妗嗘暟鎹�
 const modelOptions = ref([]);
+
+// 鐩戝惉涓嶈壇鏁伴噺鍙樺寲锛岃嚜鍔ㄦ洿鏂版暟閲�
+// 褰� defectiveQuantity 澧炲姞鏃讹紝quantity 鍑忓皯锛涘綋 defectiveQuantity 鍑忓皯鏃讹紝quantity 澧炲姞
+watch(() => form.value.defectiveQuantity, (newVal, oldVal) => {
+  if (newVal > form.value.quantity) {
+    form.value.defectiveQuantity = form.value.quantity;
+  }
+  form.value.qualifiedQuantity = Number((form.value.quantity - newVal).toFixed(2));
+});
+
+// 鐩戝惉鎬绘暟閲忓彉鍖栵紝鑷姩鏇存柊鍚堟牸鏁伴噺
+watch(() => form.value.quantity, (newVal, oldVal) => {
+  const totalQty = Number(newVal) || 0;
+  const defectiveQty = Number(form.value.defectiveQuantity) || 0;
+
+  // 纭繚涓嶈壇鏁伴噺涓嶈秴杩囨�绘暟閲�
+  if (defectiveQty > totalQty) {
+    form.value.defectiveQuantity = totalQty;
+  }
+
+  // 璁$畻鍚堟牸鏁伴噺
+  form.value.qualifiedQuantity = Number((totalQty - defectiveQty).toFixed(2));
+});
 
 // 鎵撳紑寮规
 const openDialog = async (type, row) => {
@@ -258,6 +308,7 @@
           if (selectedModel) {
             form.value.model = selectedModel.model || '';
             form.value.unit = selectedModel.unit || '';
+            form.value.materialCode = selectedModel.materialCode || '';
           }
         }
         
@@ -297,6 +348,7 @@
 const getModels = (value) => {
   form.value.productModelId = undefined;
   form.value.unit = undefined;
+  form.value.materialCode = undefined;
   modelOptions.value = [];
   currentProductId.value = value
   form.value.productName = findNodeById(productOptions.value, value);
@@ -311,6 +363,7 @@
 const handleChangeModel = (value) => {
   form.value.model = modelOptions.value.find(item => item.id == value)?.model || '';
   form.value.unit = modelOptions.value.find(item => item.id == value)?.unit || '';
+  form.value.materialCode = modelOptions.value.find(item => item.id == value)?.materialCode || '';
 }
 
 const findNodeById = (nodes, productId) => {

--
Gitblit v1.9.3