| <script lang="ts"> |
| import { DropdownMenu } from 'bits-ui'; |
| import { createEventDispatcher } from 'svelte'; |
| |
| import { flyAndScale } from '$lib/utils/transitions'; |
| import { WEBUI_BASE_URL } from '$lib/constants'; |
| import { activeUserIds } from '$lib/stores'; |
| |
| export let side = 'right'; |
| export let align = 'top'; |
| |
| export let user = null; |
| let show = false; |
| |
| const dispatch = createEventDispatcher(); |
| </script> |
|
|
| <DropdownMenu.Root |
| bind:open={show} |
| closeFocus={false} |
| onOpenChange={(state) => { |
| dispatch('change', state); |
| }} |
| typeahead={false} |
| > |
| <DropdownMenu.Trigger> |
| <slot /> |
| </DropdownMenu.Trigger> |
|
|
| <slot name="content"> |
| <DropdownMenu.Content |
| class="max-w-full w-[240px] rounded-lg z-[9999] bg-white dark:bg-black dark:text-white shadow-lg" |
| sideOffset={8} |
| {side} |
| {align} |
| transition={flyAndScale} |
| > |
| {#if user} |
| <div class=" flex flex-col gap-2 w-full rounded-lg"> |
| <div class="py-8 relative bg-gray-900 rounded-t-lg"> |
| <img |
| crossorigin="anonymous" |
| src={user?.profile_image_url ?? `${WEBUI_BASE_URL}/static/favicon.png`} |
| class=" absolute -bottom-5 left-3 size-12 ml-0.5 object-cover rounded-full -translate-y-[1px]" |
| alt="profile" |
| /> |
| </div> |
|
|
| <div class=" flex flex-col pt-4 pb-2.5 px-4"> |
| <div class=" -mb-1"> |
| <span class="font-medium text-sm line-clamp-1"> {user.name} </span> |
| </div> |
|
|
| <div class=" flex items-center gap-2"> |
| {#if $activeUserIds.includes(user.id)} |
| <div> |
| <span class="relative flex size-2"> |
| <span |
| class="animate-ping absolute inline-flex h-full w-full rounded-full bg-green-400 opacity-75" |
| /> |
| <span class="relative inline-flex rounded-full size-2 bg-green-500" /> |
| </span> |
| </div> |
|
|
| <div class=" -translate-y-[1px]"> |
| <span class="text-xs"> Active </span> |
| </div> |
| {:else} |
| <div> |
| <span class="relative flex size-2"> |
| <span class="relative inline-flex rounded-full size-2 bg-gray-500" /> |
| </span> |
| </div> |
|
|
| <div class=" -translate-y-[1px]"> |
| <span class="text-xs"> Away </span> |
| </div> |
| {/if} |
| </div> |
| </div> |
| </div> |
| {/if} |
| </DropdownMenu.Content> |
| </slot> |
| </DropdownMenu.Root> |
|
|