71 lines
2.4 KiB
TypeScript
71 lines
2.4 KiB
TypeScript
|
// This file handles the "Confirm instance details" dialog
|
||
|
|
||
|
import knownSoftware from "./known_software.mjs";
|
||
|
|
||
|
const blankImage = "";
|
||
|
|
||
|
export function initializeInstanceDetailsDialog(dialog: HTMLDialogElement): {
|
||
|
showInstanceDetailsDialog: () => void,
|
||
|
hideInstanceDetailsDialog: () => void,
|
||
|
populateInstanceDetailsDialog: (
|
||
|
instanceNameValue: string,
|
||
|
instanceSoftwareValue: string,
|
||
|
instanceIconValue: string | null
|
||
|
) => void,
|
||
|
} {
|
||
|
const showInstanceDetailsDialog = () => dialog.showModal();
|
||
|
const hideInstanceDetailsDialog = () => dialog.close();
|
||
|
|
||
|
const form = dialog.querySelector(".instanceDetailsForm");
|
||
|
if (!(form instanceof HTMLFormElement))
|
||
|
throw new Error(".instanceDetailsForm isn't a form");
|
||
|
|
||
|
const instanceName = form.querySelector("#instanceName");
|
||
|
if (!(instanceName instanceof HTMLInputElement))
|
||
|
throw new Error("#instanceName isn't an input");
|
||
|
|
||
|
const instanceSoftware = form.querySelector("#instanceSoftware");
|
||
|
if (!(instanceSoftware instanceof HTMLSelectElement))
|
||
|
throw new Error("#instanceSoftware isn't a select");
|
||
|
|
||
|
for (const [name, software] of Object.entries(knownSoftware.software)) {
|
||
|
const option = new Option(software.name, name);
|
||
|
instanceSoftware.appendChild(option);
|
||
|
}
|
||
|
|
||
|
const instanceIcon = form.querySelector("#instanceIcon");
|
||
|
if (!(instanceIcon instanceof HTMLImageElement))
|
||
|
throw new Error("#instanceIcon isn't an image");
|
||
|
|
||
|
instanceIcon.src = blankImage;
|
||
|
|
||
|
const populateInstanceDetailsDialog = (
|
||
|
instanceNameValue: string,
|
||
|
instanceSoftwareValue: string,
|
||
|
instanceIconValue: string | null
|
||
|
) => {
|
||
|
instanceName.value = instanceNameValue;
|
||
|
instanceSoftware.value = instanceSoftwareValue;
|
||
|
instanceIcon.src = instanceIconValue ?? blankImage;
|
||
|
};
|
||
|
|
||
|
form.addEventListener("submit", e => {
|
||
|
form.reset();
|
||
|
});
|
||
|
|
||
|
const closeButton = form.querySelector(".close");
|
||
|
if (!(closeButton instanceof HTMLButtonElement))
|
||
|
throw new Error(".close isn't a button");
|
||
|
|
||
|
closeButton.addEventListener("click", e => {
|
||
|
instanceIcon.src = blankImage;
|
||
|
hideInstanceDetailsDialog();
|
||
|
});
|
||
|
|
||
|
return {
|
||
|
showInstanceDetailsDialog,
|
||
|
hideInstanceDetailsDialog,
|
||
|
populateInstanceDetailsDialog
|
||
|
};
|
||
|
}
|