mirror of
https://github.com/open-webui/open-webui.git
synced 2025-12-12 20:35:19 +00:00
69 lines
1.5 KiB
Svelte
69 lines
1.5 KiB
Svelte
<script>
|
|
import { marked } from 'marked';
|
|
import { replaceTokens, processResponseContent } from '$lib/utils';
|
|
import { user } from '$lib/stores';
|
|
|
|
import markedExtension from '$lib/utils/marked/extension';
|
|
import markedKatexExtension from '$lib/utils/marked/katex-extension';
|
|
import { mentionExtension } from '$lib/utils/marked/mention-extension';
|
|
|
|
import MarkdownTokens from './Markdown/MarkdownTokens.svelte';
|
|
|
|
export let id = '';
|
|
export let content;
|
|
export let done = true;
|
|
export let model = null;
|
|
export let save = false;
|
|
export let preview = false;
|
|
|
|
export let editCodeBlock = true;
|
|
export let topPadding = false;
|
|
|
|
export let sourceIds = [];
|
|
|
|
export let onSave = () => {};
|
|
export let onUpdate = () => {};
|
|
|
|
export let onPreview = () => {};
|
|
|
|
export let onSourceClick = () => {};
|
|
export let onTaskClick = () => {};
|
|
|
|
let tokens = [];
|
|
|
|
const options = {
|
|
throwOnError: false,
|
|
breaks: true
|
|
};
|
|
|
|
marked.use(markedKatexExtension(options));
|
|
marked.use(markedExtension(options));
|
|
marked.use({
|
|
extensions: [mentionExtension({ triggerChar: '@' }), mentionExtension({ triggerChar: '#' })]
|
|
});
|
|
|
|
$: (async () => {
|
|
if (content) {
|
|
tokens = marked.lexer(
|
|
replaceTokens(processResponseContent(content), sourceIds, model?.name, $user?.name)
|
|
);
|
|
}
|
|
})();
|
|
</script>
|
|
|
|
{#key id}
|
|
<MarkdownTokens
|
|
{tokens}
|
|
{id}
|
|
{done}
|
|
{save}
|
|
{preview}
|
|
{editCodeBlock}
|
|
{topPadding}
|
|
{onTaskClick}
|
|
{onSourceClick}
|
|
{onSave}
|
|
{onUpdate}
|
|
{onPreview}
|
|
/>
|
|
{/key}
|