From d991871847391f150dd9c5aa9c871a96b75b7880 Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期一, 23 三月 2026 17:11:36 +0800
Subject: [PATCH] fix: 质量管理 可编辑

---
 src/views/consumablesLogistics/receiptManagement/Record.vue |   97 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 96 insertions(+), 1 deletions(-)

diff --git a/src/views/consumablesLogistics/receiptManagement/Record.vue b/src/views/consumablesLogistics/receiptManagement/Record.vue
index 571a22a..018dbe2 100644
--- a/src/views/consumablesLogistics/receiptManagement/Record.vue
+++ b/src/views/consumablesLogistics/receiptManagement/Record.vue
@@ -34,7 +34,8 @@
         <el-button @click="handleOut">瀵煎嚭</el-button>
         <el-button type="danger"
                    plain
-                   @click="handleDelete">鍒犻櫎
+                   @click="handleDelete"
+                   v-if="hasCReceiptCancel">鍒犻櫎
         </el-button>
       </div>
     </div>
@@ -95,6 +96,18 @@
                        @click="handlePreview(scope.row)">瀵煎嚭杩囩鍗�</el-button>
           </template>
         </el-table-column> -->
+        <el-table-column label="鎿嶄綔"
+                         width="120"
+                         align="center">
+          <template #default="scope">
+            <el-button
+              v-if="hasCReceiptEdit"
+              type="primary"
+              size="mini"
+              @click="handleEdit(scope.row)"
+            >缂栬緫</el-button>
+          </template>
+        </el-table-column>
       </el-table>
       <div style="margin-top: 12px; display: flex; justify-content: flex-end;">
         <pagination v-show="total > 0"
@@ -106,6 +119,51 @@
       </div>
     </div>
   </div>
+
+  <el-dialog
+    v-model="isShowEditModal"
+    title="缂栬緫鍏ュ簱"
+    width="600"
+    @close="closeEditModal"
+  >
+    <el-form
+      label-width="100px"
+      :model="editForm"
+      label-position="top"
+      ref="editFormRef"
+    >
+      <el-form-item
+        label="鏁伴噺"
+        prop="qualitity"
+        :rules="[{ required: true, message: '璇疯緭鍏ユ暟閲�', trigger: ['blur', 'change'] }]"
+      >
+        <el-input-number
+          v-model="editForm.qualitity"
+          :min="0"
+          :step="1"
+          :precision="0"
+          controls-position="right"
+          style="width: 100%"
+          placeholder="璇疯緭鍏ユ暟閲�"
+        />
+      </el-form-item>
+
+      <el-form-item
+        label="閲囪喘鍛�"
+        prop="purchaser"
+        :rules="[{ required: true, message: '璇疯緭鍏ラ噰璐憳', trigger: ['blur', 'change'] }]"
+      >
+        <el-input v-model="editForm.purchaser" placeholder="璇疯緭鍏ラ噰璐憳" />
+      </el-form-item>
+    </el-form>
+
+    <template #footer>
+      <div class="dialog-footer">
+        <el-button type="primary" @click="handleEditSubmit">纭</el-button>
+        <el-button @click="closeEditModal">鍙栨秷</el-button>
+      </div>
+    </template>
+  </el-dialog>
 </template>
 
 <script setup>
@@ -116,15 +174,18 @@
   toRefs,
   onMounted,
   getCurrentInstance,
+  computed,
 } from "vue";
 import {ElMessageBox} from "element-plus";
 import {
   getConsumablesInRecordListPage,
   batchDeleteConsumablesInRecords,
+  editStockInStock,
 } from "@/api/consumablesLogistics/consumablesInRecord.js";
 import {
   findAllQualifiedStockInRecordTypeOptions, findAllUnQualifiedStockInRecordTypeOptions,
 } from "@/api/basicData/enum.js";
+import { checkPermi } from "@/utils/permission.js";
 
 const {proxy} = getCurrentInstance();
 
@@ -135,6 +196,9 @@
     default: '0'
   }
 })
+
+const hasCReceiptEdit = computed(() => checkPermi(['c_receipt_edit']));
+const hasCReceiptCancel = computed(() => checkPermi(['c_receipt_cancel']));
 
 const tableData = ref([]);
 const selectedRows = ref([]);
@@ -253,6 +317,37 @@
       });
 };
 
+// 缂栬緫鑰楁潗鍏ュ簱
+const isShowEditModal = ref(false);
+const editFormRef = ref(null);
+const editForm = ref({});
+
+const handleEdit = (row) => {
+  editForm.value = {
+    id: row.id,
+    qualitity: row.qualitity,
+    purchaser: row.purchaser,
+  };
+  isShowEditModal.value = true;
+};
+
+const closeEditModal = () => {
+  isShowEditModal.value = false;
+  editForm.value = {};
+  editFormRef.value?.clearValidate?.();
+};
+
+const handleEditSubmit = () => {
+  editFormRef.value?.validate?.((valid) => {
+    if (!valid) return;
+    editStockInStock(editForm.value).then(() => {
+      closeEditModal();
+      proxy.$modal.msgSuccess("缂栬緫鎴愬姛");
+      getList();
+    });
+  });
+};
+
 onMounted(() => {
   getList();
   fetchStockRecordTypeOptions();

--
Gitblit v1.9.3