From ce92cb3a3645ca473798698522f477c8c2eb2e7f Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期二, 24 三月 2026 11:51:09 +0800
Subject: [PATCH] fix: 仓储物流和耗材物流可编辑删除

---
 src/pages/consumablesLogistics/receiptManagement/Record.vue |  104 ++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 101 insertions(+), 3 deletions(-)

diff --git a/src/pages/consumablesLogistics/receiptManagement/Record.vue b/src/pages/consumablesLogistics/receiptManagement/Record.vue
index 29cce52..14fad4e 100644
--- a/src/pages/consumablesLogistics/receiptManagement/Record.vue
+++ b/src/pages/consumablesLogistics/receiptManagement/Record.vue
@@ -37,7 +37,12 @@
         <el-button type="primary" @click="handleQuery" style="margin-left: 10px">鎼滅储</el-button>
       </div>
       <div>
-        <el-button type="danger" plain @click="handleDelete">鍒犻櫎</el-button>
+        <el-button
+          v-if="hasCReceiptCancel"
+          type="danger"
+          plain
+          @click="handleDelete"
+        >鍒犻櫎</el-button>
       </div>
     </div>
 
@@ -56,11 +61,21 @@
         <el-table-column label="浜у搧鍚嶇О" prop="productName" min-width="160" show-overflow-tooltip />
         <el-table-column label="瑙勬牸鍨嬪彿" prop="model" min-width="160" show-overflow-tooltip />
         <el-table-column label="鍗曚綅" prop="unit" width="100" show-overflow-tooltip />
-        <el-table-column label="鍏ュ簱鏁伴噺" prop="stockInNum" width="110" show-overflow-tooltip />
+        <el-table-column label="鍏ュ簱鏁伴噺" prop="qualitity" width="110" show-overflow-tooltip />
         <el-table-column label="鍏ュ簱浜�" prop="createBy" width="120" show-overflow-tooltip />
         <el-table-column label="鏉ユ簮" prop="recordType" width="140" show-overflow-tooltip>
           <template #default="scope">
             {{ getRecordType(scope.row.recordType) }}
+          </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>
@@ -73,20 +88,67 @@
         @pagination="paginationChange"
       />
     </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>
   </div>
 </template>
 
 <script setup>
-import { onMounted, reactive, ref, toRefs, watch } from "vue";
+import { computed, onMounted, reactive, ref, toRefs, watch } from "vue";
 import { ElMessage, ElMessageBox } from "element-plus";
 import Pagination from "@/components/PIMTable/Pagination.vue";
 import {
   batchDeleteConsumablesInRecords,
   getConsumablesInRecordListPage,
+  editStockInStock,
 } from "@/api/consumablesLogistics/consumablesInRecord.js";
 import {
   findAllQualifiedStockInRecordTypeOptions,
 } from "@/api/basicData/enum.js";
+import { checkPermi } from "@/utils/permission.js";
 
 const props = defineProps({
   type: {
@@ -95,6 +157,9 @@
     default: "0",
   },
 });
+
+const hasCReceiptEdit = computed(() => checkPermi(['c_receipt_edit']))
+const hasCReceiptCancel = computed(() => checkPermi(['c_receipt_cancel']))
 
 const tableData = ref([]);
 const selectedRows = ref([]);
@@ -158,6 +223,7 @@
 };
 
 const handleDelete = () => {
+  if (!hasCReceiptCancel.value) return
   const ids = selectedRows.value.map(i => i.id).filter(Boolean);
   if (ids.length === 0) {
     ElMessage.warning("璇烽�夋嫨鏁版嵁");
@@ -176,6 +242,38 @@
     .catch(() => {});
 };
 
+// 缂栬緫鍏ュ簱
+const isShowEditModal = ref(false);
+const editFormRef = ref(null);
+const editForm = ref({});
+
+const handleEdit = (row) => {
+  if (!hasCReceiptEdit.value) return
+  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();
+      ElMessage.success("缂栬緫鎴愬姛");
+      getList();
+    });
+  });
+};
+
 watch(
   () => props.type,
   () => {

--
Gitblit v1.9.3