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
				? 21 * 11
				: 21 * (max_lines + 1);
	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)
			)
	};
}