file-viewer3 1.0.8 → 1.0.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +160 -0
- package/README.en.md +390 -0
- package/README.md +306 -89
- package/dist/components/3MFLoader.js +527 -0
- package/dist/components/AMFLoader.js +188 -0
- package/dist/components/ArchiveViewer.js +526 -0
- package/dist/components/AudioViewer.js +66 -0
- package/dist/components/CadViewer.js +9040 -0
- package/dist/components/CodeViewer.js +151 -0
- package/dist/components/ColladaLoader.js +2282 -0
- package/dist/components/DrawingViewer.js +295 -0
- package/dist/components/EdaViewer.js +630 -0
- package/dist/components/EmailViewer.js +276 -0
- package/dist/components/EpubViewer.js +172 -0
- package/dist/components/FBXLoader.js +1574 -0
- package/dist/components/GLTFLoader.js +1383 -0
- package/dist/components/ImageViewer.js +1516 -1895
- package/dist/components/KMZLoader.js +45 -0
- package/dist/components/MarkdownViewer.js +1456 -1557
- package/dist/components/ModelViewer.js +797 -0
- package/dist/components/OBJLoader.js +287 -0
- package/dist/components/OfdViewer.js +133 -0
- package/dist/components/PCDLoader.js +141 -0
- package/dist/components/PLYLoader.js +305 -0
- package/dist/components/PdfView.js +27662 -21655
- package/dist/components/PptxRender.js +11170 -21118
- package/dist/components/STLLoader.js +83 -0
- package/dist/components/TDSLoader.js +228 -0
- package/dist/components/TypstViewer.js +1697 -0
- package/dist/components/USDLoader.js +2526 -0
- package/dist/components/UmdViewer.js +1873 -0
- package/dist/components/VRMLLoader.js +6422 -0
- package/dist/components/VTKLoader.js +337 -0
- package/dist/components/XYZLoader.js +30 -0
- package/dist/components/XlsxTable.js +7871 -69873
- package/dist/components/__vite-browser-external.js +7 -0
- package/dist/components/_plugin-vue_export-helper.js +8 -0
- package/dist/components/ar-SA-G6X2FPQ2.js +523 -0
- package/dist/components/arc.js +79 -0
- package/dist/components/architecture-7EHR7CIX.js +3 -0
- package/dist/components/architectureDiagram-3BPJPVTR.js +4096 -0
- package/dist/components/archive.js +24 -0
- package/dist/components/asyncToGenerator.js +29 -0
- package/dist/components/audio.js +19 -0
- package/dist/components/az-AZ-76LH7QW2.js +523 -0
- package/dist/components/bash.js +169 -0
- package/dist/components/bg-BG-XCXSNQG7.js +523 -0
- package/dist/components/blockDiagram-GPEHLZMM.js +3357 -0
- package/dist/components/bn-BD-2XOGV67Q.js +523 -0
- package/dist/components/c4Diagram-AAUBKEIU.js +2957 -0
- package/dist/components/ca-ES-6MX7JW3Y.js +523 -0
- package/dist/components/cad.js +23 -0
- package/dist/components/cfb.js +1174 -0
- package/dist/components/channel.js +5 -0
- package/dist/components/chunk-2J33WTMH.js +26 -0
- package/dist/components/chunk-3OPIFGDE.js +4167 -0
- package/dist/components/chunk-4BX2VUAB.js +19 -0
- package/dist/components/chunk-55IACEB6.js +9 -0
- package/dist/components/chunk-5ZQYHXKU.js +669 -0
- package/dist/components/chunk-6U3AYISY.js +624 -0
- package/dist/components/chunk-727SXJPM.js +3356 -0
- package/dist/components/chunk-AGHRB4JF.js +324 -0
- package/dist/components/chunk-AQP2D5EJ.js +2055 -0
- package/dist/components/chunk-BSJP7CBP.js +83 -0
- package/dist/components/chunk-CSCIHK7Q.js +3500 -0
- package/dist/components/chunk-EIO257PC.js +1836 -0
- package/dist/components/chunk-FMBD7UC4.js +5 -0
- package/dist/components/chunk-K2UTITRG.js +17627 -0
- package/dist/components/chunk-KSCS5N6A.js +572 -0
- package/dist/components/chunk-L5ZTLDWV.js +40 -0
- package/dist/components/chunk-LZXEDZCA.js +60 -0
- package/dist/components/chunk-ND2GUHAM.js +61 -0
- package/dist/components/chunk-NNHCCRGN.js +20425 -0
- package/dist/components/chunk-NZK2D7GU.js +68 -0
- package/dist/components/chunk-O5CBEL6O.js +1894 -0
- package/dist/components/chunk-QZHKN3VN.js +12 -0
- package/dist/components/chunk-SRAX5OIU.js +22 -0
- package/dist/components/chunk-WU5MYG2G.js +14 -0
- package/dist/components/chunk-XPW4576I.js +1146 -0
- package/dist/components/chunk-Z3N5DIM6.js +59 -0
- package/dist/components/chunk-ZUYEQ4TG.js +22 -0
- package/dist/components/chunk.js +23 -0
- package/dist/components/classDiagram-4FO5ZUOK.js +29 -0
- package/dist/components/classDiagram-v2-Q7XG4LA2.js +29 -0
- package/dist/components/compiler.js +2 -0
- package/dist/components/core.js +845 -0
- package/dist/components/cose-bilkent-S5V4N54A.js +2268 -0
- package/dist/components/cpp.js +225 -0
- package/dist/components/cs-CZ-2BRQDIVT.js +523 -0
- package/dist/components/csharp.js +260 -0
- package/dist/components/css.js +140 -0
- package/dist/components/cytoscape.esm.js +18114 -0
- package/dist/components/da-DK-5WZEPLOC.js +523 -0
- package/dist/components/dagre-BM42HDAG.js +325 -0
- package/dist/components/dagre.js +1936 -0
- package/dist/components/de-DE-XR44H4JA.js +523 -0
- package/dist/components/defaultLocale.js +201 -0
- package/dist/components/defineProperty.js +50 -0
- package/dist/components/diagram-2AECGRRQ.js +229 -0
- package/dist/components/diagram-5GNKFQAL.js +108 -0
- package/dist/components/diagram-KO2AKTUF.js +443 -0
- package/dist/components/diagram-LMA3HP47.js +139 -0
- package/dist/components/diagram-OG6HWLK6.js +541 -0
- package/dist/components/diff.js +39 -0
- package/dist/components/directory-open-01563666.js +26 -0
- package/dist/components/directory-open-4ed118d0.js +83 -0
- package/dist/components/dist.js +50 -0
- package/dist/components/dist2.js +3291 -0
- package/dist/components/dist3.js +1593 -0
- package/dist/components/documentSearch.js +378 -0
- package/dist/components/docx-preview.js +3113 -0
- package/dist/components/drawing.js +19 -0
- package/dist/components/ebook.js +16 -0
- package/dist/components/eda.js +20 -0
- package/dist/components/el-GR-BZB4AONW.js +523 -0
- package/dist/components/email.js +21 -0
- package/dist/components/en-B4ZKOASM.js +3 -0
- package/dist/components/erDiagram-TEJ5UH35.js +1719 -0
- package/dist/components/es-ES-U4NZUMDT.js +523 -0
- package/dist/components/eu-ES-A7QVB2H4.js +523 -0
- package/dist/components/eventmodeling-FCH6USID.js +3 -0
- package/dist/components/fa-IR-HGAKTJCU.js +523 -0
- package/dist/components/fflate.module.js +323 -0
- package/dist/components/fi-FI-Z5N7JZ37.js +523 -0
- package/dist/components/file-open-002ab408.js +38 -0
- package/dist/components/file-open-7c801643.js +24 -0
- package/dist/components/file-save-3189631c.js +40 -0
- package/dist/components/file-save-745eba88.js +36 -0
- package/dist/components/flowDiagram-I6XJVG4X.js +4181 -0
- package/dist/components/fr-FR-RHASNOE6.js +523 -0
- package/dist/components/ganttDiagram-6RSMTGT7.js +2182 -0
- package/dist/components/gitGraph-WXDBUCRP.js +3 -0
- package/dist/components/gitGraphDiagram-PVQCEYII.js +788 -0
- package/dist/components/gl-ES-HMX3MZ6V.js +523 -0
- package/dist/components/global-compiler.js +23 -0
- package/dist/components/global-renderer.js +23 -0
- package/dist/components/go.js +140 -0
- package/dist/components/graphlib.js +1267 -0
- package/dist/components/he-IL-6SHJWFNN.js +523 -0
- package/dist/components/hi-IN-IWLTKZ5I.js +523 -0
- package/dist/components/hu-HU-A5ZG7DT2.js +523 -0
- package/dist/components/id-ID-SAP4L64H.js +523 -0
- package/dist/components/image-GAAHSSAO.js +3 -0
- package/dist/components/image-blob-reduce.esm.js +1429 -0
- package/dist/components/image.js +17 -0
- package/dist/components/info-J43DQDTF.js +3 -0
- package/dist/components/infoDiagram-5YYISTIA.js +26 -0
- package/dist/components/ini.js +88 -0
- package/dist/components/init.js +15 -0
- package/dist/components/ishikawaDiagram-YF4QCWOH.js +718 -0
- package/dist/components/it-IT-JPQ66NNP.js +523 -0
- package/dist/components/ja-JP-DBVTYXUO.js +523 -0
- package/dist/components/java.js +169 -0
- package/dist/components/javascript.js +436 -0
- package/dist/components/journeyDiagram-JHISSGLW.js +885 -0
- package/dist/components/json.js +36 -0
- package/dist/components/jszip.min.js +3033 -0
- package/dist/components/kaa-6HZHGXH3.js +523 -0
- package/dist/components/kab-KAB-ZGHBKWFO.js +523 -0
- package/dist/components/kanban-definition-UN3LZRKU.js +986 -0
- package/dist/components/katex.js +21979 -0
- package/dist/components/kk-KZ-P5N5QNE5.js +523 -0
- package/dist/components/km-KH-HSX4SM5Z.js +523 -0
- package/dist/components/ko-KR-MTYHY66A.js +523 -0
- package/dist/components/ku-TR-6OUDTVRD.js +523 -0
- package/dist/components/lib.js +4877 -0
- package/dist/components/libarchive.js +360 -0
- package/dist/components/linear.js +289 -0
- package/dist/components/lt-LT-XHIRWOB4.js +523 -0
- package/dist/components/lv-LV-5QDEKY6T.js +523 -0
- package/dist/components/markdown.js +181 -0
- package/dist/components/md.js +17 -0
- package/dist/components/mermaid-parser.core.js +328 -0
- package/dist/components/mindmap-definition-RKZ34NQL.js +1016 -0
- package/dist/components/model.js +21 -0
- package/dist/components/mp4.js +12 -0
- package/dist/components/mr-IN-CRQNXWMA.js +523 -0
- package/dist/components/my-MM-5M5IBNSE.js +523 -0
- package/dist/components/nb-NO-T6EIAALU.js +523 -0
- package/dist/components/nestedRender.js +158 -0
- package/dist/components/nl-NL-IS3SIHDZ.js +523 -0
- package/dist/components/nn-NO-6E72VCQL.js +523 -0
- package/dist/components/objectSpread2.js +29 -0
- package/dist/components/objectWithoutProperties.js +28 -0
- package/dist/components/oc-FR-POXYY2M6.js +523 -0
- package/dist/components/ofd.js +5261 -0
- package/dist/components/ofd2.js +16 -0
- package/dist/components/ordinal.js +65 -0
- package/dist/components/pa-IN-N4M65BXN.js +523 -0
- package/dist/components/packet-YPE3B663.js +3 -0
- package/dist/components/pdf.js +24 -0
- package/dist/components/percentages-BXMCSKIN.js +3 -0
- package/dist/components/php.js +294 -0
- package/dist/components/pica.js +1009 -0
- package/dist/components/pie-LRSECV5Y.js +3 -0
- package/dist/components/pie.js +47 -0
- package/dist/components/pieDiagram-4H26LBE5.js +130 -0
- package/dist/components/pl-PL-T2D74RX3.js +523 -0
- package/dist/components/postal-mime.js +3146 -0
- package/dist/components/pptx.js +15 -0
- package/dist/components/printLayout.js +42 -0
- package/dist/components/prod.js +21770 -0
- package/dist/components/pt-BR-5N22H2LF.js +523 -0
- package/dist/components/pt-PT-UZXXM6DQ.js +523 -0
- package/dist/components/python.js +238 -0
- package/dist/components/quadrantDiagram-W4KKPZXB.js +1988 -0
- package/dist/components/radar-GUYGQ44K.js +3 -0
- package/dist/components/renderer.js +2 -0
- package/dist/components/requirementDiagram-4Y6WPE33.js +2230 -0
- package/dist/components/ro-RO-JPDTUUEW.js +523 -0
- package/dist/components/rough.esm.js +1355 -0
- package/dist/components/roundRect.js +90 -0
- package/dist/components/ru-RU-B4JR7IUQ.js +523 -0
- package/dist/components/rust.js +169 -0
- package/dist/components/sankeyDiagram-5OEKKPKP.js +972 -0
- package/dist/components/sequenceDiagram-3UESZ5HK.js +4255 -0
- package/dist/components/shared.js +175 -0
- package/dist/components/shared2.js +4 -0
- package/dist/components/si-LK-N5RQ5JYF.js +523 -0
- package/dist/components/sk-SK-C5VTKIMK.js +523 -0
- package/dist/components/sl-SI-NN7IZMDC.js +523 -0
- package/dist/components/sourceLoading.js +134 -0
- package/dist/components/sql.js +118 -0
- package/dist/components/src.js +2664 -0
- package/dist/components/src2.js +10722 -0
- package/dist/components/stateDiagram-AJRCARHV.js +217 -0
- package/dist/components/stateDiagram-v2-BHNVJYJU.js +27 -0
- package/dist/components/subset-shared.chunk.js +3 -0
- package/dist/components/subset-worker.chunk.js +21 -0
- package/dist/components/sv-SE-XGPEYMSR.js +523 -0
- package/dist/components/ta-IN-2NMHFXQM.js +523 -0
- package/dist/components/text.js +20 -0
- package/dist/components/th-TH-HPSO5L25.js +523 -0
- package/dist/components/three.module.js +13134 -0
- package/dist/components/time.js +910 -0
- package/dist/components/timeline-definition-PNZ67QCA.js +1084 -0
- package/dist/components/tr-TR-DEFEU3FU.js +523 -0
- package/dist/components/treeView-BLDUP644.js +3 -0
- package/dist/components/treemap-LRROVOQU.js +3 -0
- package/dist/components/typescript.js +521 -0
- package/dist/components/typst.js +25 -0
- package/dist/components/uk-UA-QMV73CPH.js +523 -0
- package/dist/components/umd.js +16 -0
- package/dist/components/use.js +422 -0
- package/dist/components/util.js +49 -0
- package/dist/components/vennDiagram-CIIHVFJN.js +1880 -0
- package/dist/components/vi-VN-M7AON7JQ.js +523 -0
- package/dist/components/viewerZoom.js +92 -0
- package/dist/components/wardley-L42UT6IY.js +3 -0
- package/dist/components/wardleyDiagram-YWT4CUSO.js +656 -0
- package/dist/components/wasm-pack-shim.js +1711 -0
- package/dist/components/wasm-pack-shim2.js +934 -0
- package/dist/components/wasm.js +97 -0
- package/dist/components/word.js +3055 -0
- package/dist/components/worker-ref.js +15 -20
- package/dist/components/xlsx.js +21 -0
- package/dist/components/xml.js +166 -0
- package/dist/components/xychartDiagram-2RQKCTM6.js +2015 -0
- package/dist/components/yaml.js +144 -0
- package/dist/components/zh-CN-LNUGB5OW.js +523 -0
- package/dist/components/zh-HK-E62DVLB3.js +523 -0
- package/dist/components/zh-TW-RAJ6MFWO.js +523 -0
- package/dist/file-viewer3.css +2 -0
- package/dist/index.mjs +3292 -5
- package/dist/src/App.vue.d.ts +3 -0
- package/dist/src/compare/CompareApp.vue.d.ts +3 -0
- package/dist/src/compare/main.d.ts +0 -0
- package/dist/src/compare/useSynchronizedScroll.d.ts +7 -0
- package/dist/src/components/HelloWorld.vue.d.ts +3 -0
- package/dist/src/components/utils.d.ts +4 -0
- package/dist/src/main.d.ts +0 -0
- package/dist/src/package/common/printCapability.d.ts +27 -0
- package/dist/src/package/common/printLayout.d.ts +16 -0
- package/dist/src/package/common/sourceLoading.d.ts +10 -0
- package/dist/src/package/common/type.d.ts +522 -8
- package/dist/src/package/common/worker-ref.d.ts +1 -1
- package/dist/src/package/components/FileViewer/FileViewer.vue.d.ts +74 -24
- package/dist/src/package/components/FileViewer/exportDocumentTemplate.d.ts +9 -0
- package/dist/src/package/components/FileViewer/hooks/useViewerDocumentFeatures.d.ts +29 -0
- package/dist/src/package/components/FileViewer/hooks/useViewerExport.d.ts +21 -0
- package/dist/src/package/components/FileViewer/hooks/useViewerWatermark.d.ts +8 -0
- package/dist/src/package/components/FileViewer/hooks/useViewerZoom.d.ts +34 -0
- package/dist/src/package/components/FileViewer/index.d.ts +1 -1
- package/dist/src/package/components/FileViewer/util.d.ts +2 -1
- package/dist/src/package/index.d.ts +14 -4
- package/dist/src/package/use/documentLocation.d.ts +15 -0
- package/dist/src/package/use/documentSearch.d.ts +234 -0
- package/dist/src/package/use/index.d.ts +4 -0
- package/dist/src/package/use/loading.d.ts +33 -0
- package/dist/src/package/use/viewerZoom.d.ts +42 -0
- package/dist/src/package/use/worker.d.ts +2 -2
- package/dist/src/package/vendors/archive/ArchiveViewer.vue.d.ts +9 -0
- package/dist/src/package/vendors/archive/cache.d.ts +10 -0
- package/dist/src/package/vendors/archive/fallback.d.ts +9 -0
- package/dist/src/package/vendors/archive/index.d.ts +3 -0
- package/dist/src/package/vendors/archive/shared.d.ts +24 -0
- package/dist/src/package/vendors/audio/AudioViewer.vue.d.ts +7 -0
- package/dist/src/package/vendors/audio/index.d.ts +7 -0
- package/dist/src/package/vendors/cad/CadViewer.vue.d.ts +9 -0
- package/dist/src/package/vendors/cad/index.d.ts +8 -0
- package/dist/src/package/vendors/drawing/DrawingViewer.vue.d.ts +15 -0
- package/dist/src/package/vendors/drawing/index.d.ts +7 -0
- package/dist/src/package/vendors/ebook/EpubViewer.vue.d.ts +6 -0
- package/dist/src/package/vendors/ebook/index.d.ts +7 -0
- package/dist/src/package/vendors/eda/EdaViewer.vue.d.ts +8 -0
- package/dist/src/package/vendors/eda/index.d.ts +2 -0
- package/dist/src/package/vendors/eda/parser.d.ts +77 -0
- package/dist/src/package/vendors/email/EmailViewer.vue.d.ts +10 -0
- package/dist/src/package/vendors/email/index.d.ts +2 -0
- package/dist/src/package/vendors/image/ImageViewer.vue.d.ts +6 -13
- package/dist/src/package/vendors/image/index.d.ts +1 -1
- package/dist/src/package/vendors/md/MarkdownViewer.vue.d.ts +6 -13
- package/dist/src/package/vendors/md/index.d.ts +1 -1
- package/dist/src/package/vendors/model/ModelViewer.vue.d.ts +8 -0
- package/dist/src/package/vendors/model/index.d.ts +3 -0
- package/dist/src/package/vendors/model/shared.d.ts +1 -0
- package/dist/src/package/vendors/nestedRender.d.ts +10 -0
- package/dist/src/package/vendors/ofd/OfdViewer.vue.d.ts +6 -0
- package/dist/src/package/vendors/ofd/index.d.ts +7 -0
- package/dist/src/package/vendors/pdf/PdfView.vue.d.ts +10 -13
- package/dist/src/package/vendors/pdf/index.d.ts +2 -1
- package/dist/src/package/vendors/pdf/worker/pdf.worker.d.ts +0 -0
- package/dist/src/package/vendors/pptx/PptxRender.vue.d.ts +9 -81
- package/dist/src/package/vendors/pptx/index.d.ts +1 -1
- package/dist/src/package/vendors/renders.d.ts +1 -1
- package/dist/src/package/vendors/text/CodeViewer.vue.d.ts +7 -13
- package/dist/src/package/vendors/text/index.d.ts +6 -2
- package/dist/src/package/vendors/typst/TypstViewer.vue.d.ts +15 -0
- package/dist/src/package/vendors/typst/index.d.ts +8 -0
- package/dist/src/package/vendors/umd/UmdViewer.vue.d.ts +6 -0
- package/dist/src/package/vendors/umd/index.d.ts +7 -0
- package/dist/src/package/vendors/umd/parser.d.ts +30 -0
- package/dist/src/package/vendors/word/doc.d.ts +5 -0
- package/dist/src/package/vendors/word/docx.d.ts +5 -0
- package/dist/src/package/vendors/word/docx.worker.d.ts +1 -0
- package/dist/src/package/vendors/word/index.d.ts +3 -0
- package/dist/src/package/vendors/xlsx/XlsxTable.state.d.ts +80 -0
- package/dist/src/package/vendors/xlsx/XlsxTable.view.d.ts +25 -0
- package/dist/src/package/vendors/xlsx/XlsxTable.vue.d.ts +6 -21
- package/dist/src/package/vendors/xlsx/index.d.ts +3 -2
- package/dist/src/package/vendors/xlsx/util.d.ts +0 -5
- package/dist/src/package/vendors/xlsx/worker/index.d.ts +4 -6
- package/dist/src/package/vendors/xlsx/worker/sheetjs/SheetJsModel.d.ts +73 -0
- package/dist/src/package/vendors/xlsx/worker/sheetjs/sheet.worker.d.ts +1 -0
- package/dist/style.css +1 -57
- package/dist/wasm/cad/dwfv-render.wasm +0 -0
- package/dist/wasm/cad/dwg-worker.js +24 -0
- package/dist/wasm/cad/libredwg-web.js +15 -0
- package/dist/wasm/cad/libredwg-web.wasm +0 -0
- package/package.json +118 -42
- package/.vscode/extensions.json +0 -3
- package/dist/components/_commonjs-dynamic-modules.js +0 -6
- package/dist/components/_commonjsHelpers.js +0 -36
- package/dist/components/docx-preview.min.js +0 -5287
- package/dist/components/index.js +0 -1717
- package/dist/favicon.ico +0 -0
- package/dist/index.umd.js +0 -436
- package/dist/src/package/vendors/docx/index.d.ts +0 -4
- package/dist/src/package/vendors/xlsx/render.d.ts +0 -6
- package/dist/src/package/vendors/xlsx/worker/xls/SheetJsModel.d.ts +0 -36
- package/dist/src/package/vendors/xlsx/worker/xlsx/ExcelJsModel.d.ts +0 -39
- package/dist/src/package/vendors/xlsx/worker/xlsx/context.d.ts +0 -7
- package/dist/src/package/vendors/xlsx/worker/xlsx/index.d.ts +0 -4
- package/dist/src/package/vendors/xlsx/worker/xlsx/util.d.ts +0 -10
- package/dist/worker/pdf.worker.js +0 -66
- package/dist/worker/pptx.worker.js +0 -21
- package/dist/worker/sheet.worker.js +0 -38
- package/dist/worker/xlsx.worker.js +0 -65
- /package/dist/src/package/vendors/xlsx/worker/{xlsx → sheetjs}/color.d.ts +0 -0
- /package/dist/src/package/vendors/xlsx/worker/{xls → sheetjs}/index.d.ts +0 -0
package/README.md
CHANGED
|
@@ -1,149 +1,366 @@
|
|
|
1
|
-
#
|
|
2
|
-
本项目作为当前仓库的vue3构建版本,会跟随vue2版本持续更新,敬请期待,欢迎提交issue和交流技术。
|
|
1
|
+
# Flyfish Viewer
|
|
3
2
|
|
|
4
|
-
|
|
3
|
+
[简体中文](README.md) | [English](README.en.md)
|
|
5
4
|
|
|
6
|
-
|
|
5
|
+
把 Word、Excel、PPT、PDF、Typst、压缩包、邮件、音频和电子书稳稳带进浏览器里。
|
|
7
6
|
|
|
8
|
-
|
|
9
|
-
本项目按计划支持vue3 + vite,并持续优化pptx和word模块。
|
|
7
|
+
`@flyfish-group/file-viewer3` 是一款基于 Vue 3、TypeScript 和 Vite 构建的纯前端文件预览组件。Vue2.7 项目请使用同能力包 `@flyfish-group/file-viewer`。两条 npm 包线保持一致的格式覆盖、示例体验和 API 语义,Vue3 构建产物作为 React、纯 Web 和其他适配层的统一预览基线。
|
|
10
8
|
|
|
11
|
-
|
|
9
|
+
它不依赖后端转码服务,适合接入 OA、知识库、附件中心、流程系统和需要离线能力的业务场景。这个项目的目标很直接: 让文档预览不再像临时拼出来的功能,而是像一个可以放心交付、能独立演示、能持续维护的产品模块。
|
|
12
10
|
|
|
11
|
+
- npm(Vue3): [@flyfish-group/file-viewer3](https://www.npmjs.com/package/@flyfish-group/file-viewer3)
|
|
12
|
+
- npm(Vue2): [@flyfish-group/file-viewer](https://www.npmjs.com/package/@flyfish-group/file-viewer)
|
|
13
|
+
- npm(React): [@flyfish-group/file-viewer-react](https://www.npmjs.com/package/@flyfish-group/file-viewer-react)
|
|
14
|
+
- npm(纯 JS): [@flyfish-group/file-viewer-web](https://www.npmjs.com/package/@flyfish-group/file-viewer-web)
|
|
15
|
+
- 官方文档: [doc.flyfish.dev](https://doc.flyfish.dev)
|
|
16
|
+
- 在线 Demo: [viewer.flyfish.dev](https://viewer.flyfish.dev)
|
|
17
|
+
- 文档比对 Demo: [viewer.flyfish.dev/compare.html](https://viewer.flyfish.dev/compare.html)
|
|
18
|
+
- Release 下载: [github.com/flyfish-dev/file-viewer/releases](https://github.com/flyfish-dev/file-viewer/releases)
|
|
19
|
+
- Docker 镜像发布目标: `flyfishdev/file-viewer:1.0.25`
|
|
20
|
+
- 公开成品仓库(GitHub): [github.com/flyfish-dev/file-viewer](https://github.com/flyfish-dev/file-viewer)
|
|
21
|
+
- 公开成品仓库(Gitee): [gitee.com/flyfish-dev/file-viewer](https://gitee.com/flyfish-dev/file-viewer)
|
|
22
|
+
- 源码自助开通: [https://dev.flyfish.group/shop](https://dev.flyfish.group/shop)
|
|
13
23
|
|
|
24
|
+
## 当前发布版本
|
|
14
25
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
> 5. 优化Pptx响应速度,使用重用逻辑
|
|
22
|
-
> 6. 优化Pptx加载项,解耦图表部分,待重构解耦相关NvD3依赖。
|
|
23
|
-
> 7. 使用完全的组合式API构建应用,高性能低占用
|
|
24
|
-
> 8. 解耦了样式依赖,FileViewer组件依赖父节点进行布局,自动填满
|
|
26
|
+
| 技术栈 | npm 包 | 最新版本 | 推荐分支 | 说明 |
|
|
27
|
+
| --- | --- | --- | --- | --- |
|
|
28
|
+
| Vue3 | `@flyfish-group/file-viewer3` | `1.0.25` | `v3` | 主推版本,也是 React / 纯 Web 私有化 iframe 适配层的构建基线 |
|
|
29
|
+
| Vue2.7 | `@flyfish-group/file-viewer` | `1.0.25` | `main` | 兼容 Vue2 项目,格式能力与 Vue3 保持一致 |
|
|
30
|
+
| React 17 / 18 / 19 | `@flyfish-group/file-viewer-react` | `1.0.25` | 当前仓库子工程 | iframe 组件,默认加载 `/file-viewer/index.html` |
|
|
31
|
+
| 纯 JS | `@flyfish-group/file-viewer-web` | `1.0.25` | 当前仓库子工程 | iframe helper 和 viewer 产物复制工具 |
|
|
25
32
|
|
|
33
|
+
如果你在内网、离线环境,或者 npm 发布权限还没有完成配置,也可以直接使用公开成品仓库 `artifacts/` 里的 tarball。离线安装 React 包时请先安装同版本 web 包:
|
|
26
34
|
|
|
35
|
+
```bash
|
|
36
|
+
npm install ./artifacts/flyfish-group-file-viewer3-1.0.25.tgz
|
|
37
|
+
npm install ./artifacts/flyfish-group-file-viewer-1.0.25.tgz
|
|
38
|
+
npm install ./artifacts/flyfish-group-file-viewer-web-1.0.25.tgz
|
|
39
|
+
npm install ./artifacts/flyfish-group-file-viewer-react-1.0.25.tgz
|
|
40
|
+
```
|
|
27
41
|
|
|
28
|
-
|
|
42
|
+
Vue3、Vue2、React 和纯 JS tarball 都会随公开成品仓库一起生成。离线安装 React 包时请先安装同版本 web 包;React / 纯 JS 包推荐用 `npm install` 获得安装即复制的体验。pnpm 10 默认会拦截依赖包的 `postinstall`,如果看到 `Ignored build scripts: @flyfish-group/file-viewer-web`,请执行 `pnpm approve-builds` 允许该包,或安装后运行 `pnpm exec file-viewer-copy-assets ./public/file-viewer`。
|
|
43
|
+
|
|
44
|
+
GitHub Release 会同步提供完整下载项:
|
|
45
|
+
|
|
46
|
+
| 文件 | 用途 |
|
|
47
|
+
| --- | --- |
|
|
48
|
+
| `file-viewer-v3-*-demo.tar.gz` | 主 Demo / iframe 私有化部署静态站,解压后即可用 `/index.html?url=...` 接入 |
|
|
49
|
+
| `file-viewer-v3-*-adapter-demo.tar.gz` | React / 纯 JS 适配层演示站 |
|
|
50
|
+
| `file-viewer-v3-*-lib-dist.tar.gz` | Vue3 组件库构建产物,适合离线检查 dist 内容 |
|
|
51
|
+
| `file-viewer-v3-*-docs.tar.gz` | 文档站静态产物 |
|
|
52
|
+
| `flyfish-group-file-viewer3-*.tgz` | Vue3 本地 npm 安装包 |
|
|
53
|
+
| `flyfish-group-file-viewer-*.tgz` | Vue2.7 本地 npm 安装包 |
|
|
54
|
+
| `flyfish-group-file-viewer-web-*.tgz` | 纯 JS iframe helper,本地安装后复制 viewer 静态产物 |
|
|
55
|
+
| `flyfish-group-file-viewer-react-*.tgz` | React iframe 组件,本地安装时请同时安装同版本 web 包 |
|
|
56
|
+
|
|
57
|
+

|
|
58
|
+
|
|
59
|
+
## 为什么值得接入
|
|
60
|
+
|
|
61
|
+
- **纯前端 Serverless。** 文档解析和展示全部在浏览器内完成,部署简单,不依赖 Office 服务端、LibreOffice 守护进程或额外转码链路。
|
|
62
|
+
- **格式覆盖完整。** 当前内置 152 个扩展名映射,覆盖 Word、Excel、PowerPoint、PDF、OFD、Typst、压缩包、邮件、OLB/DRA、CAD、3D 模型、Excalidraw、draw.io、EPUB、UMD、Markdown、图片、音频、代码/文本和 MP4,能覆盖绝大多数业务附件场景。
|
|
63
|
+
- **按需异步加载。** PDF、OFD、Typst、压缩包、邮件、OLB/DRA、CAD、3D 模型、绘图、Office、EPUB、UMD、Markdown 和代码高亮渲染器都按需加载,重型解析依赖不会进入其他格式的首屏路径。
|
|
64
|
+
- **预览器操作完整。** 内置下载原文件、打印完整渲染结果、导出渲染后 HTML、水印开关、水印 options、主题 options、搜索高亮、上一个 / 下一个命中、行级定位和 AI 友好文本切片;PDF 使用 PDF.js 原生搜索,Word / Markdown / 代码等文本类格式使用通用 DOM 搜索,避免污染 PDF 文本层、canvas、iframe 等特殊渲染结构;`theme` 支持 `light`、`dark`、`system`,默认跟随系统,浅色业务 UI 可显式锁定 `light`;打印按钮会按当前格式和渲染链路动态显隐,Word / PDF 使用专属完整页导出适配器,不依赖当前视口,适合合同、归档和审批类场景。
|
|
65
|
+
- **集成控制更完整。** 提供加载/卸载生命周期钩子、iframe 事件回传和按钮前置校验机制,下载、打印、导出前可以接入权限验证、审计确认或业务二次弹窗。
|
|
66
|
+
- **阅读体验更像产品。** `.doc`、`.docx`、PDF 都保留灰色工作台、白色纸张、居中阅读和自适应缩放;DOCX 默认使用 Web Worker 承载 `docx-preview` 的解析和 HTML 构建,并把同一份 docx-preview HTML 按页面渐进挂载,主线程只负责挂载、缩放和打印适配;PDF 兼容旋转页和页面 / 目录导航,Excel 会尽量还原图片和自动文本色,避免“内容能打开但不好读”的落差。
|
|
67
|
+
- **明暗主题有边界。** Demo 外壳、Markdown 和代码预览会适配系统暗色模式;PDF、Word、Excel 等带原始版式的内容保持独立纸张或表格背景,避免全局主题污染文档。
|
|
68
|
+
- **Demo 更适合验收。** 示例文件按文档、表格、图纸、代码、图片等类型分组展示,点击样例即可打开并自动收起选择器。
|
|
69
|
+
- **独立文档比对入口。** 生产 Demo 额外提供 `/compare.html`,左右并排预览两份文档,支持示例、URL、本地上传、交换、重置、同步滚动、聚焦文档搜索、行级定位和 PDF 工具栏隐藏,不污染主预览入口。
|
|
70
|
+
- **Vue2 / Vue3 体验一致。** `main` 分支面向 Vue2.7,`v3` 分支面向 Vue3;两边共享完整格式覆盖、示例文件盒子、文档站和 iframe 集成体验。
|
|
71
|
+
- **组件和独立站两用。** 既支持在 Vue 项目里直接作为组件使用,也支持独立部署后通过 iframe 嵌入到任意系统,方便多业务线复用。
|
|
72
|
+
- **Docker 一键部署。** 提供 nginx 静态镜像、`Dockerfile` 和 buildx 发布脚本,发布镜像覆盖 `linux/amd64` 与 `linux/arm64`。
|
|
73
|
+
- **适合成品交付。** 公开成品仓库、混淆压缩产物、npm tarball、静态部署产物和私有化 iframe 适配包都一起维护,便于下载、验收和二次接入。
|
|
74
|
+
|
|
75
|
+
## 支持格式
|
|
76
|
+
|
|
77
|
+
当前版本内置 152 个扩展名映射,覆盖 20 条预览链路。
|
|
78
|
+
|
|
79
|
+
| 类别 | 扩展名 | 当前表现 | 适合场景 |
|
|
80
|
+
| --- | --- | --- | --- |
|
|
81
|
+
| Word | `docx`、`docm`、`dotx`、`dotm` | `docx-preview` + Web Worker,保留文档结构和版式;模板/宏格式按只读预览处理 | 新生成的 Word 文档、正式文档、Word 模板 |
|
|
82
|
+
| Word | `doc`、`dot` | `msdoc-viewer` + Word 风格页面容器,增强 CFB 容错和表格布局 | 历史 `.doc` 老文档、Word 97-2003 模板 |
|
|
83
|
+
| Excel | `xlsx`、`xltx` | `styled-exceljs` + 虚拟滚动,支持尺寸、合并、常见样式、自动文本色和 workbook drawing 图片;打印按钮按能力隐藏,避免只打印当前视口 | 需要保留表格结构和样式的业务、Excel 模板 |
|
|
84
|
+
| Excel 兼容格式 | `xlsm`、`xlsb`、`xls`、`xlt`、`xltm`、`csv`、`ods`、`fods`、`numbers` | 统一解析,按格式可用信息渐进还原样式;同样遵循虚拟表格打印边界 | 老表格、轻量数据查看 |
|
|
85
|
+
| PowerPoint | `pptx`、`pptm`、`potx`、`potm`、`ppsx`、`ppsm` | 浏览幻灯片内容,增强组合图形、主题背景、图片裁剪与 EMF 矢量图预览 | 汇报材料、课件、方案、演示模板 |
|
|
86
|
+
| PDF | `pdf` | 基于 `pdfjs-dist` 预览,同源 URL 默认渐进读取;服务端支持 Range 时自动分片加载,支持缩放工具栏、旋转页、页侧边栏/目录树侧边栏切换、宽度自适应、完整打印和导出 HTML | 合同、票据、版式成品 |
|
|
87
|
+
| OFD | `ofd` | 基于 `DLTech21/ofd.js` 仓库源码在线预览国产版式文档,避开 npm dist 授权 wasm 分支 | 电子发票、公文、归档材料 |
|
|
88
|
+
| Typst | `typ`、`typst` | 直接读取 Typst 源文件,按需加载 `@myriaddreamin/typst.ts` 浏览器 WASM 编译器并按页 SVG 渲染;支持完整预览、打印和导出 HTML | 技术报告、论文草稿、工程文档模板 |
|
|
89
|
+
| 压缩包 | `zip`、`zipx`、`7z`、`rar`、`tar`、`gz`、`gzip`、`tgz`、`bz2`、`bzip2`、`tbz`、`tbz2`、`xz`、`txz`、`lzma`、`zst`、`tzst`、`cab`、`ar`、`cpio`、`iso`、`xar`、`lha`、`lzh`、`jar`、`war`、`ear`、`apk`、`cbz`、`cbr` | 基于 `libarchive.js` 的 WASM Worker 读取目录,点击后按需解压内部文件并复用统一预览器,支持 IndexedDB 缓存和体积上限 | 归档附件、批量交付包、压缩包内文档快速查看 |
|
|
90
|
+
| 邮件 | `eml`、`msg` | EML 使用 `postal-mime`,MSG 使用 `@kenjiuno/msgreader`,支持头信息、HTML/文本正文、附件下载与附件预览 | 邮件归档、工单邮件、客户来信附件 |
|
|
91
|
+
| EDA | `olb`、`dra` | 使用 `cfb` 解析 OrCAD/Allegro 常见 CFB 容器,展示结构树、元件/封装/Padstack 候选、属性、诊断和可读字符串;退化时提供安全二进制索引 | 元件库、封装图纸、EDA 附件初筛 |
|
|
92
|
+
| CAD | `dwg`、`dxf`、`dwf`、`dwfx`、`xps` | 基于 `@flyfish-dev/cad-viewer` 预览图纸;DWG 通过 Worker + LibreDWG WASM 解析,DXF 使用 JS parser,DWF/DWFx/XPS 使用 native `dwf-viewer` 渲染 W2D/W3D/XPS 图形 | 工程图纸、二维 CAD 附件、AutoCAD 归档文件 |
|
|
93
|
+
| 3D 模型 | `glb`、`gltf`、`obj`、`stl`、`ply`、`fbx`、`dae`、`3ds`、`3mf`、`amf`、`usd`、`usda`、`usdc`、`usdz`、`kmz`、`pcd`、`wrl`、`vrml`、`xyz`、`vtk`、`vtp`、`step`、`stp`、`iges`、`igs`、`ifc`、`3dm` | 基于 Three.js 交互预览;工程 CAD/BIM 格式会给出不内置几何内核的原因和转换建议 | 设计模型、点云、三维资产、工程模型 |
|
|
94
|
+
| Excalidraw | `excalidraw` | 基于官方 `@excalidraw/excalidraw` 的 `restore` + `exportToSvg` 输出只读预览 | 白板草图、流程草稿、产品沟通图 |
|
|
95
|
+
| draw.io | `drawio`、`dio` | 基于官方 diagrams.net `GraphViewer` 预览 mxGraphModel / mxfile | 流程图、架构图、业务泳道图 |
|
|
96
|
+
| 电子书 | `epub` | 基于 `epubjs` 解析目录和章节资源,使用兼容性更好的滚动阅读 | 电子书、培训手册、长篇阅读材料 |
|
|
97
|
+
| 电子书 | `umd` | 按 UMD 移动电子书结构解析元数据、目录和 zlib 压缩正文 | 旧移动电子书、历史小说附件 |
|
|
98
|
+
| Markdown | `md`、`markdown` | Markdown 阅读样式,支持明暗主题阅读面 | README、知识文档、说明文档 |
|
|
99
|
+
| 图片 | `gif`、`jpg`、`jpeg`、`bmp`、`tiff`、`tif`、`png`、`svg`、`webp` | 原生图片浏览 | 图片附件、设计稿、Logo |
|
|
100
|
+
| 代码/文本 | `txt`、`json`、`js`、`mjs`、`cjs`、`css`、`java`、`py`、`html`、`htm`、`jsx`、`ts`、`tsx`、`xml`、`log`、`vue`、`yaml`、`yml`、`ini`、`sh`、`bash`、`sql`、`go`、`rs`、`php`、`c`、`cpp`、`cc`、`h`、`hpp`、`cs`、`diff` | 使用 `highlight.js` 轻量高亮,HTML 按源码展示 | 日志、配置、代码片段、接口响应 |
|
|
101
|
+
| 音频 | `mp3`、`mpeg`、`wav`、`ogg`、`oga`、`opus`、`m4a`、`aac`、`flac`、`weba` | 浏览器原生音频播放,带控制条和基础进度信息 | 录音、播客、语音附件、音效素材 |
|
|
102
|
+
| 视频 | `mp4` | 浏览器原生视频播放 | 演示视频、录屏 |
|
|
103
|
+
|
|
104
|
+
## 接入路线
|
|
105
|
+
|
|
106
|
+
### 1. Vue 3 组件集成
|
|
107
|
+
|
|
108
|
+
适合已经在 Vue 3 项目里开发,希望最短路径完成接入的团队。React、纯 Web 和后续其他框架适配层都以这套 Vue3 构建产物作为 iframe 预览基线。
|
|
109
|
+
|
|
110
|
+
```bash
|
|
111
|
+
pnpm add @flyfish-group/file-viewer3
|
|
112
|
+
```
|
|
29
113
|
|
|
30
|
-
|
|
114
|
+
```ts
|
|
115
|
+
import { createApp } from 'vue'
|
|
116
|
+
import App from './App.vue'
|
|
117
|
+
import FileViewer from '@flyfish-group/file-viewer3'
|
|
31
118
|
|
|
32
|
-
|
|
33
|
-
npm install
|
|
119
|
+
createApp(App).use(FileViewer).mount('#app')
|
|
34
120
|
```
|
|
35
121
|
|
|
36
|
-
|
|
37
|
-
```
|
|
38
|
-
npm run dev
|
|
39
|
-
```
|
|
122
|
+
Vue3 入口会把样式一起带到安装器里,所以这里不需要再额外引入 `dist/file-viewer3.css`。
|
|
40
123
|
|
|
41
|
-
|
|
124
|
+
```vue
|
|
125
|
+
<script setup lang="ts">
|
|
126
|
+
import { ref } from 'vue'
|
|
127
|
+
|
|
128
|
+
const url = ref('https://example.com/demo.pdf')
|
|
129
|
+
</script>
|
|
130
|
+
|
|
131
|
+
<template>
|
|
132
|
+
<div style="height: 100vh">
|
|
133
|
+
<file-viewer :url="url" />
|
|
134
|
+
</div>
|
|
135
|
+
</template>
|
|
42
136
|
```
|
|
43
|
-
|
|
137
|
+
|
|
138
|
+
### 2. Vue 2 组件集成
|
|
139
|
+
|
|
140
|
+
适合仍在 Vue2.7 技术栈上,希望直接以内嵌组件方式完成接入的团队。Vue2 入口也会自动带上样式,不需要再额外 import CSS。
|
|
141
|
+
|
|
142
|
+
```bash
|
|
143
|
+
pnpm add @flyfish-group/file-viewer
|
|
44
144
|
```
|
|
45
145
|
|
|
46
|
-
|
|
146
|
+
```ts
|
|
147
|
+
import Vue from 'vue'
|
|
148
|
+
import App from './App.vue'
|
|
149
|
+
import FileViewer from '@flyfish-group/file-viewer'
|
|
150
|
+
|
|
151
|
+
Vue.use(FileViewer)
|
|
152
|
+
|
|
153
|
+
new Vue({
|
|
154
|
+
render: h => h(App)
|
|
155
|
+
}).$mount('#app')
|
|
47
156
|
```
|
|
48
|
-
|
|
157
|
+
|
|
158
|
+
```vue
|
|
159
|
+
<template>
|
|
160
|
+
<div style="height: 100vh">
|
|
161
|
+
<file-viewer :url="url" />
|
|
162
|
+
</div>
|
|
163
|
+
</template>
|
|
164
|
+
|
|
165
|
+
<script>
|
|
166
|
+
export default {
|
|
167
|
+
data() {
|
|
168
|
+
return {
|
|
169
|
+
url: 'https://example.com/demo.pdf'
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
</script>
|
|
49
174
|
```
|
|
50
175
|
|
|
176
|
+
### 3. Iframe 嵌入
|
|
177
|
+
|
|
178
|
+
适合多系统共用一套预览器、想把预览能力独立部署、或者不希望把解析依赖带进业务包的场景。
|
|
51
179
|
|
|
180
|
+
```html
|
|
181
|
+
<iframe
|
|
182
|
+
id="viewer"
|
|
183
|
+
src="/file-viewer/index.html?url=https%3A%2F%2Fexample.com%2Fdemo.docx"
|
|
184
|
+
style="width: 100%; height: 100%; border: 0"
|
|
185
|
+
></iframe>
|
|
186
|
+
```
|
|
52
187
|
|
|
53
|
-
|
|
188
|
+
更完整的二进制推送方案、`from` 安全校验和宿主页面示例,请查看仓库内的 [Iframe 嵌入说明](docs/guide/iframe.md)。
|
|
54
189
|
|
|
55
|
-
###
|
|
190
|
+
### 4. React / 纯 Web 子工程
|
|
56
191
|
|
|
57
|
-
|
|
192
|
+
React 与纯 Web 适配层不再复制渲染器,只通过 iframe 加载 Vue3 基线预览器产物。包里会携带主工程构建产物,安装后复制到宿主项目 `public/file-viewer`,组件默认加载 `/file-viewer/index.html`,只提供私有化静态部署路线:
|
|
58
193
|
|
|
59
|
-
|
|
194
|
+
官网 Demo 可用于快速验证预览效果,但 React / 纯 JS 组件不会把官网 Demo 地址作为内置 viewer 地址。
|
|
60
195
|
|
|
196
|
+
```bash
|
|
197
|
+
npm install @flyfish-group/file-viewer-react@1.0.25
|
|
198
|
+
npm install @flyfish-group/file-viewer-web@1.0.25
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
```tsx
|
|
202
|
+
import FileViewer from '@flyfish-group/file-viewer-react'
|
|
203
|
+
|
|
204
|
+
export function Preview() {
|
|
205
|
+
return (
|
|
206
|
+
<div style={{ height: '100vh' }}>
|
|
207
|
+
<FileViewer
|
|
208
|
+
url="https://example.com/demo.docx"
|
|
209
|
+
/>
|
|
210
|
+
</div>
|
|
211
|
+
)
|
|
212
|
+
}
|
|
61
213
|
```
|
|
62
|
-
|
|
214
|
+
|
|
215
|
+
`@flyfish-group/file-viewer-react` 支持 React 17 / 18 / 19,内部复用 `@flyfish-group/file-viewer-web` 的 iframe 协议工具。鉴权文件仍建议由宿主系统先下载成 `Blob`,再用 `file` + `name` 推送给预览器。静态目录不是 `public/file-viewer` 时,可以运行 `npx file-viewer-copy-assets ./public/vendor/file-viewer`,并覆盖 `viewerUrl="/vendor/file-viewer/index.html"`。helper 会默认追加 `__flyfish_viewer_version`,避免旧入口 HTML 缓存继续引用已经不存在的 hash chunk。
|
|
216
|
+
|
|
217
|
+
本仓库内置了一个私有化适配层演示应用,覆盖 React 组件和纯 Web helper 两种入口。调试时直接运行:
|
|
218
|
+
|
|
219
|
+
```bash
|
|
220
|
+
pnpm dev:adapters
|
|
63
221
|
```
|
|
64
222
|
|
|
65
|
-
|
|
223
|
+
它会先构建并同步 Vue3 基线预览器到演示应用的 `public/file-viewer` 和 `public/vendor/file-viewer`,打开本地地址即可同时验证 React 组件和纯 JS `mountViewerFrame` 在自定义子路径下的 DOCX 预览效果。验证静态部署产物时运行:
|
|
66
224
|
|
|
67
|
-
|
|
225
|
+
```bash
|
|
226
|
+
pnpm build:adapter-demo
|
|
227
|
+
pnpm --filter @flyfish-group/file-viewer-demo preview
|
|
228
|
+
```
|
|
68
229
|
|
|
69
|
-
|
|
230
|
+
确认无误后,`packages/demo/dist` 可以作为普通静态目录部署;其中已经包含 `file-viewer/index.html`、`vendor/file-viewer/index.html` 和演示文件。
|
|
70
231
|
|
|
71
|
-
|
|
72
|
-
import { createApp } from 'vue'
|
|
73
|
-
import App from './App.vue'
|
|
74
|
-
import FileViewer from 'file-viewer3'
|
|
232
|
+
### 5. Docker 一键部署
|
|
75
233
|
|
|
76
|
-
|
|
77
|
-
.mount('#app')
|
|
234
|
+
适合内网、私有云、客户现场或希望直接运行完整 Demo 的场景。镜像发布后可直接运行:
|
|
78
235
|
|
|
236
|
+
```bash
|
|
237
|
+
docker run -d \
|
|
238
|
+
--name flyfish-viewer \
|
|
239
|
+
--restart unless-stopped \
|
|
240
|
+
-p 8080:80 \
|
|
241
|
+
flyfishdev/file-viewer:1.0.25
|
|
79
242
|
```
|
|
80
243
|
|
|
81
|
-
|
|
244
|
+
访问:
|
|
82
245
|
|
|
83
|
-
|
|
246
|
+
- 主预览: `http://localhost:8080/`
|
|
247
|
+
- 文档比对: `http://localhost:8080/compare.html`
|
|
84
248
|
|
|
85
|
-
|
|
249
|
+
源码仓库内也提供 `Dockerfile`,本地构建运行:
|
|
86
250
|
|
|
87
|
-
```
|
|
88
|
-
|
|
89
|
-
|
|
251
|
+
```bash
|
|
252
|
+
pnpm docker:build
|
|
253
|
+
docker run --rm -p 8080:80 flyfishdev/file-viewer:1.0.25
|
|
254
|
+
```
|
|
90
255
|
|
|
91
|
-
|
|
256
|
+
## 使用说明
|
|
257
|
+
|
|
258
|
+
- 组件支持两条主要输入路径: `url?: string` 与 `file?: File`
|
|
259
|
+
- 独立文档比对页位于 `/compare.html`,可通过 `?left=/example/test.doc&right=/example/word.docx` 预置左右文件;它支持同步滚动、当前聚焦文档的浮层搜索、高亮命中、上一个 / 下一个、行级定位和 PDF 工具栏隐藏,但只做视觉并排预览,不做语义 diff,完整说明见 [Demo 文档](docs/guide/demo.md#文档比对页)
|
|
260
|
+
- 当 `file` 和 `url` 同时存在时,会优先渲染 `file`
|
|
261
|
+
- 如果业务侧拿到的是 `Blob` 或 `ArrayBuffer`,推荐先包装成带扩展名的 `File`
|
|
262
|
+
- 预览器会填满父容器,请为父容器提供稳定高度
|
|
263
|
+
- 使用 `url` 预览时,目标资源需要允许浏览器访问;跨域场景下需要正确配置 CORS
|
|
264
|
+
- 如果下载地址本身没有明确扩展名,建议先在业务侧取回文件,再包装成 `File`
|
|
265
|
+
- PPTX 渲染器会尽量还原常见组合图形、旋转/翻转、主题背景、图片裁剪和 EMF 矢量图片;复杂 Office 特效仍建议用真实业务文件做回归
|
|
266
|
+
- OFD、Typst、压缩包、邮件、OLB/DRA、CAD、3D 模型、绘图、EPUB、UMD、PDF、Office、Markdown、音频和代码高亮渲染器都按需异步加载,只有命中格式时才拉取对应代码块;Typst compiler WASM 可通过 `options.typst.compilerWasmUrl` 指向自托管地址,默认仅在打开 `.typ` / `.typst` 时加载
|
|
267
|
+
- `options.archive` 一般只需要配置 `cache`、`workerTimeoutMs` 和体积上限;预览器会先尝试当前部署 base 下的 `vendor/libarchive/worker-bundle.js`,失败后自动使用打包内置 Worker。手机 WebView、本地临时服务器、MIME 或 CSP 导致 Worker 初始化超时时,会继续降级到 ZIP/TAR/GZIP 兼容模式,避免压缩包一直停在 loading。只有静态目录或 CDN 路径特殊时,才需要显式传 `archive.workerUrl` / `archive.wasmUrl`
|
|
268
|
+
- `options.theme` 支持 `light`、`dark`、`system`,默认继续跟随系统;`options.docx.worker` 默认开启,让 DOCX 在 Worker 内用 `docx-preview` 构建 HTML,`options.docx.progressive` 默认开启,把 docx-preview 页面按批次挂载以便先看到内容;CSP 或低版本浏览器不兼容时可设为 `worker: false` 回退原生主线程渲染;`options.watermark` 支持文字或图片水印;`options.toolbar` 可控制下载原文件、打印完整渲染结果、导出 HTML、统一缩放按钮和操作栏位置,`toolbar.zoom` 可单独控制缩放按钮显示,`toolbar.position` 支持 `auto`、`top`、`bottom-right`,PDF 默认悬浮到右下角以避开自身导航栏;统一缩放通过渲染器内部 provider 适配 PDF、Word、PPTX、Excel 虚拟表格、图片、CAD、OFD、Typst、Markdown、代码和绘图等链路,避免业务侧外层 CSS 缩放造成表格坐标或 canvas 交互偏移;`options.pdf.toolbar` 可隐藏 PDF 自身页码缩放工具栏;`options.search` 可控制搜索高亮、整词/大小写和命中数量;`options.ai` 可开启文本切片结构,返回行号、页码、锚点和 label 等溯源字段,便于业务侧做向量化、召回、AI 摘要、高亮回填和来源定位;`options.hooks` 可接收加载/卸载生命周期;`options.beforeOperation` 可在下载、打印、导出和缩放前做权限校验;打印按钮会结合当前文件类型、渲染完成状态和导出适配器动态显隐,Word / PDF 会生成完整页面,Excel 等虚拟表格会隐藏打印按钮,避免只打印当前视口或第一页
|
|
269
|
+
|
|
270
|
+
```ts
|
|
271
|
+
const blob = await response.blob()
|
|
272
|
+
const file = new File([blob], 'contract.pdf', { type: blob.type })
|
|
273
|
+
```
|
|
92
274
|
|
|
93
|
-
|
|
94
|
-
url.value = 'http://flyfish.group/%E6%95%B0%E6%8D%AE%E4%B8%AD%E5%8F%B0%E7%AC%94%E8%AE%B0(1).docx';
|
|
95
|
-
})
|
|
96
|
-
</script>
|
|
97
|
-
<template>
|
|
98
|
-
<div class='simple-view'>
|
|
99
|
-
<file-viewer :url="url" />
|
|
100
|
-
</div>
|
|
101
|
-
</template>
|
|
275
|
+
## 本地开发
|
|
102
276
|
|
|
103
|
-
|
|
104
|
-
.simple-view {
|
|
105
|
-
height: 100vh;
|
|
106
|
-
}
|
|
107
|
-
</style>
|
|
277
|
+
下面的命令适用于源码开通后的完整项目。公开 GitHub / Gitee 成品仓库不包含源码目录,普通用户建议直接通过 npm、`dist/` 或 `artifacts/` 里的 tarball 使用。
|
|
108
278
|
|
|
279
|
+
```bash
|
|
280
|
+
pnpm install
|
|
281
|
+
pnpm dev
|
|
282
|
+
```
|
|
109
283
|
|
|
284
|
+
常用脚本:
|
|
285
|
+
|
|
286
|
+
- `pnpm build`: 构建示例站点
|
|
287
|
+
- `pnpm build-lib`: 构建组件库产物
|
|
288
|
+
- `pnpm docs:dev`: 启动 VitePress 文档站
|
|
289
|
+
- `pnpm docs:build`: 构建文档站
|
|
290
|
+
- `pnpm type-check`: 执行 TypeScript 类型检查
|
|
291
|
+
- `pnpm dev:adapters`: 启动 React + 纯 JS 适配层 Demo
|
|
292
|
+
- `pnpm build:adapter-demo`: 构建适配层 Demo
|
|
293
|
+
- `pnpm docker:build`: 构建本机架构 Docker 镜像
|
|
294
|
+
- `pnpm docker:publish`: 推送 Docker Hub `linux/amd64` / `linux/arm64` 多架构镜像;可通过 `DOCKER_IMAGE` 替换命名空间
|
|
295
|
+
- `pnpm release:adapters:pack`: 打包 React / 纯 JS npm tarball
|
|
296
|
+
|
|
297
|
+
## 打包发布
|
|
298
|
+
|
|
299
|
+
Vue3 和 Vue2 发包时分别在对应分支执行同一套发布链路:
|
|
300
|
+
|
|
301
|
+
| 包 | 分支 | npm 名称 |
|
|
302
|
+
| --- | --- | --- |
|
|
303
|
+
| Vue3 | `v3` | `@flyfish-group/file-viewer3` |
|
|
304
|
+
| Vue2.7 | `main` | `@flyfish-group/file-viewer` |
|
|
305
|
+
| React | 当前仓库子工程 | `@flyfish-group/file-viewer-react` |
|
|
306
|
+
| 纯 JS | 当前仓库子工程 | `@flyfish-group/file-viewer-web` |
|
|
307
|
+
|
|
308
|
+
建议在发布前执行下面这组命令:
|
|
309
|
+
|
|
310
|
+
```bash
|
|
311
|
+
pnpm type-check
|
|
312
|
+
pnpm build
|
|
313
|
+
pnpm build-lib
|
|
314
|
+
pnpm obfuscate
|
|
315
|
+
pnpm docs:build
|
|
316
|
+
npm pack
|
|
110
317
|
```
|
|
111
318
|
|
|
112
|
-
|
|
319
|
+
其中:
|
|
320
|
+
|
|
321
|
+
- `dist/` 是库构建产物;执行 `pnpm obfuscate` 后会对其中的 `.js` / `.mjs` 进行压缩混淆
|
|
322
|
+
- `pnpm build` 会生成可独立部署的 Demo 静态站点产物
|
|
323
|
+
- `docs/.vitepress/dist/` 是文档站静态产物
|
|
324
|
+
- `npm pack` 会生成可直接发布或分发的 npm 包 tarball
|
|
113
325
|
|
|
114
|
-
|
|
326
|
+
如果只是准备 npm 包,可以直接执行:
|
|
115
327
|
|
|
116
|
-
|
|
328
|
+
```bash
|
|
329
|
+
pnpm release:pack
|
|
330
|
+
```
|
|
331
|
+
|
|
332
|
+
React 和纯 JS 适配包发布前执行:
|
|
117
333
|
|
|
118
|
-
|
|
334
|
+
```bash
|
|
335
|
+
pnpm type-check:adapters
|
|
336
|
+
pnpm build:adapter-demo
|
|
337
|
+
pnpm release:adapters:pack
|
|
338
|
+
pnpm release:adapters:publish
|
|
339
|
+
```
|
|
119
340
|
|
|
120
|
-
|
|
121
|
-
2. 打开`example`文件夹中的`embedded.html`,修改目标地址为本地调试地址
|
|
341
|
+
发布到 npm:
|
|
122
342
|
|
|
123
|
-
```
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
origin: 'http://localhost:8900',
|
|
127
|
-
// 目标frame
|
|
128
|
-
frame: null,
|
|
129
|
-
// 文件url
|
|
130
|
-
url: './word.docx'
|
|
131
|
-
};
|
|
343
|
+
```bash
|
|
344
|
+
npm publish --dry-run --access public
|
|
345
|
+
npm publish --access public
|
|
132
346
|
```
|
|
133
347
|
|
|
134
|
-
|
|
135
|
-
4. 具体请参考demo代码,原理是基于`iframe`跨域通信机制。
|
|
348
|
+
如果 npm 账号启用了 MFA,请使用交互式终端完成浏览器确认后再等待发布结果。
|
|
136
349
|
|
|
137
|
-
|
|
350
|
+
公开 GitHub / Gitee 成品仓库只提交可直接使用的构建产物、Demo、文档站、示例文件和 npm tarball,不提交当前源码目录。为避免 Gitee 因历史二进制膨胀超过 1GB,同步 Gitee 时会使用最新完整成品快照的干净历史,而不是把多轮构建产物历史全部带过去。需要源码、二开包或商业自助开通的用户,可以前往 [https://dev.flyfish.group/shop](https://dev.flyfish.group/shop),付费 4.99 后自助开通。
|
|
138
351
|
|
|
352
|
+
## 文档导航
|
|
139
353
|
|
|
354
|
+
- [文档导览](https://doc.flyfish.dev/guide/)
|
|
355
|
+
- [快速开始](https://doc.flyfish.dev/guide/quickstart)
|
|
356
|
+
- [Demo 说明](https://doc.flyfish.dev/guide/demo)
|
|
357
|
+
- [组件用法](https://doc.flyfish.dev/guide/usage)
|
|
358
|
+
- [支持格式](https://doc.flyfish.dev/guide/formats)
|
|
359
|
+
- [本地开发与打包](https://doc.flyfish.dev/guide/development)
|
|
360
|
+
- [Docker 部署](https://doc.flyfish.dev/guide/docker)
|
|
140
361
|
|
|
141
|
-
##
|
|
142
|
-
#### [feature]`v1.0.7` `2022年4月24日`
|
|
143
|
-
1. 修复基于依赖的项目,无法预览pdf的问题
|
|
362
|
+
## 开源说明
|
|
144
363
|
|
|
145
|
-
|
|
364
|
+
本项目使用 `Apache-2.0` 许可证。
|
|
146
365
|
|
|
147
|
-
|
|
148
|
-
2. 增加pdf预览初始缩放大小,自动适配页面。调整pdf预览缩放下限为0.5
|
|
149
|
-
3. demo增加url预览模式,在请求参数中添加`url=文件地址`,可自动拉取并渲染文件
|
|
366
|
+
二开或商用时,请按许可证要求保留版权、许可证和来源说明,并注明项目来源为 Flyfish Viewer / `@flyfish-group/file-viewer3` 或 `@flyfish-group/file-viewer`。如果你基于本项目修复了通用问题或增强了通用能力,也欢迎通过 issue / PR 一起贡献回来,让这套预览能力继续变得更稳。
|