-
Notifications
You must be signed in to change notification settings - Fork 0
/
svelte.config.js
62 lines (57 loc) · 1.35 KB
/
svelte.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import adapter from "@sveltejs/adapter-node";
import { vitePreprocess } from "@sveltejs/vite-plugin-svelte";
import { mdsvex } from "mdsvex";
import {
createShikiHighlighter,
runTwoSlash,
renderCodeToHTML,
} from "shiki-twoslash";
import rehypeExternalLinks from "rehype-external-links";
import remarkGfm from "remark-gfm";
import rehypeSlug from "rehype-slug";
/** @type {import('@sveltejs/kit').Config} */
const config = {
extensions: [".svelte", ".md"],
preprocess: [
vitePreprocess(),
mdsvex({
extensions: [".md"],
smartypants: {
dashes: "oldschool",
},
rehypePlugins: [
rehypeSlug,
[
rehypeExternalLinks,
{
target: "_blank",
rel: ["noopener", "noreferrer"],
},
],
],
remarkPlugins: [remarkGfm],
}),
],
highlight: {
highlighter: async (code, lang = "text") => {
const highlighter = await createShikiHighlighter();
let twoslashResults = null;
if (meta?.includes("twoslash")) {
twoslashResults = runTwoSlash(code, lang, {});
}
const html = renderCodeToHTML(
code,
lang,
meta || [],
{},
highlighter,
twoslashResults
);
return `{@html \`${html}\` }`;
},
},
kit: {
adapter: adapter(),
},
};
export default config;