feat: Make textarea submit on "Enter"
This commit is contained in:
		
							parent
							
								
									b95fdf09ef
								
							
						
					
					
						commit
						359a2c38ba
					
				| @ -1,6 +1,7 @@ | ||||
| import { db } from '$lib/server/db'; | ||||
| import type { TypeMessage } from '$lib/types'; | ||||
| import { error } from '@sveltejs/kit'; | ||||
| import type { Actions } from '@sveltejs/kit'; | ||||
| 
 | ||||
| export async function load({ params }): Promise<{ messages: TypeMessage[] }> { | ||||
|   let messages: TypeMessage[]; | ||||
| @ -25,3 +26,7 @@ export async function load({ params }): Promise<{ messages: TypeMessage[] }> { | ||||
|     messages: messages ?? [], | ||||
|   }; | ||||
| } | ||||
| 
 | ||||
| export const actions = { | ||||
|   sendMessage: async ({ request }) => {}, | ||||
| } satisfies Actions; | ||||
|  | ||||
| @ -18,11 +18,20 @@ | ||||
|   let msg: string = $state(''); | ||||
|   const channel: string = $derived(page.params.channel); | ||||
|   let textareaRef: HTMLElement | undefined = $state(); | ||||
|   let submitRef: HTMLButtonElement | undefined = $state(); | ||||
| 
 | ||||
|   // Connect on page load | ||||
|   onMount(() => { | ||||
|     // Connect on page load | ||||
|     socket = new Websocket(io()); | ||||
|     socket.connect(); | ||||
| 
 | ||||
|     // Submit on textarea enter | ||||
|     textareaRef?.addEventListener('keypress', (e) => { | ||||
|       if (e.key === 'Enter' && !e.shiftKey) { | ||||
|         e.preventDefault(); | ||||
|         submitRef?.click(); | ||||
|       } | ||||
|     }); | ||||
|   }); | ||||
| 
 | ||||
|   // Update channel on page refresh | ||||
| @ -61,5 +70,6 @@ | ||||
|       placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring | ||||
|        disabled:cursor-not-allowed disabled:opacity-50"></textarea> | ||||
|     <Button class="h-full min-h-10 w-14" type="submit"><Send class="size-full" /></Button> | ||||
|     <button type="submit" bind:this={submitRef} class="hidden">submit</button> | ||||
|   </form> | ||||
| </div> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user