inference-playground / src /lib /components /InferencePlayground /InferencePlaygroundMessage.svelte
mishig's picture
mishig HF staff
Restructure to have `InferencePlayground.svelte` component (#23)
1189124 unverified
raw
history blame
1.81 kB
<script lang="ts">
import { createEventDispatcher } from 'svelte';
import { type ChatCompletionInputMessage } from '@huggingface/tasks';
export let message: ChatCompletionInputMessage;
export let conversationIdx: number;
export let messageIdx: number;
export let autofocus: boolean = false;
const dispatch = createEventDispatcher<{
delete: void;
messageValueChanged: { conversationIdx: number; messageIdx: number; value: string };
}>();
</script>
<div
class="group/message group grid grid-cols-[1fr,2.5rem] items-start gap-2 px-3.5 pb-6 pt-4 hover:bg-gray-100/70 @2xl:grid-cols-[130px,1fr,2.5rem] @2xl:grid-rows-1 @2xl:gap-4 @2xl:px-6 dark:border-gray-800 dark:hover:bg-gray-800/30 {$$props.class}"
>
<div class="col-span-2 pb-1 pt-3 text-sm font-semibold uppercase @2xl:col-span-1 @2xl:pb-2">
{message.role}
</div>
<textarea
{autofocus}
value={message.content}
on:input={(e) =>
dispatch('messageValueChanged', { conversationIdx, messageIdx, value: e.target.value })}
placeholder="Enter {message.role} message"
class="resize-none rounded bg-transparent px-2 py-2.5 ring-gray-100 [field-sizing:content] hover:resize-y hover:bg-white focus:resize-y focus:bg-white focus:ring group-hover/message:ring @2xl:px-3 dark:ring-gray-600 dark:hover:bg-gray-900 dark:focus:bg-gray-900"
rows="1"
></textarea>
<button
tabindex="1"
on:click={() => {
dispatch('delete');
}}
type="button"
class="mt-1.5 hidden size-8 rounded-lg border border-gray-200 bg-white text-xs font-medium text-gray-900 hover:bg-gray-100 hover:text-blue-700 focus:z-10 focus:outline-none focus:ring-4 focus:ring-gray-100 group-hover/message:block dark:border-gray-600 dark:bg-gray-800 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white dark:focus:ring-gray-700"
>βœ•</button
>
</div>