From 19f0e68b3fe3cf5244a2b936bfef4e0712bdf025 Mon Sep 17 00:00:00 2001
From: zhangwencui <1064582902@qq.com>
Date: 星期六, 20 六月 2026 11:02:12 +0800
Subject: [PATCH] tooltip错位修改

---
 src/views/qualityManagement/finalInspection/components/filesDia.vue |  111 ++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 76 insertions(+), 35 deletions(-)

diff --git a/src/views/qualityManagement/finalInspection/components/filesDia.vue b/src/views/qualityManagement/finalInspection/components/filesDia.vue
index 008479c..691e651 100644
--- a/src/views/qualityManagement/finalInspection/components/filesDia.vue
+++ b/src/views/qualityManagement/finalInspection/components/filesDia.vue
@@ -13,7 +13,7 @@
             :action="uploadUrl"
             :on-success="handleUploadSuccess"
             :on-error="handleUploadError"
-            name="file"
+            name="files"
             :show-file-list="false"
             :headers="headers"
             style="display: inline;margin-right: 10px"
@@ -26,10 +26,12 @@
           rowKey="id"
           :column="tableColumn"
           :tableData="tableData"
+          :page="page"
           :tableLoading="tableLoading"
           :isSelection="true"
           @selection-change="handleSelectionChange"
-          height="600"
+          @pagination="paginationSearch"
+          height="500"
       >
       </PIMTable>
       <template #footer>
@@ -38,12 +40,12 @@
         </div>
       </template>
     </el-dialog>
+    <filePreview ref="filePreviewRef" />
   </div>
 </template>
 
 <script setup>
-import {ref} from "vue";
-import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate} from "@/api/personnelManagement/onboarding.js";
+import {ref, reactive, getCurrentInstance} from "vue";
 import {Search} from "@element-plus/icons-vue";
 import {
   qualityInspectParamDel,
@@ -52,30 +54,25 @@
 } from "@/api/qualityManagement/qualityInspectParam.js";
 import {ElMessageBox} from "element-plus";
 import {getToken} from "@/utils/auth.js";
+import filePreview from '@/components/filePreview/index.vue'
 import {
-  qualityInspectFileAdd,
-  qualityInspectFileDel,
-  qualityInspectFileListPage
-} from "@/api/qualityManagement/qualityInspectFile.js";
+  attachmentList,
+  createAttachment,
+  deleteAttachment
+} from "@/api/basicData/storageAttachment.js";
+
 const { proxy } = getCurrentInstance()
 const emit = defineEmits(['close'])
 
 const dialogFormVisible = ref(false);
 const currentId = ref('')
 const selectedRows = ref([]);
+const filePreviewRef = ref()
 const tableColumn = ref([
   {
     label: "鏂囦欢鍚嶇О",
     prop: "name",
   },
-  // {
-  //   label: "涓婁紶浜�",
-  //   prop: "createUser",
-  // },
-  // {
-  //   label: "涓婁紶鏃堕棿",
-  //   prop: "createTime",
-  // },
   {
     dataType: "action",
     label: "鎿嶄綔",
@@ -87,17 +84,29 @@
         clickFun: (row) => {
           downLoadFile(row);
         },
+      },
+      {
+        name: "棰勮",
+        type: "text",
+        clickFun: (row) => {
+          lookFile(row);
+        },
       }
     ],
   },
 ]);
+const page = reactive({
+	current: 1,
+	size: 100,
+	total: 0,
+});
 const tableData = ref([]);
 const fileList = ref([]);
 const tableLoading = ref(false);
 const headers = ref({
   Authorization: "Bearer " + getToken(),
 });
-const uploadUrl = ref(import.meta.env.VITE_APP_BASE_API + "/file/upload"); // 涓婁紶鐨勫浘鐗囨湇鍔″櫒鍦板潃
+const uploadUrl = ref(import.meta.env.VITE_APP_BASE_API + "/common/upload"); // 涓婁紶鐨勬湇鍔″櫒鍦板潃
 
 // 鎵撳紑寮规
 const openDialog = (row) => {
@@ -105,9 +114,18 @@
   currentId.value = row.id;
   getList()
 }
+const paginationSearch = (obj) => {
+	page.current = obj.page;
+	page.size = obj.limit;
+	getList();
+};
 const getList = () => {
-  qualityInspectFileListPage({inspectId: currentId.value}).then(res => {
-    tableData.value = res.data.records;
+  attachmentList({recordId: currentId.value, recordType: 'quality_inspect'}).then(res => {
+    tableData.value = (res.data || []).map(item => ({
+      ...item,
+      name: item.originalFilename || item.name
+    }));
+    page.total = res.data ? res.data.length : 0;
   })
 }
 // 琛ㄦ牸閫夋嫨鏁版嵁
@@ -116,31 +134,49 @@
 };
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
 }
 // 鍏抽棴寮规
 const closeDia = () => {
   dialogFormVisible.value = false;
   emit('close')
 };
+let pendingFiles = [];
+let uploadTimer = null;
+
 // 涓婁紶鎴愬姛澶勭悊
 function handleUploadSuccess(res, file) {
   // 濡傛灉涓婁紶鎴愬姛
-  if (res.code == 200) {
-    const fileRow = {}
-    fileRow.name = res.data.originalName
-    fileRow.url = res.data.tempPath
-    uploadFile(fileRow)
+  if (res.code == 200 && res.data && res.data.length > 0) {
+    const newFiles = res.data.map(item => ({
+      ...item,
+      name: item.originalFilename || item.name
+    }));
+    
+    pendingFiles = [...pendingFiles, ...newFiles];
+    
+    // 闃叉姈澶勭悊锛岄伩鍏嶅鏂囦欢鍚屾椂涓婁紶瀵艰嚧鍒楄〃琚鐩�
+    if (uploadTimer) clearTimeout(uploadTimer);
+    uploadTimer = setTimeout(() => {
+      const mergedFiles = [...(tableData.value || []), ...pendingFiles];
+      const storageAttachmentDTO = {
+        recordType: 'quality_inspect',
+        recordId: currentId.value,
+        application: "file",
+        storageBlobDTOs: mergedFiles
+      };
+      createAttachment(storageAttachmentDTO).then(r => {
+        proxy.$modal.msgSuccess("鏂囦欢涓婁紶鎴愬姛");
+        getList()
+      }).catch(() => {
+        proxy.$modal.msgError("鏂囦欢涓婁紶澶辫触");
+      }).finally(() => {
+        pendingFiles = []; // 閲嶇疆
+      });
+    }, 500);
   } else {
     proxy.$modal.msgError("鏂囦欢涓婁紶澶辫触");
   }
-}
-function uploadFile(file) {
-  file.inspectId = currentId.value;
-  qualityInspectFileAdd(file).then(res => {
-    proxy.$modal.msgSuccess("鏂囦欢涓婁紶鎴愬姛");
-    getList()
-  })
 }
 // 涓婁紶澶辫触澶勭悊
 function handleUploadError() {
@@ -150,17 +186,17 @@
 const handleDelete = () => {
   let ids = [];
   if (selectedRows.value.length > 0) {
-    ids = selectedRows.value.map((item) => item.id);
+    ids = selectedRows.value.map((item) => item.storageAttachmentId);
   } else {
     proxy.$modal.msgWarning("璇烽�夋嫨鏁版嵁");
     return;
   }
-  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "瀵煎嚭", {
+  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚垹闄わ紝鏄惁纭鍒犻櫎锛�", "鎻愮ず", {
     confirmButtonText: "纭",
     cancelButtonText: "鍙栨秷",
     type: "warning",
   }).then(() => {
-    qualityInspectFileDel(ids).then((res) => {
+    deleteAttachment(ids).then((res) => {
       proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
       getList();
     });
@@ -168,6 +204,11 @@
     proxy.$modal.msg("宸插彇娑�");
   });
 };
+// 棰勮闄勪欢
+const lookFile = (row) => {
+  filePreviewRef.value.open(row.url)
+}
+
 defineExpose({
   openDialog,
 });

--
Gitblit v1.9.3