2024-03-20 04:16:05 +08:00
|
|
|
import { tick } from "svelte";
|
|
|
|
|
|
|
|
interface Value {
|
|
|
|
lines: number;
|
|
|
|
max_lines: number;
|
|
|
|
text: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function resize(
|
|
|
|
target: HTMLTextAreaElement | HTMLInputElement,
|
|
|
|
lines: number,
|
|
|
|
max_lines: number
|
|
|
|
): Promise<void> {
|
|
|
|
await tick();
|
|
|
|
if (lines === max_lines) return;
|
|
|
|
|
|
|
|
let max =
|
|
|
|
max_lines === undefined
|
|
|
|
? false
|
|
|
|
: max_lines === undefined // default
|
2024-05-03 16:57:08 +08:00
|
|
|
? 21 * 11
|
|
|
|
: 21 * (max_lines + 1);
|
2024-03-20 04:16:05 +08:00
|
|
|
let min = 21 * (lines + 1);
|
|
|
|
|
|
|
|
target.style.height = "1px";
|
|
|
|
|
|
|
|
let scroll_height;
|
|
|
|
if (max && target.scrollHeight > max) {
|
|
|
|
scroll_height = max;
|
|
|
|
} else if (target.scrollHeight < min) {
|
|
|
|
scroll_height = min;
|
|
|
|
} else {
|
|
|
|
scroll_height = target.scrollHeight;
|
|
|
|
}
|
|
|
|
|
|
|
|
target.style.height = `${scroll_height}px`;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function text_area_resize(
|
|
|
|
_el: HTMLTextAreaElement,
|
|
|
|
_value: Value
|
|
|
|
): any | undefined {
|
|
|
|
if (_value.lines === _value.max_lines) return;
|
|
|
|
_el.style.overflowY = "scroll";
|
|
|
|
_el.addEventListener("input", (event: Event) =>
|
|
|
|
resize(event.target as HTMLTextAreaElement, _value.lines, _value.max_lines)
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!_value.text.trim()) return;
|
|
|
|
resize(_el, _value.lines, _value.max_lines);
|
|
|
|
|
|
|
|
return {
|
|
|
|
destroy: () =>
|
|
|
|
_el.removeEventListener("input", (e: Event) =>
|
|
|
|
resize(e.target as HTMLTextAreaElement, _value.lines, _value.max_lines)
|
|
|
|
)
|
|
|
|
};
|
|
|
|
}
|