37 lines
989 B
JavaScript
37 lines
989 B
JavaScript
|
import adapter from '@sveltejs/adapter-vercel'
|
||
|
import { vitePreprocess } from '@sveltejs/kit/vite'
|
||
|
|
||
|
import { mdsvex, escapeSvelte } from 'mdsvex'
|
||
|
import shiki from 'shiki'
|
||
|
import remarkUnwrapImages from 'remark-unwrap-images'
|
||
|
import remarkToc from 'remark-toc'
|
||
|
import rehypeSlug from 'rehype-slug'
|
||
|
|
||
|
/** @type {import('mdsvex').MdsvexOptions} */
|
||
|
const mdsvexOptions = {
|
||
|
extensions: ['.md'],
|
||
|
layout: {
|
||
|
_: './src/mdsvex.svelte'
|
||
|
},
|
||
|
highlight: {
|
||
|
highlighter: async (code, lang = 'text') => {
|
||
|
const highlighter = await shiki.getHighlighter({ theme: 'poimandres' })
|
||
|
const html = escapeSvelte(highlighter.codeToHtml(code, { lang }))
|
||
|
return `{@html \`${html}\` }`
|
||
|
}
|
||
|
},
|
||
|
remarkPlugins: [remarkUnwrapImages, [remarkToc, { tight: true }]],
|
||
|
rehypePlugins: [rehypeSlug]
|
||
|
}
|
||
|
|
||
|
/** @type {import('@sveltejs/kit').Config} */
|
||
|
const config = {
|
||
|
extensions: ['.svelte', '.md'],
|
||
|
preprocess: [vitePreprocess(), mdsvex(mdsvexOptions)],
|
||
|
kit: {
|
||
|
adapter: adapter()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
export default config
|