mirror of
https://github.com/open-webui/open-webui.git
synced 2025-12-12 12:25:20 +00:00
71 lines
1.9 KiB
Svelte
71 lines
1.9 KiB
Svelte
<script lang="ts">
|
|
import Tooltip from '$lib/components/common/Tooltip.svelte';
|
|
import { tick, getContext, onMount, onDestroy } from 'svelte';
|
|
import { toast } from 'svelte-sonner';
|
|
|
|
const i18n = getContext('i18n');
|
|
|
|
export let query = '';
|
|
export let prompts = [];
|
|
export let onSelect = (e) => {};
|
|
|
|
let selectedPromptIdx = 0;
|
|
export let filteredItems = [];
|
|
|
|
$: filteredItems = prompts
|
|
.filter((p) => p.command.toLowerCase().includes(query.toLowerCase()))
|
|
.sort((a, b) => a.title.localeCompare(b.title));
|
|
|
|
$: if (query) {
|
|
selectedPromptIdx = 0;
|
|
}
|
|
|
|
export const selectUp = () => {
|
|
selectedPromptIdx = Math.max(0, selectedPromptIdx - 1);
|
|
};
|
|
export const selectDown = () => {
|
|
selectedPromptIdx = Math.min(selectedPromptIdx + 1, filteredItems.length - 1);
|
|
};
|
|
|
|
export const select = async () => {
|
|
const command = filteredItems[selectedPromptIdx];
|
|
if (command) {
|
|
onSelect({ type: 'prompt', data: command });
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<div class="px-2 text-xs text-gray-500 py-1">
|
|
{$i18n.t('Prompts')}
|
|
</div>
|
|
|
|
{#if filteredItems.length > 0}
|
|
<div class=" space-y-0.5 scrollbar-hidden">
|
|
{#each filteredItems as promptItem, promptIdx}
|
|
<Tooltip content={promptItem.title} placement="top-start">
|
|
<button
|
|
class=" px-3 py-1 rounded-xl w-full text-left {promptIdx === selectedPromptIdx
|
|
? ' bg-gray-50 dark:bg-gray-800 selected-command-option-button'
|
|
: ''} truncate"
|
|
type="button"
|
|
on:click={() => {
|
|
onSelect({ type: 'prompt', data: promptItem });
|
|
}}
|
|
on:mousemove={() => {
|
|
selectedPromptIdx = promptIdx;
|
|
}}
|
|
on:focus={() => {}}
|
|
data-selected={promptIdx === selectedPromptIdx}
|
|
>
|
|
<span class=" font-medium text-black dark:text-gray-100">
|
|
{promptItem.command}
|
|
</span>
|
|
|
|
<span class=" text-xs text-gray-600 dark:text-gray-100">
|
|
{promptItem.title}
|
|
</span>
|
|
</button>
|
|
</Tooltip>
|
|
{/each}
|
|
</div>
|
|
{/if}
|