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 |  116 +++++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 70 insertions(+), 46 deletions(-)

diff --git a/src/views/qualityManagement/processInspection/components/formDia.vue b/src/views/qualityManagement/processInspection/components/formDia.vue
index b15eabb..3dac79e 100644
--- a/src/views/qualityManagement/processInspection/components/formDia.vue
+++ b/src/views/qualityManagement/processInspection/components/formDia.vue
@@ -1,7 +1,7 @@
 <template>
   <div>
     <el-dialog v-model="dialogFormVisible"
-               :title="operationType === 'add' ? '鏂板杩囩▼妫�楠�' : '缂栬緫杩囩▼妫�楠�'"
+               :title="operationType === 'add' ? '鏂板杩囩▼妫�楠�' : operationType === 'view' ? '鏌ョ湅杩囩▼妫�楠�' : '缂栬緫杩囩▼妫�楠�'"
                width="70%"
                @close="closeDia">
       <el-form :model="form"
@@ -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="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>
@@ -35,7 +36,7 @@
                               @change="getModels"
                               :data="productOptions"
                               :render-after-expand="false"
-                              :disabled="operationType === 'edit'"
+                              :disabled="isViewMode || operationType === 'edit'"
                               style="width: 100%" />
             </el-form-item>
           </el-col>
@@ -47,7 +48,7 @@
               <el-select v-model="form.productModelId"
                          placeholder="璇烽�夋嫨"
                          clearable
-                         :disabled="operationType === 'edit'"
+                         :disabled="isViewMode || operationType === 'edit'"
                          filterable
                          readonly
                          @change="handleChangeModel">
@@ -65,7 +66,8 @@
                          placeholder="璇烽�夋嫨鎸囨爣"
                          clearable
                          @change="handleTestStandardChange"
-                         style="width: 100%">
+                         style="width: 100%"
+                         :disabled="isViewMode">
                 <el-option v-for="item in testStandardOptions"
                            :key="item.id"
                            :label="item.standardName || item.standardNo"
@@ -93,7 +95,7 @@
                                placeholder="璇疯緭鍏�"
                                clearable
                                :precision="2"
-                               :disabled="processQuantityDisabled" />
+                               :disabled="isViewMode || processQuantityDisabled" />
             </el-form-item>
           </el-col>
         </el-row>
@@ -108,7 +110,8 @@
                                placeholder="璇疯緭鍏�"
                                clearable
                                :precision="2"
-                               @change="handleQualifiedQuantityChange" />
+                               @change="handleQualifiedQuantityChange"
+                               :disabled="isViewMode" />
             </el-form-item>
           </el-col>
           <el-col :span="12">
@@ -121,7 +124,8 @@
                                placeholder="璇疯緭鍏�"
                                clearable
                                :precision="2"
-                               @change="handleUnqualifiedQuantityChange" />
+                               @change="handleUnqualifiedQuantityChange"
+                               :disabled="isViewMode" />
             </el-form-item>
           </el-col>
         </el-row>
@@ -131,13 +135,14 @@
                           prop="checkCompany">
               <el-input v-model="form.checkCompany"
                         placeholder="璇疯緭鍏�"
-                        clearable />
+                        clearable
+                        :disabled="isViewMode" />
             </el-form-item>
           </el-col>
           <el-col :span="12">
             <el-form-item label="妫�娴嬬粨鏋滐細"
                           prop="checkResult">
-              <el-select v-model="form.checkResult">
+              <el-select v-model="form.checkResult" :disabled="isViewMode">
                 <el-option label="鍚堟牸"
                            value="鍚堟牸" />
                 <el-option label="涓嶅悎鏍�"
@@ -154,7 +159,8 @@
                           prop="checkName">
               <el-select v-model="form.checkName"
                          placeholder="璇烽�夋嫨"
-                         clearable>
+                         clearable
+                         :disabled="isViewMode">
                 <el-option v-for="item in userList"
                            :key="item.nickName"
                            :label="item.nickName"
@@ -171,7 +177,8 @@
                               value-format="YYYY-MM-DD"
                               format="YYYY-MM-DD"
                               clearable
-                              style="width: 100%" />
+                              style="width: 100%"
+                              :disabled="isViewMode" />
             </el-form-item>
           </el-col>
         </el-row>
@@ -183,14 +190,18 @@
                 height="400">
         <template #slot="{ row }">
           <el-input v-model="row.testValue"
-                    clearable />
+                    clearable
+                    :disabled="isViewMode" />
         </template>
       </PIMTable>
       <template #footer>
         <div class="dialog-footer">
-          <el-button type="primary"
-                     @click="submitForm">纭</el-button>
-          <el-button @click="closeDia">鍙栨秷</el-button>
+          <template v-if="!isViewMode">
+            <el-button type="primary"
+                       @click="submitForm">纭</el-button>
+            <el-button @click="closeDia">鍙栨秷</el-button>
+          </template>
+          <el-button v-else @click="closeDia">鍏抽棴</el-button>
         </div>
       </template>
     </el-dialog>
@@ -206,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,
@@ -218,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"]);
@@ -228,7 +239,6 @@
   const data = reactive({
     form: {
       checkTime: "",
-      process: "",
       checkName: "",
       productName: "",
       productId: "",
@@ -241,32 +251,36 @@
       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([]);
   const { form, rules } = toRefs(data);
+  // 鏄惁涓烘煡鐪嬫ā寮�
+  const isViewMode = computed(() => operationType.value === 'view');
   // 缂栬緫鏃讹細productMainId 鎴� purchaseLedgerId 浠讳竴鏈夊�煎垯宸ュ簭銆佹暟閲忕疆鐏�
   const processQuantityDisabled = computed(() => {
     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: "鎸囨爣",
@@ -303,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: "",
@@ -327,12 +340,13 @@
       quantity: "",
       checkCompany: "",
       checkResult: "",
+      purchaseContractNo: "",
     };
     testStandardOptions.value = [];
     tableData.value = [];
     // 鍏堢‘淇濅骇鍝佹爲宸插姞杞斤紝鍚﹀垯缂栬緫鏃朵骇鍝�/瑙勬牸鍨嬪彿鏃犳硶鍙嶆樉
     await getProductOptions();
-    if (operationType.value === "edit") {
+    if (operationType.value === "edit" || operationType.value === "view") {
       // 鍏堜繚瀛� testStandardId锛岄伩鍏嶈娓呯┖
       const savedTestStandardId = row.testStandardId;
       // 鍏堣缃〃鍗曟暟鎹紝浣嗘殏鏃舵竻绌� testStandardId锛岀瓑閫夐」鍔犺浇瀹屾垚鍚庡啀璁剧疆
@@ -358,7 +372,6 @@
         let params = {
           productId: currentProductId.value,
           inspectType: 1,
-          process: form.value.process || "",
         };
         qualityInspectDetailByProductId(params).then(res => {
           testStandardOptions.value = res.data || [];
@@ -506,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") {
@@ -557,6 +577,10 @@
     getQualityTestStandardParamByTestStandardId(testStandardId)
       .then(res => {
         tableData.value = res.data || [];
+        tableData.value = tableData.value.map(item => ({
+          ...item,
+          id: null
+        }));
       })
       .catch(error => {
         console.error("鑾峰彇鏍囧噯鍙傛暟澶辫触:", error);

--
Gitblit v1.9.3