Skip to content

EN On Demand Renderers

小爬的老粉丝 edited this page Jun 25, 2026 · 1 revision

Modular And On-demand Renderers

Small When You Can, Complete When You Need

The 2.1.0 architecture lets teams choose minimal renderer imports, product-shaped presets, or the complete official demo capability set.

Minimal Import

For a PDF-only Vue 3 product:

npm install @file-viewer/vue3 @file-viewer/renderer-pdf
import { pdfRenderer } from '@file-viewer/renderer-pdf'

const options = {
  rendererMode: 'replace',
  renderers: [pdfRenderer]
}

This path is bundler-neutral and works in Webpack, Rspack, Rollup, Umi, classic multi-page apps, and micro-frontends. Vite projects can add the plugin to generate and inject the renderer import automatically:

npm install -D @file-viewer/vite-plugin
import { defineConfig } from 'vite'
import { fileViewerRenderers } from '@file-viewer/vite-plugin'

export default defineConfig({
  plugins: [
    fileViewerRenderers({
      formats: ['pdf'],
      copyAssets: true,
      chunkStrategy: 'renderer'
    })
  ]
})

Presets

Preset Best for
@file-viewer/preset-lite Text, code, Markdown, image, audio, and video attachments
@file-viewer/preset-office PDF, Word, spreadsheet, presentation, OFD, and OpenDocument workflows
@file-viewer/preset-engineering CAD, EDA, Typst, archives, email, data, 3D, geo, drawing, and mind maps
@file-viewer/preset-all Admin workbenches and demos that need every official renderer

Renderer Package Reference

Install a single renderer when a product needs the smallest possible capability set:

Renderer package Export Main pipeline
@file-viewer/renderer-pdf pdfRenderer PDF
@file-viewer/renderer-word wordRenderer DOCX, DOC, DOT, RTF, ODT
@file-viewer/renderer-spreadsheet spreadsheetRenderer Excel, OpenDocument spreadsheet, CSV-like tables
@file-viewer/renderer-presentation presentationRenderer PPT / PPTX and presentation files
@file-viewer/renderer-ofd ofdRenderer OFD
@file-viewer/renderer-cad cadRenderer DWG, DXF, DWF, DWFx, XPS
@file-viewer/renderer-3d modelRenderer 3D models and lightweight geometry signatures
@file-viewer/renderer-drawing drawingRenderer draw.io, Excalidraw, Mermaid, PlantUML
@file-viewer/renderer-mindmap mindmapRenderer XMind
@file-viewer/renderer-geo geoRenderer GeoJSON, KML, GPX, SHP
@file-viewer/renderer-typst typstRenderer Typst source rendered through local WASM assets
@file-viewer/renderer-archive archiveRenderer Archives and nested file preview
@file-viewer/renderer-email emailRenderer EML, MSG, MBOX
@file-viewer/renderer-epub ebookRenderer EPUB, UMD
@file-viewer/renderer-text textRenderer Markdown, highlighted code, patch, git bundle
@file-viewer/renderer-image imageRenderer Image and HEIC / HEIF paths
@file-viewer/renderer-media mediaRenderer Audio, video, HLS, MIDI summaries
@file-viewer/renderer-data dataRenderer PSD, fonts, SQLite, Parquet, Avro, WASM, WebArchive
@file-viewer/renderer-eda edaRenderer OLB, DRA, GDS, OAS/OASIS

Engine packages such as @file-viewer/pptx, @file-viewer/geometry-engine, @file-viewer/eda-layout, and @file-viewer/eda-orcad are maintained for renderer internals and advanced reuse. Normal viewer integrations should use the renderer or preset package above.

Automatic Preset Assembly

For an Office document platform, the bundler-neutral path is:

npm install @file-viewer/vue3 @file-viewer/preset-office
import officePreset from '@file-viewer/preset-office'

const options = {
  rendererMode: 'replace',
  preset: officePreset
}

@file-viewer/vite-plugin can discover installed presets and inject the generated virtual module into the Vite HTML entry. In Vite projects, add the plugin once and the framework component automatically receives that preview capability without a manual preset import:

npm install -D @file-viewer/vite-plugin
fileViewerRenderers({
  copyAssets: true
  // No preset option required: installed @file-viewer/preset-* packages are discovered.
})

inject defaults to true. Preset packages register themselves in core when imported, and FileViewerOptions.autoRenderers defaults to true in normal extend mode. Set autoRenderers:false only when a product needs full manual control.

The default experience is intentionally zero-config: if the plugin receives no explicit preset, formats, or renderers, or only receives copyAssets:true, it auto-discovers installed @file-viewer/preset-* packages. preset-all takes precedence when present; otherwise installed lite, office, and engineering presets are composed.

Install @file-viewer/preset-all when a heavy user wants the fastest full-capability setup:

npm install @file-viewer/vue3 @file-viewer/preset-all
# Vite projects add the plugin:
npm install -D @file-viewer/vite-plugin

Use preset:'auto' or autoPresets:true when you also enable scan:true; this keeps installed preset discovery active while source hints add extra renderers. If preset-all is installed, it takes precedence to avoid importing narrower presets twice.

fileViewerRenderers({
  preset: 'auto',
  scan: true,
  formats: ['pdf'],
  copyAssets: true,
  chunkStrategy: 'renderer'
})
Customization Purpose
copyAssets:true Copies matched Worker, WASM, font, PDF/CAD/Typst/Archive/Data, and vendor assets
preset:'auto' / autoPresets:true Keeps installed preset auto-discovery active together with scan:true
formats / renderers Adds a few formats outside a preset, or builds a strict single-renderer bundle
scan:true Collects format hints from fileViewerFormats, data-file-viewer-formats, accept, and similar source hints
inject:false Disables auto injection so application code imports virtual:file-viewer-renderers and passes options.renderers manually
chunkStrategy:'renderer' Uses renderer-level chunk names for caching and heavy-pipeline size debugging

Manual Control

Strict bundles can still use the virtual module directly:

fileViewerRenderers({
  formats: ['pdf'],
  inject: false,
  copyAssets: true
})
import { configuredFileViewerRenderers } from 'virtual:file-viewer-renderers'

const options = {
  rendererMode: 'replace',
  renderers: configuredFileViewerRenderers
}

scan:true detects hints such as fileViewerFormats, data-file-viewer-formats, and upload accept attributes, then merges them with explicit formats.

Missing Renderer Guidance

If a file extension is in the supported matrix but its renderer has not been assembled, the viewer shows a friendly install-oriented state. For example, opening .pdf without the PDF renderer recommends @file-viewer/preset-office or @file-viewer/renderer-pdf. Only extensions outside the matrix are shown as truly unsupported.

Asset Rules

Use copyAssets:true or npx file-viewer-copy-assets ./public/file-viewer for offline deployments. Worker, WASM, font, PDF, CAD, Typst, Archive, Data, and Draw.io assets should be served from your own domain.

Clone this wiki locally