import { requestTicket, goToPage, deleteAllCookies, requestPVE, setTitleAndHeader } from "./utils.js";
import { alert } from "./dialog.js";

window.addEventListener("DOMContentLoaded", init);

async function init() {
	setTitleAndHeader();
	await deleteAllCookies();
	let formSubmitButton = document.querySelector("#submit");
	let realms = await requestPVE("/access/domains", "GET");
	let realmSelect = document.querySelector("#realm");
	realms.data.forEach((element) => {
		realmSelect.add(new Option(element.comment, element.realm));
		if ("default" in element && element.default === 1) {
			realmSelect.value = element.realm;
		}
	});
	formSubmitButton.addEventListener("click", async (e) => {
		e.preventDefault();
		let form = document.querySelector("form");
		let formData = new FormData(form);

		formSubmitButton.innerText = "Authenticating...";
		let ticket = await requestTicket(formData.get("username"), formData.get("password"), formData.get("realm"));
		if (ticket.status === 200) {
			formSubmitButton.innerText = "LOGIN";
			goToPage("index.html");
		}
		else if (ticket.status === 401) {
			alert("Authenticaton failed.");
			formSubmitButton.innerText = "LOGIN";
		}
		else if (ticket.status === 408) {
			alert("Network error.");
			formSubmitButton.innerText = "LOGIN";
		}
		else {
			alert("An error occured.");
			formSubmitButton.innerText = "LOGIN";
			console.error(ticket.error);
		}
	});
}