Skip to content

Commit 28728fa

Browse files
committed
perf: register marked extensions once at module load
1 parent effa8b8 commit 28728fa

1 file changed

Lines changed: 28 additions & 25 deletions

File tree

src/lib/components/chat/Messages/Markdown.svelte

Lines changed: 28 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,41 @@
1-
<script>
2-
import { onDestroy } from 'svelte';
1+
<script context="module">
32
import { marked } from 'marked';
4-
import { replaceTokens, processResponseContent } from '$lib/utils';
5-
import { user } from '$lib/stores';
63
74
import markedExtension from '$lib/utils/marked/extension';
85
import markedKatexExtension from '$lib/utils/marked/katex-extension';
96
import { disableSingleTilde } from '$lib/utils/marked/strikethrough-extension';
107
import { mentionExtension } from '$lib/utils/marked/mention-extension';
118
import colonFenceExtension from '$lib/utils/marked/colon-fence-extension';
12-
13-
import MarkdownTokens from './Markdown/MarkdownTokens.svelte';
149
import footnoteExtension from '$lib/utils/marked/footnote-extension';
1510
import citationExtension from '$lib/utils/marked/citation-extension';
1611
12+
const options = {
13+
throwOnError: false,
14+
breaks: true
15+
};
16+
17+
marked.use(markedKatexExtension(options));
18+
marked.use(markedExtension(options));
19+
marked.use(citationExtension(options));
20+
marked.use(footnoteExtension(options));
21+
marked.use(colonFenceExtension(options));
22+
marked.use(disableSingleTilde);
23+
marked.use({
24+
extensions: [
25+
mentionExtension({ triggerChar: '@' }),
26+
mentionExtension({ triggerChar: '#' }),
27+
mentionExtension({ triggerChar: '$' })
28+
]
29+
});
30+
</script>
31+
32+
<script>
33+
import { onDestroy } from 'svelte';
34+
import { replaceTokens, processResponseContent } from '$lib/utils';
35+
import { user } from '$lib/stores';
36+
37+
import MarkdownTokens from './Markdown/MarkdownTokens.svelte';
38+
1739
export let id = '';
1840
export let content;
1941
export let done = true;
@@ -40,25 +62,6 @@
4062
let lastContent = '';
4163
let lastParsedContent = '';
4264
43-
const options = {
44-
throwOnError: false,
45-
breaks: true
46-
};
47-
48-
marked.use(markedKatexExtension(options));
49-
marked.use(markedExtension(options));
50-
marked.use(citationExtension(options));
51-
marked.use(footnoteExtension(options));
52-
marked.use(colonFenceExtension(options));
53-
marked.use(disableSingleTilde);
54-
marked.use({
55-
extensions: [
56-
mentionExtension({ triggerChar: '@' }),
57-
mentionExtension({ triggerChar: '#' }),
58-
mentionExtension({ triggerChar: '$' })
59-
]
60-
});
61-
6265
const parseTokens = () => {
6366
if (content === lastContent) return;
6467
lastContent = content;

0 commit comments

Comments
 (0)