From ea21bdf65a9967749ac9d7311b8e7b9e364b8a5c Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期四, 26 六月 2025 11:35:28 +0800
Subject: [PATCH] 1.库存管理编辑弹框数据修改

---
 src/views/warehouseManagement/index.vue |   67 ++++++++++++++++++++++++++-------
 1 files changed, 53 insertions(+), 14 deletions(-)

diff --git a/src/views/warehouseManagement/index.vue b/src/views/warehouseManagement/index.vue
index 0996680..8b73507 100644
--- a/src/views/warehouseManagement/index.vue
+++ b/src/views/warehouseManagement/index.vue
@@ -54,11 +54,11 @@
           <el-table-column prop="totalPriceIncludingTax" label="鎬讳环(鍚◣)" width="130" />
           <el-table-column prop="priceExcludingTax" label="鍗曚环(涓嶅惈绋�)" width="130" />
           <el-table-column prop="totalPriceExcludingTax" label="鎬讳环(涓嶅惈绋�)" width="130" />
-          <el-table-column prop="pendingReplenishment" label="寰呰ˉ搴�" width="130" />
+          <el-table-column prop="pendingReplenishment" label="寰呰ˉ搴�" width="130" v-if="activeTab=== 'officialInventory'"/>
           <el-table-column label="鐓よ川" align="center" v-if="activeTab=== 'officialInventory'" width="600">
             <el-table-column v-for="col in columnTitle" :key="col.prop" :prop="col.prop" :label="col.label" align="center" sortable min-width="200"/>
           </el-table-column>
-          <el-table-column prop="registrantId" label="鐧昏浜�" width="180"/>
+          <el-table-column prop="registrant" label="鐧昏浜�" width="180"/>
           <el-table-column prop="registrationDate" label="鐧昏鏃ユ湡" width="180"/>
           <el-table-column fixed="right" label="鎿嶄綔" min-width="60" align="center">
             <template #default="scope">
@@ -82,13 +82,17 @@
       <el-form :model="form" :rules="rules" ref="formRef" label-width="180px">
         <el-row>
           <el-col :span="12">
-            <el-form-item label="渚涜揣鍟嗗悕绉�" prop="supplierName">
-              <el-input v-model="form.supplierName" placeholder="璇疯緭鍏ヤ緵璐у晢鍚嶇О" maxlength="30" />
+            <el-form-item label="渚涘簲鍟嗗悕绉�" prop="supplierId">
+              <el-select v-model="form.supplierId" placeholder="璇烽�夋嫨渚涘簲鍟�">
+                <el-option :label="item.label" v-for="item in supplyList" :key="item.value" :value="item.value"/>
+              </el-select>
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="鐓ょ" prop="coal">
-              <el-input v-model="form.coal" placeholder="璇疯緭鍏ョ叅绉�" maxlength="30" />
+            <el-form-item label="鐓ょ" prop="coalId">
+              <el-select v-model="form.coalId" placeholder="璇烽�夋嫨鐓ょ">
+                <el-option :label="item.label" v-for="item in coalList" :key="item.value" :value="item.value"/>
+              </el-select>
             </el-form-item>
           </el-col>
         </el-row>
@@ -159,17 +163,21 @@
       </template>
     </el-dialog>
     <!-- 鍚堝苟鏁版嵁寮规 -->
-    <el-dialog title="鍚堝苟搴撳瓨" v-model="mergeVisible" width="800px">
+    <el-dialog :title="operationType.value === 'edit' ? '缂栬緫搴撳瓨' : '鍚堝苟搴撳瓨'" v-model="mergeVisible" width="800px">
       <el-form :model="mergeForm" :rules="mergeRules" ref="mergeRef" label-width="100px">
         <el-row>
           <el-col :span="12">
-            <el-form-item label="渚涜揣鍟嗗悕绉�" prop="supplierName">
-              <el-input v-model="mergeForm.supplierName" placeholder="璇疯緭鍏ヤ緵璐у晢鍚嶇О" maxlength="30" />
+            <el-form-item label="渚涘簲鍟嗗悕绉�" prop="supplierId">
+              <el-select v-model="mergeForm.supplierId" placeholder="璇烽�夋嫨渚涘簲鍟�">
+                <el-option :label="item.label" v-for="item in supplyList" :key="item.value" :value="item.value"/>
+              </el-select>
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="鐓ょ" prop="coal">
-              <el-input v-model="mergeForm.coal" placeholder="璇疯緭鍏ョ叅绉�" maxlength="30" />
+            <el-form-item label="鐓ょ" prop="coalId">
+              <el-select v-model="mergeForm.coalId" placeholder="璇烽�夋嫨鐓ょ">
+                <el-option :label="item.label" v-for="item in coalList" :key="item.value" :value="item.value"/>
+              </el-select>
             </el-form-item>
           </el-col>
         </el-row>
@@ -239,6 +247,8 @@
   pendingInventoryList
 } from "@/api/warehouseManagement/index.js";
 import {editOfficial, merge} from "../../api/warehouseManagement/index.js";
+import {getSupplyList} from "@/api/procureMent/index.js";
+import {getCoalInfoList} from "@/api/production/index.js";
 
 const { proxy } = getCurrentInstance()
 
@@ -273,8 +283,8 @@
     pId: '',
   },
   mergeForm: {
-    supplierName: '',
-    coal: '',
+    supplierId: '',
+    coalId: '',
     unit: '',
     inventoryQuantity: '',
     priceIncludingTax: '',
@@ -313,6 +323,33 @@
   coal: "",
 })
 const columnTitle = ref([])
+const supplyList = ref([]);
+const coalList = ref([]);
+
+// 鑾峰彇渚涘簲鍟嗕笅鎷夊拰鐓ょ涓嬫媺
+const getDropdownData = async () => {
+  try {
+    const [supplyRes, coalRes] = await Promise.all([
+      getSupplyList(),
+      getCoalInfoList(),
+    ]);
+    let supplyData = supplyRes.data;
+    let coalData = coalRes.data;
+    supplyList.value = supplyData.map((item) => ({
+      value: item.id,
+      label: item.supplierName,
+    }));
+    coalList.value = coalData.map((item) => ({
+      value: item.id,
+      label: item.coal,
+    }));
+  } catch (error) {
+    ElMessage.error("鑾峰彇涓嬫媺鏁版嵁澶辫触锛岃绋嶅悗閲嶈瘯");
+  }
+};
+defineExpose({
+  getDropdownData,
+});
 onMounted(() => {
   handleTabClick({ props: { name: "pendingInbound" } });
 });
@@ -386,6 +423,7 @@
   form.value = {...row}
   form.value.pId = row.id
   inventoryQuantity.value = row.inventoryQuantity
+  getDropdownData()
   coalPlanListOptions()
 }
 // 鏌ヨ鐓よ川鏂规涓嬫媺妗�
@@ -417,7 +455,8 @@
 }
 // 鍚堝苟搴撳瓨鏁版嵁鏂规硶
 const mergeRows = (type,row) => {
-  coalFieldListOption();
+  getDropdownData()
+  coalPlanListOptions()
   mergeVisible.value = true;
   operationType.value = type;
   if (type === 'edit') {

--
Gitblit v1.9.3