Spaces:
				
			
			
	
			
			
		Paused
		
	
	
	
			
			
	
	
	
	
		
		
		Paused
		
	| <script lang="ts"> | |
| import { WEBUI_BASE_URL } from '$lib/constants'; | |
| import { Handle, Position, type NodeProps } from '@xyflow/svelte'; | |
| import ProfileImageBase from '../Messages/ProfileImageBase.svelte'; | |
| import Tooltip from '$lib/components/common/Tooltip.svelte'; | |
| import Heart from '$lib/components/icons/Heart.svelte'; | |
| type $$Props = NodeProps; | |
| export let data: $$Props['data']; | |
| </script> | |
| <div | |
| class="px-4 py-3 shadow-md rounded-xl dark:bg-black bg-white border dark:border-gray-900 w-60 h-20 group" | |
| > | |
| <Tooltip | |
| content={data?.message?.error ? data.message.error.content : data.message.content} | |
| class="w-full" | |
| allowHTML={false} | |
| > | |
| {#if data.message.role === 'user'} | |
| <div class="flex w-full"> | |
| <ProfileImageBase | |
| src={data.user?.profile_image_url ?? '/user.png'} | |
| className={'size-5 -translate-y-[1px]'} | |
| /> | |
| <div class="ml-2"> | |
| <div class=" flex justify-between items-center"> | |
| <div class="text-xs text-black dark:text-white font-medium line-clamp-1"> | |
| {data?.user?.name ?? 'User'} | |
| </div> | |
| </div> | |
| {#if data?.message?.error} | |
| <div class="text-red-500 line-clamp-2 text-xs mt-0.5">{data.message.error.content}</div> | |
| {:else} | |
| <div class="text-gray-500 line-clamp-2 text-xs mt-0.5">{data.message.content}</div> | |
| {/if} | |
| </div> | |
| </div> | |
| {:else} | |
| <div class="flex w-full"> | |
| <ProfileImageBase | |
| src={data?.model?.info?.meta?.profile_image_url ?? ''} | |
| className={'size-5 -translate-y-[1px]'} | |
| /> | |
| <div class="ml-2"> | |
| <div class=" flex justify-between items-center"> | |
| <div class="text-xs text-black dark:text-white font-medium line-clamp-1"> | |
| {data?.model?.name ?? data?.message?.model ?? 'Assistant'} | |
| </div> | |
| <button | |
| class={data?.message?.favorite ? '' : 'invisible group-hover:visible'} | |
| on:click={() => { | |
| data.message.favorite = !(data?.message?.favorite ?? false); | |
| }} | |
| > | |
| <Heart | |
| className="size-3 {data?.message?.favorite | |
| ? 'fill-red-500 stroke-red-500' | |
| : 'hover:fill-red-500 hover:stroke-red-500'} " | |
| strokeWidth="2.5" | |
| /> | |
| </button> | |
| </div> | |
| {#if data?.message?.error} | |
| <div class="text-red-500 line-clamp-2 text-xs mt-0.5"> | |
| {data.message.error.content} | |
| </div> | |
| {:else} | |
| <div class="text-gray-500 line-clamp-2 text-xs mt-0.5">{data.message.content}</div> | |
| {/if} | |
| </div> | |
| </div> | |
| {/if} | |
| </Tooltip> | |
| <Handle type="target" position={Position.Top} class="w-2 rounded-full dark:bg-gray-900" /> | |
| <Handle type="source" position={Position.Bottom} class="w-2 rounded-full dark:bg-gray-900" /> | |
| </div> | |
