diff options
| author | Owen Jacobson <owen@grimoire.ca> | 2025-05-13 20:40:23 -0400 |
|---|---|---|
| committer | Owen Jacobson <owen@grimoire.ca> | 2025-05-13 21:11:00 -0400 |
| commit | 61b3e3cba8a11a53947ce0e7c8a6980fb20ef914 (patch) | |
| tree | 987df3b61ba30b25efcc0bf395169d0c8b76a5aa /ui/lib/components | |
| parent | e623ab68e7f4d1a9bd8222aa8d8f5d9108a238c0 (diff) | |
Restore the placeholder when the editable input is emptied out after modification.
This also avoids using `placeholder` on elements where it's nonstandard, like `<div>`s.
Diffstat (limited to 'ui/lib/components')
| -rw-r--r-- | ui/lib/components/MessageInput.svelte | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/ui/lib/components/MessageInput.svelte b/ui/lib/components/MessageInput.svelte index b230939..cdb855e 100644 --- a/ui/lib/components/MessageInput.svelte +++ b/ui/lib/components/MessageInput.svelte @@ -4,6 +4,16 @@ let value = $state(''); let disabled = $state(false); + // Entering and removing text from the input area leaves a stray line break behind. This effect + // looks for that scenario and removes it, restoring the "empty" state (and bringing the + // placeholder back again in the process). + $effect(() => { + const trimmed = value.trim(); + if (trimmed !== value && trimmed === '') { + value = trimmed; + } + }); + async function onsubmit(event) { event.preventDefault(); disabled = true; @@ -48,7 +58,7 @@ bind:innerText={value} {onkeydown} {onpaste} - placeholder="Say something..." + data-placeholder="Say something..." ></div> <button type="submit">»</button> </form> |
