File size: 1,545 Bytes
39eb06d
60216ec
4b8b411
39eb06d
38434c2
9885691
39eb06d
f6138b3
39eb06d
 
 
42614e7
39eb06d
c32d95e
9885691
 
39eb06d
9885691
251818f
39eb06d
c32d95e
39eb06d
 
 
 
 
60216ec
39eb06d
 
90f84fa
39eb06d
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<script lang="ts">
	import { type ChatCompletionInputMessage } from "@huggingface/tasks";
	import { createEventDispatcher } from "svelte";

	export let message: ChatCompletionInputMessage;
	export let autofocus: boolean = false;

	const dispatch = createEventDispatcher<{ delete: void }>();
</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}
		bind:value={message.content}
		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 sm: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>