Anki/ts/routes/deck-options/ParamsInput.svelte
llama 97b12b420a
Resize fsrs params input to fit content (#3999)
* resize param input on value change

* resize on window resize
2025-05-15 16:41:30 +10:00

47 lines
1.1 KiB
Svelte

<!--
Copyright: Ankitects Pty Ltd and contributors
License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
-->
<script lang="ts">
import { tick } from "svelte";
export let value: number[];
export let defaults: number[];
let stringValue: string;
let taRef: HTMLTextAreaElement;
function updateHeight() {
if (taRef) {
taRef.style.height = "auto";
taRef.style.height = `${taRef.scrollHeight}px`;
}
}
$: {
stringValue = render(value);
tick().then(updateHeight);
}
function render(params: number[]): string {
return params.map((v) => v.toFixed(4)).join(", ");
}
function update(this: HTMLInputElement): void {
value = this.value
.replace(/ /g, "")
.split(",")
.filter((e) => e)
.map((v) => Number(v));
}
</script>
<svelte:window onresize={updateHeight} />
<textarea
bind:this={taRef}
value={stringValue}
on:blur={update}
class="w-100"
placeholder={render(defaults)}
></textarea>