open-webui/src/lib/components/chat/MessageInput/Commands.svelte

81 lines
1.9 KiB
Svelte
Raw Normal View History

2024-08-23 12:31:39 +00:00
<script>
import { createEventDispatcher } from 'svelte';
import { toast } from 'svelte-sonner';
const dispatch = createEventDispatcher();
import Prompts from './Commands/Prompts.svelte';
2024-10-02 05:45:04 +00:00
import Knowledge from './Commands/Knowledge.svelte';
2024-08-23 12:31:39 +00:00
import Models from './Commands/Models.svelte';
import { removeLastWordFromString } from '$lib/utils';
2024-09-28 00:23:09 +00:00
import { processWeb, processYoutubeVideo } from '$lib/apis/retrieval';
2024-08-23 12:31:39 +00:00
export let prompt = '';
export let files = [];
let commandElement = null;
export const selectUp = () => {
commandElement?.selectUp();
};
export const selectDown = () => {
commandElement?.selectDown();
};
let command = '';
2024-10-19 23:18:14 +00:00
$: command = prompt?.split('\n').pop()?.split(' ')?.pop() ?? '';
2024-08-23 12:31:39 +00:00
</script>
2024-10-19 06:54:35 +00:00
{#if ['/', '#', '@'].includes(command?.charAt(0)) || '\\#' === command.slice(0, 2)}
2024-08-23 12:31:39 +00:00
{#if command?.charAt(0) === '/'}
<Prompts bind:this={commandElement} bind:prompt bind:files {command} />
2024-10-19 20:40:20 +00:00
{:else if (command?.charAt(0) === '#' && command.startsWith('#') && !command.includes('# ')) || ('\\#' === command.slice(0, 2) && command.startsWith('#') && !command.includes('# '))}
2024-10-02 05:45:04 +00:00
<Knowledge
2024-08-23 12:31:39 +00:00
bind:this={commandElement}
bind:prompt
2024-10-19 06:54:35 +00:00
command={command.includes('\\#') ? command.slice(2) : command}
2024-08-23 12:31:39 +00:00
on:youtube={(e) => {
console.log(e);
2024-10-08 01:19:13 +00:00
dispatch('upload', {
type: 'youtube',
data: e.detail
});
2024-08-23 12:31:39 +00:00
}}
on:url={(e) => {
console.log(e);
2024-10-08 01:19:13 +00:00
dispatch('upload', {
type: 'web',
data: e.detail
});
2024-08-23 12:31:39 +00:00
}}
on:select={(e) => {
console.log(e);
files = [
...files,
{
...e.detail,
status: 'processed'
}
];
dispatch('select');
}}
/>
{:else if command?.charAt(0) === '@'}
<Models
bind:this={commandElement}
{command}
on:select={(e) => {
prompt = removeLastWordFromString(prompt, command);
dispatch('select', {
type: 'model',
data: e.detail
});
}}
/>
{/if}
{/if}