Search code examples
importmarkdownsveltekit

How to import Markdown files in SvelteKit?


<script>
    import Markdown from '../components/Markdown.svelte';
    import path from '../../static/assets/docs/overview.md';
</script>

<article class="prose prose-red max-w-none">
    <Markdown markdown={path} />
</article>

Here's the warning:

files in the public directory are served at the root path.
Instead of /static/assets/docs/overview.md?import, use /assets/docs/overview.md?import.

If I use import path from '/assets/docs/overview.md'; I get the following error:

9:30:18 PM [vite] Internal server error: Cannot import non-asset file /assets/docs/overview.md which is inside /public.JS/CSS files inside /public are copied as-is on build and can only be referenced via <script src> or <link href> in html.
  Plugin: vite:import-analysis
  File: /Users/me/www/underwriting-ui/src/routes/docs.svelte
      at TransformContext.transform (/Users/me/www/underwriting-ui/node_modules/vite/dist/node/chunks/dep-713b45e1.js:67350:31)
      at async Object.transform (/Users/me/www/underwriting-ui/node_modules/vite/dist/node/chunks/dep-713b45e1.js:42397:30)
      at async doTransform (/Users/me/www/underwriting-ui/node_modules/vite/dist/node/chunks/dep-713b45e1.js:56738:29)

Solution

  • I have the same scenario - documentation in static markdown from which I need to generate HTML at build time. I ended up using vite-plugin-markdown.

    add this to your vite.config.js

    import { Mode, plugin as markdown } from 'vite-plugin-markdown'
    
    const config = {
      plugins: [markdown({ mode: [Mode.HTML, Mode.TOC], ...})], ...
    }
    

    then in your svelte component

    import { toc, html } from '~/docs/api/auth.md'
    

    I'm especially happy about "toc", which outputs something like:

    [{ level: '1', content: 'foo' }, { level: '2', content: 'bar' }, ...]