Prechádzať zdrojové kódy

fix: 修复双体系建设管理,返回,上传文件乱码,查看文档内容只读等问题

lixuan 2 mesiacov pred
rodič
commit
4074173682

+ 59 - 33
src/views/production-safety/productionSafetySystem/doubleSystemManagement/components/doubleSystemManagementDetail.vue

@@ -14,16 +14,30 @@
       </template>
       </template>
       <template #fileUrl>
       <template #fileUrl>
         <UploadFiles
         <UploadFiles
+          v-if="!isViewMode"
           label="上传文件"
           label="上传文件"
           :maxCount="1"
           :maxCount="1"
           :file-list="ruleFormData.fileUrlList"
           :file-list="ruleFormData.fileUrlList"
           :disabled="isViewMode"
           :disabled="isViewMode"
           :allow-all-file-types="true"
           :allow-all-file-types="true"
-          @uploadSuccess="handleUploadSuccess"
+          @uploadSuccess="(list: FileItem[]) => handleUploadSuccess(list)"
         />
         />
+        <div class="file-list" v-else>
+          <div class="file-item" v-for="file in ruleFormData.fileUrlList" :key="file.fileId">
+            <span class="file-item--name">{{ file.fileName }}</span>
+            <div class="file-item--footer">
+              <el-button link type="primary" @click="previewOnline(file.fileUrl, file.fileType)"
+                >预览</el-button
+              >
+              <!-- <el-button link type="primary" @click.stop="downloadFile(file.fileUrl, file.fileName)"
+                >下载</el-button
+              > -->
+            </div>
+          </div>
+        </div>
       </template>
       </template>
       <template #content>
       <template #content>
-        <div class="editor-container">
+        <div class="editor-container" v-if="!isViewMode">
           <Toolbar 
           <Toolbar 
             style="border-bottom: 1px solid #dcdfe6" 
             style="border-bottom: 1px solid #dcdfe6" 
             :editor="editorRef" 
             :editor="editorRef" 
@@ -37,6 +51,7 @@
             @on-change="handleEditorChange"
             @on-change="handleEditorChange"
           />
           />
         </div>
         </div>
+        <div v-html="ruleFormData.content" v-else></div>
       </template>
       </template>
       <template #status>
       <template #status>
         <el-radio-group v-model="ruleFormData.status" :disabled="isViewMode">
         <el-radio-group v-model="ruleFormData.status" :disabled="isViewMode">
@@ -45,6 +60,7 @@
         </el-radio-group>
         </el-radio-group>
       </template>
       </template>
     </BasicForm>
     </BasicForm>
+    <PreviewOnline ref="previewOnlineRef" />
   </main>
   </main>
   <footer class="safety-platform-container__footer">
   <footer class="safety-platform-container__footer">
     <el-button @click="router.back()">返回</el-button>
     <el-button @click="router.back()">返回</el-button>
@@ -72,6 +88,7 @@
   } from '@/api/production-safety-system';
   } from '@/api/production-safety-system';
   import type { FileItem } from '@/components/UploadFiles/types';
   import type { FileItem } from '@/components/UploadFiles/types';
   import { formatAttachmentList } from '@/components/UploadFiles/utils';
   import { formatAttachmentList } from '@/components/UploadFiles/utils';
+  import PreviewOnline from '@/views/disaster/components/PreviewOnline.vue';
 
 
   const router = useRouter();
   const router = useRouter();
   const route = useRoute();
   const route = useRoute();
@@ -83,6 +100,8 @@
   const isEditMode = computed(() => operate.value === 'dual-system-edit');
   const isEditMode = computed(() => operate.value === 'dual-system-edit');
   const isViewMode = computed(() => operate.value === 'dual-system-view');
   const isViewMode = computed(() => operate.value === 'dual-system-view');
 
 
+  const previewOnlineRef = ref<InstanceType<typeof PreviewOnline>>();
+
   const { ruleFormData, formRules, ruleFormConfig, cloneRuleFormData, beforeRouteLeave } =
   const { ruleFormData, formRules, ruleFormConfig, cloneRuleFormData, beforeRouteLeave } =
     useFormConfigHook(DUAL_SYSTEM_FORM_CONFIG, DUAL_SYSTEM_FORM_DATA, DUAL_SYSTEM_FORM_RULES);
     useFormConfigHook(DUAL_SYSTEM_FORM_CONFIG, DUAL_SYSTEM_FORM_DATA, DUAL_SYSTEM_FORM_RULES);
 
 
@@ -124,6 +143,7 @@
   // 文件上传
   // 文件上传
   const handleUploadSuccess = (files: FileItem[]) => {
   const handleUploadSuccess = (files: FileItem[]) => {
     ruleFormData.fileUrlList = files;
     ruleFormData.fileUrlList = files;
+    ruleFormData.fileUrl = JSON.stringify(files) || '';
   };
   };
 
 
   // 将逗号分隔的URL字符串转换为FileItem数组
   // 将逗号分隔的URL字符串转换为FileItem数组
@@ -182,9 +202,7 @@
         ruleFormData.fileUrl = res.fileUrl || '';
         ruleFormData.fileUrl = res.fileUrl || '';
         ruleFormData.content = res.content || '';
         ruleFormData.content = res.content || '';
         ruleFormData.status = res.status ?? 1;
         ruleFormData.status = res.status ?? 1;
-        
-        // 如果有文件URL,转换为FileItem格式
-        ruleFormData.fileUrlList = convertFileUrlToFileItems(res.fileUrl || '');
+        ruleFormData.fileUrlList = JSON.parse(res.fileUrl || '[]');
       }
       }
       cloneRuleFormData();
       cloneRuleFormData();
     } catch (e) {
     } catch (e) {
@@ -205,35 +223,37 @@
     
     
     try {
     try {
       // 处理文件上传:先上传文件获取 URL,然后提取 fileUrl
       // 处理文件上传:先上传文件获取 URL,然后提取 fileUrl
-      let fileUrl = '';
-      if (ruleFormData.fileUrlList && ruleFormData.fileUrlList.length > 0) {
-        // 分离已有URL的文件和新上传的文件
-        const existingFiles: string[] = [];
-        const newFiles: FileItem[] = [];
+      // let fileUrl = '';
+      // if (ruleFormData.fileUrlList && ruleFormData.fileUrlList.length > 0) {
+      //   // 分离已有URL的文件和新上传的文件
+      //   const existingFiles: string[] = [];
+      //   const newFiles: FileItem[] = [];
         
         
-        ruleFormData.fileUrlList.forEach((file: FileItem) => {
-          // 如果文件已经有 fileUrl 且没有 file 对象,说明是已有文件
-          if (file.fileUrl && !file.file) {
-            existingFiles.push(file.fileUrl);
-          } else {
-            // 否则是需要上传的新文件
-            newFiles.push(file);
-          }
-        });
+      //   ruleFormData.fileUrlList.forEach((file: FileItem) => {
+      //     // 如果文件已经有 fileUrl 且没有 file 对象,说明是已有文件
+      //     if (file.fileUrl && !file.file) {
+      //       existingFiles.push(file.fileUrl);
+      //     } else {
+      //       // 否则是需要上传的新文件
+      //       newFiles.push(file);
+      //     }
+      //   });
 
 
-        // 上传新文件
-        let uploadedUrls: string[] = [];
-        if (newFiles.length > 0) {
-          const uploadedFiles = await formatAttachmentList(newFiles);
-          uploadedUrls = uploadedFiles
-            .map((file: any) => file.fileUrl || file.url || '')
-            .filter((url: string) => url);
-        }
+      //   // 上传新文件
+      //   let uploadedUrls: string[] = [];
+      //   if (newFiles.length > 0) {
+      //     const uploadedFiles = await formatAttachmentList(newFiles);
+      //     uploadedUrls = uploadedFiles
+      //       .map((file: any) => file.fileUrl || file.url || '')
+      //       .filter((url: string) => url);
+      //   }
 
 
-        // 合并已有URL和新上传的URL,取第一个作为fileUrl
-        const allUrls = [...existingFiles, ...uploadedUrls].filter((url: string) => url);
-        fileUrl = allUrls.length > 0 ? allUrls[0] : '';
-      }
+      //   // 合并已有URL和新上传的URL,取第一个作为fileUrl
+      //   const allUrls = [...existingFiles, ...uploadedUrls].filter((url: string) => url);
+      //   fileUrl = allUrls.length > 0 ? allUrls[0] : '';
+      // }
+
+      const uploadedFileList = await formatAttachmentList(ruleFormData.fileUrlList);
 
 
       const basePayload: ProductionSafetyFile = {
       const basePayload: ProductionSafetyFile = {
         fileName: ruleFormData.fileName,
         fileName: ruleFormData.fileName,
@@ -242,7 +262,7 @@
         fileVersion: ruleFormData.fileVersion,
         fileVersion: ruleFormData.fileVersion,
         fileFormat: ruleFormData.fileFormat,
         fileFormat: ruleFormData.fileFormat,
         releaseDate: ruleFormData.releaseDate,
         releaseDate: ruleFormData.releaseDate,
-        fileUrl: fileUrl || undefined,
+        fileUrl: JSON.stringify(uploadedFileList) || undefined,
         content: ruleFormData.content || undefined,
         content: ruleFormData.content || undefined,
         status: ruleFormData.status ?? 1,
         status: ruleFormData.status ?? 1,
       };
       };
@@ -257,7 +277,7 @@
         });
         });
         ElMessage.success('保存成功');
         ElMessage.success('保存成功');
       }
       }
-
+      cloneRuleFormData();
       router.back();
       router.back();
     } catch (e) {
     } catch (e) {
       console.error('保存双体系建设失败:', e);
       console.error('保存双体系建设失败:', e);
@@ -265,6 +285,12 @@
     }
     }
   };
   };
 
 
+  const previewOnline = (url: string | undefined, type) => {
+    if (url) {
+      previewOnlineRef.value?.open(url, type);
+    }
+  };
+
   onMounted(() => {
   onMounted(() => {
     cloneRuleFormData();
     cloneRuleFormData();
     beforeRouteLeave();
     beforeRouteLeave();

+ 1 - 0
src/views/production-safety/productionSafetySystem/doubleSystemManagement/configs/form.ts

@@ -89,4 +89,5 @@ export const DUAL_SYSTEM_FORM_RULES = {
   fileVersion: [{ required: true, message: '请输入文件版本号', trigger: 'blur' }],
   fileVersion: [{ required: true, message: '请输入文件版本号', trigger: 'blur' }],
   fileFormat: [{ required: true, message: '请选择文件格式', trigger: 'change' }],
   fileFormat: [{ required: true, message: '请选择文件格式', trigger: 'change' }],
   releaseDate: [{ required: true, message: '请选择发布日期', trigger: 'change' }],
   releaseDate: [{ required: true, message: '请选择发布日期', trigger: 'change' }],
+  fileUrl: [{ required: true, message: '请上传文件', trigger: 'change' }],
 };
 };

+ 1 - 1
src/views/production-safety/productionSafetySystem/doubleSystemManagement/doubleSystemManagement.vue

@@ -231,7 +231,7 @@
   // 批量导入
   // 批量导入
   const batchImportVisible = ref(false);
   const batchImportVisible = ref(false);
   const { urlPrefix } = useGlobSetting();
   const { urlPrefix } = useGlobSetting();
-  const importApiUrl = ref(urlJoin(urlPrefix, '/productionSafety/dualSystem/import'));
+  const importApiUrl = ref(urlJoin(urlPrefix, '/admin/prod/dualSystem/importDualSystem'));
   const templateUrl = ref('./skyeye-file-upload/sfysecurity/TEMPLATE/import-dual-system-template.xlsx');
   const templateUrl = ref('./skyeye-file-upload/sfysecurity/TEMPLATE/import-dual-system-template.xlsx');
 
 
   const handleImport = () => {
   const handleImport = () => {