From a563ea879ef5fb6897e76d2df661e465dce2ab9b Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期一, 01 六月 2026 15:02:27 +0800
Subject: [PATCH] Merge branch 'dev_新疆_大罗素马铃薯new' of http://114.132.189.42:9002/r/product-inventory-management into dev_新疆_大罗素马铃薯new

---
 src/views/qualityManagement/processInspection/components/formDia.vue |   68 +++++++++++++++++++---------------
 1 files changed, 38 insertions(+), 30 deletions(-)

diff --git a/src/views/qualityManagement/processInspection/components/formDia.vue b/src/views/qualityManagement/processInspection/components/formDia.vue
index 635360f..3dac79e 100644
--- a/src/views/qualityManagement/processInspection/components/formDia.vue
+++ b/src/views/qualityManagement/processInspection/components/formDia.vue
@@ -11,17 +11,18 @@
                ref="formRef">
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="宸ュ簭锛�"
-                          prop="process">
-              <el-select v-model="form.process"
-                         placeholder="璇烽�夋嫨宸ュ簭"
+            <el-form-item label="閲囪喘鍚堝悓鍙凤細"
+                          prop="purchaseContractNo">
+              <el-select v-model="form.purchaseContractNo"
+                         placeholder="璇烽�夋嫨"
                          clearable
-                         :disabled="isViewMode || processQuantityDisabled"
+                         filterable
+                         :disabled="isViewMode"
                          style="width: 100%">
-                <el-option v-for="item in processList"
-                           :key="item.name"
-                           :label="item.name"
-                           :value="item.name" />
+                <el-option v-for="item in purchaseContractList"
+                           :key="item.id"
+                           :label="item.purchaseContractNumber + ' - ' + item.supplierName"
+                           :value="item.purchaseContractNumber" />
               </el-select>
             </el-form-item>
           </el-col>
@@ -216,7 +217,7 @@
     getCurrentInstance,
     nextTick,
   } from "vue";
-  import { getOptions } from "@/api/procurementManagement/procurementLedger.js";
+  import { getOptions, purchaseListPage } from "@/api/procurementManagement/procurementLedger.js";
   import { modelList, productTreeList } from "@/api/basicData/product.js";
   import {
     qualityInspectAdd,
@@ -228,7 +229,7 @@
   } from "@/api/qualityManagement/metricMaintenance.js";
   import { userListNoPage } from "@/api/system/user.js";
   import { qualityInspectParamInfo } from "@/api/qualityManagement/qualityInspectParam.js";
-  import { list } from "@/api/productionManagement/productionProcess";
+
   import qualified from "@/views/inventoryManagement/stockManagement/Qualified.vue";
   const { proxy } = getCurrentInstance();
   const emit = defineEmits(["close"]);
@@ -238,7 +239,6 @@
   const data = reactive({
     form: {
       checkTime: "",
-      process: "",
       checkName: "",
       productName: "",
       productId: "",
@@ -251,20 +251,21 @@
       unqualifiedQuantity: "",
       checkCompany: "",
       checkResult: "",
+      purchaseContractNo: "",
     },
     rules: {
-      checkTime: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-      process: [{ required: true, message: "璇烽�夋嫨宸ュ簭", trigger: "change" }],
+      checkTime: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
       checkName: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
       productId: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
       productModelId: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
       testStandardId: [{ required: false, message: "璇烽�夋嫨鎸囨爣", trigger: "change" }],
       unit: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
-      quantity: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-      qualifiedQuantity: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-      unqualifiedQuantity: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+      quantity: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
+      qualifiedQuantity: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
+      unqualifiedQuantity: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
       checkCompany: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
-      checkResult: [{ required: true, message: "璇疯緭鍏�", trigger: "change" }],
+      purchaseContractNo: [{ required: false, message: "璇烽�夋嫨", trigger: "change" }],
+      checkResult: [{ required: false, message: "璇疯緭鍏�", trigger: "change" }],
     },
   });
   const userList = ref([]);
@@ -276,9 +277,10 @@
     const v = form.value || {};
     return !!(v.productMainId != null || v.purchaseLedgerId != null);
   });
-  const processList = ref([]); // 宸ュ簭涓嬫媺鍒楄〃锛堝伐搴忓悕绉� name锛�
+
   const supplierList = ref([]);
   const productOptions = ref([]);
+  const purchaseContractList = ref([]); // 閲囪喘鍚堝悓鍙峰垪琛�
   const tableColumn = ref([
     {
       label: "鎸囨爣",
@@ -315,20 +317,19 @@
     getOptions().then(res => {
       supplierList.value = res.data;
     });
-    // 鍔犺浇宸ュ簭涓嬫媺鍒楄〃
-    try {
-      const res = await list({ size: -1, current: -1 });
-      processList.value = res.data.records || [];
-    } catch (e) {
-      console.error("鍔犺浇宸ュ簭鍒楄〃澶辫触", e);
-      processList.value = [];
-    }
     let userLists = await userListNoPage();
     userList.value = userLists.data;
-    // 鍏堥噸缃〃鍗曟暟鎹紙淇濇寔瀛楁瀹屾暣锛岄伩鍏嶅脊绐楅娆℃覆鏌撴椂瑙﹀彂蹇呭~绾㈡鈥滈棯涓�涓嬧�濓級
+    // 鍔犺浇閲囪喘鍚堝悓鍙峰垪琛�
+    try {
+      const contractRes = await purchaseListPage({ pageNum: -1, pageSize: -1 });
+      purchaseContractList.value = contractRes.data?.records || [];
+    } catch (e) {
+      console.error("鍔犺浇閲囪喘鍚堝悓鍙峰け璐�", e);
+      purchaseContractList.value = [];
+    }
+    // 鍏堥噸缃〃鍗曟暟鎹紙淇濇寔瀛楁瀹屾暣锛岄伩鍏嶅脊绐楅娆℃覆鏌撴椂瑙﹀彂蹇呭~绾㈡"闂竴涓�"锛�
     form.value = {
       checkTime: "",
-      process: "",
       checkName: "",
       productName: "",
       productId: "",
@@ -339,6 +340,7 @@
       quantity: "",
       checkCompany: "",
       checkResult: "",
+      purchaseContractNo: "",
     };
     testStandardOptions.value = [];
     tableData.value = [];
@@ -370,7 +372,6 @@
         let params = {
           productId: currentProductId.value,
           inspectType: 1,
-          process: form.value.process || "",
         };
         qualityInspectDetailByProductId(params).then(res => {
           testStandardOptions.value = res.data || [];
@@ -518,9 +519,16 @@
           return;
         }
 
+        // 鏍规嵁閲囪喘鍚堝悓鍙锋煡鎵惧搴旂殑 purchaseLedgerId
+        const selectedContract = purchaseContractList.value.find(
+          item => item.purchaseContractNumber === form.value.purchaseContractNo
+        );
+        const purchaseLedgerId = selectedContract ? selectedContract.id : null;
+
         const data = {
           ...form.value,
           process: processName, // 淇濈暀 process 瀛楁浠ュ吋瀹瑰悗绔�
+          purchaseLedgerId: purchaseLedgerId, // 鎻愪氦 purchaseLedgerId
           qualityInspectParams: tableData.value,
         };
         if (operationType.value === "add") {

--
Gitblit v1.9.3