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/rawMaterialInspection/components/filesDia.vue |  113 ++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 73 insertions(+), 40 deletions(-)

diff --git a/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue b/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue
index cdce2c5..5bb666a 100644
--- a/src/views/qualityManagement/rawMaterialInspection/components/filesDia.vue
+++ b/src/views/qualityManagement/rawMaterialInspection/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,25 +40,20 @@
         </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 {Search} from "@element-plus/icons-vue";
-import {
-  qualityInspectParamDel,
-  qualityInspectParamInfo,
-  qualityInspectParamUpdate
-} from "@/api/qualityManagement/qualityInspectParam.js";
+import filePreview from '@/components/filePreview/index.vue'
 import {ElMessageBox} from "element-plus";
 import {getToken} from "@/utils/auth.js";
 import {
-  qualityInspectFileAdd,
-  qualityInspectFileDel,
-  qualityInspectFileListPage
-} from "@/api/qualityManagement/qualityInspectFile.js";
+  createAttachment,
+  deleteAttachment,
+  attachmentList
+} from "@/api/basicData/storageAttachment.js";
 const { proxy } = getCurrentInstance()
 const emit = defineEmits(['close'])
 
@@ -68,14 +65,6 @@
     label: "鏂囦欢鍚嶇О",
     prop: "name",
   },
-  // {
-  //   label: "涓婁紶浜�",
-  //   prop: "createUser",
-  // },
-  // {
-  //   label: "涓婁紶鏃堕棿",
-  //   prop: "createTime",
-  // },
   {
     dataType: "action",
     label: "鎿嶄綔",
@@ -87,17 +76,30 @@
         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 filePreviewRef = ref()
 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 +107,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;
   })
 }
 // 琛ㄦ牸閫夋嫨鏁版嵁
@@ -120,24 +131,42 @@
   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() {
@@ -145,13 +174,17 @@
 }
 // 涓嬭浇闄勪欢
 const downLoadFile = (row) => {
-  proxy.$download.name(row.url);
+	proxy.$download.byUrl(row.url, row.originalFilename);
+}
+// 棰勮闄勪欢
+const lookFile = (row) => {
+	filePreviewRef.value.open(row.url)
 }
 // 鍒犻櫎
 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;
@@ -161,7 +194,7 @@
     cancelButtonText: "鍙栨秷",
     type: "warning",
   }).then(() => {
-    qualityInspectFileDel(ids).then((res) => {
+    deleteAttachment(ids).then((res) => {
       proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
       getList();
     });

--
Gitblit v1.9.3