mirror of
https://github.com/open-webui/open-webui.git
synced 2025-12-12 12:25:20 +00:00
57 lines
1.1 KiB
Svelte
57 lines
1.1 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 MarkdownTokens from './Markdown/MarkdownTokens.svelte';
|
|
|
|
export let id = '';
|
|
export let content;
|
|
export let model = null;
|
|
export let save = false;
|
|
export let preview = 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
|
|
};
|
|
|
|
marked.use(markedKatexExtension(options));
|
|
marked.use(markedExtension(options));
|
|
|
|
$: (async () => {
|
|
if (content) {
|
|
tokens = marked.lexer(
|
|
replaceTokens(processResponseContent(content), sourceIds, model?.name, $user?.name)
|
|
);
|
|
}
|
|
})();
|
|
</script>
|
|
|
|
{#key id}
|
|
<MarkdownTokens
|
|
{tokens}
|
|
{id}
|
|
{save}
|
|
{preview}
|
|
{onTaskClick}
|
|
{onSourceClick}
|
|
{onSave}
|
|
{onUpdate}
|
|
{onPreview}
|
|
/>
|
|
{/key}
|