Spaces:
Build error
Build error
| <script lang="ts"> | |
| import { getContext } from 'svelte'; | |
| import { goto } from '$app/navigation'; | |
| import Dropdown from '$lib/components/common/Dropdown.svelte'; | |
| import Tooltip from '$lib/components/common/Tooltip.svelte'; | |
| import Pin from '$lib/components/icons/Pin.svelte'; | |
| import PinSlash from '$lib/components/icons/PinSlash.svelte'; | |
| import Link from '$lib/components/icons/Link.svelte'; | |
| import Pencil from '$lib/components/icons/Pencil.svelte'; | |
| import { config, settings, user } from '$lib/stores'; | |
| import GlobeAlt from '$lib/components/icons/GlobeAlt.svelte'; | |
| const i18n = getContext('i18n'); | |
| export let show = false; | |
| export let model; | |
| export let pinModelHandler: (modelId: string) => void = () => {}; | |
| export let copyLinkHandler: Function = () => {}; | |
| export let deleteModelHandler: Function = () => {}; | |
| export let onClose: Function = () => {}; | |
| </script> | |
| <Dropdown | |
| bind:show | |
| align="end" | |
| sideOffset={-2} | |
| onOpenChange={(state) => { | |
| if (state === false) { | |
| onClose(); | |
| } | |
| }} | |
| > | |
| <Tooltip | |
| content={$i18n.t('More')} | |
| className={($settings?.highContrastMode ?? false) | |
| ? '' | |
| : 'group-hover/item:opacity-100 opacity-0'} | |
| > | |
| <slot /> | |
| </Tooltip> | |
| <div slot="content"> | |
| <div | |
| class="min-w-[210px] text-sm rounded-2xl p-1 z-[9999999] bg-white dark:bg-gray-850 dark:text-white shadow-lg border border-gray-100 dark:border-gray-800" | |
| > | |
| {#if model?.preset || model?.info?.base_model_id ? model?.info?.user_id === $user?.id : $user?.role === 'admin'} | |
| <button | |
| type="button" | |
| class="select-none flex rounded-xl py-1.5 px-3 w-full hover:bg-gray-50 dark:hover:bg-gray-800 transition items-center gap-2" | |
| on:click={(e) => { | |
| e.stopPropagation(); | |
| e.preventDefault(); | |
| goto( | |
| model?.preset || model?.info?.base_model_id | |
| ? `/workspace/models/edit?id=${encodeURIComponent(model?.id ?? '')}` | |
| : `/admin/settings/models?id=${encodeURIComponent(model?.id ?? '')}` | |
| ); | |
| show = false; | |
| }} | |
| > | |
| <Pencil className="size-4" /> | |
| <div class="flex items-center">{$i18n.t('Edit')}</div> | |
| </button> | |
| {#if $user?.role === 'admin' && model?.owned_by === 'ollama'} | |
| <button | |
| type="button" | |
| class="select-none flex rounded-xl py-1.5 px-3 w-full hover:bg-gray-50 dark:hover:bg-gray-800 transition items-center gap-2" | |
| on:click={(e) => { | |
| e.stopPropagation(); | |
| e.preventDefault(); | |
| deleteModelHandler(model); | |
| show = false; | |
| }} | |
| > | |
| <svg | |
| xmlns="http://www.w3.org/2000/svg" | |
| fill="none" | |
| viewBox="0 0 24 24" | |
| stroke-width="1.5" | |
| stroke="currentColor" | |
| class="size-4" | |
| > | |
| <path | |
| stroke-linecap="round" | |
| stroke-linejoin="round" | |
| d="m14.74 9-.346 9m-4.788 0L9.26 9m9.968-3.21c.342.052.682.107 1.022.166m-1.022-.165L18.16 19.673a2.25 2.25 0 0 1-2.244 2.077H8.084a2.25 2.25 0 0 1-2.244-2.077L4.772 5.79m14.456 0a48.108 48.108 0 0 0-3.478-.397m-12 .562c.34-.059.68-.114 1.022-.165m0 0a48.11 48.11 0 0 1 3.478-.397m7.5 0v-.916c0-1.18-.91-2.164-2.09-2.201a51.964 51.964 0 0 0-3.32 0c-1.18.037-2.09 1.022-2.09 2.201v.916m7.5 0a48.667 48.667 0 0 0-7.5 0" | |
| /> | |
| </svg> | |
| <div class="flex items-center">{$i18n.t('Delete')}</div> | |
| </button> | |
| {/if} | |
| <hr class="border-gray-50 dark:border-gray-800/30 my-1" /> | |
| {/if} | |
| <button | |
| type="button" | |
| aria-pressed={($settings?.pinnedModels ?? []).includes(model?.id)} | |
| class="select-none flex rounded-xl py-1.5 px-3 w-full hover:bg-gray-50 dark:hover:bg-gray-800 transition items-center gap-2" | |
| on:click={(e) => { | |
| e.stopPropagation(); | |
| e.preventDefault(); | |
| pinModelHandler(model?.id); | |
| show = false; | |
| }} | |
| > | |
| {#if ($settings?.pinnedModels ?? []).includes(model?.id)} | |
| <PinSlash /> | |
| {:else} | |
| <Pin /> | |
| {/if} | |
| <div class="flex items-center"> | |
| {#if ($settings?.pinnedModels ?? []).includes(model?.id)} | |
| {$i18n.t('Hide from Sidebar')} | |
| {:else} | |
| {$i18n.t('Keep in Sidebar')} | |
| {/if} | |
| </div> | |
| </button> | |
| <button | |
| type="button" | |
| class="select-none flex rounded-xl py-1.5 px-3 w-full hover:bg-gray-50 dark:hover:bg-gray-800 transition items-center gap-2" | |
| on:click={(e) => { | |
| e.stopPropagation(); | |
| e.preventDefault(); | |
| copyLinkHandler(); | |
| show = false; | |
| }} | |
| > | |
| <Link /> | |
| <div class="flex items-center">{$i18n.t('Copy Link')}</div> | |
| </button> | |
| {#if $config?.features.enable_community_sharing} | |
| <hr class="border-gray-50 dark:border-gray-800/30 my-1" /> | |
| <button | |
| type="button" | |
| class="select-none flex rounded-xl py-1.5 px-3 w-full hover:bg-gray-50 dark:hover:bg-gray-800 transition items-center gap-2" | |
| on:click={(e) => { | |
| e.stopPropagation(); | |
| e.preventDefault(); | |
| window.open( | |
| `https://openwebui.com/models?q=${encodeURIComponent(model?.id ?? '')}`, | |
| '_blank' | |
| ); | |
| show = false; | |
| }} | |
| > | |
| <GlobeAlt className="size-4" /> | |
| <div class="flex items-center">{$i18n.t('Community Reviews')}</div> | |
| </button> | |
| {/if} | |
| </div> | |
| </div> | |
| </Dropdown> | |