1
0
Fork 0
VaultUI/src/htmlUtils.ts

69 lines
2.1 KiB
TypeScript
Raw Normal View History

import { getObjectKeys } from "./utils";
type optionsFunctionsObject = {
2021-05-10 11:35:14 +01:00
[key: string]: (e: Element, arg: unknown) => void
}
const optionsFunctions: optionsFunctionsObject = {
"class": (e: Element, arg: string | string[]) => {
if (!Array.isArray(arg)) {
arg = String(arg).split(" ");
}
e.classList.add(...arg);
},
"id": (e: Element, arg: string) => e.id = arg,
"html": (e: Element, arg: string) => e.innerHTML = arg,
2021-05-10 11:35:14 +01:00
"onclick": (e: Element, arg: () => void) => (e as HTMLButtonElement).onclick = arg,
"attributes": setElementAttributes,
2021-05-10 11:35:14 +01:00
"text": (e: Element, arg: string) => (e as HTMLParagraphElement).innerText = arg,
"children": (e: Element, arg: Element | Element[]) => {
if (Array.isArray(arg)) {
arg.forEach(child => {
if (child != null) e.appendChild(child);
});
} else {
if (arg != null) e.appendChild(arg);
}
},
"thenRun": (e: Element, arg: (e: Element) => void) => arg(e),
}
interface ElementInfo {
2021-05-07 23:08:02 +01:00
condition?: boolean;
tag: string;
class?: string | string[];
id?: string;
html?: string;
2021-05-10 11:35:14 +01:00
attributes?: Record<string, string>;
children?: Element | Element[];
text?: string;
thenRun?: (e: Element) => void;
2021-05-10 11:35:14 +01:00
onclick?: () => void;
[propName: string]: unknown;
}
2021-05-08 03:40:44 +01:00
export function makeElement(elementInfo: ElementInfo): HTMLElement {
if ("condition" in elementInfo) { if (!elementInfo.condition) { return null; } }
2021-05-07 23:08:02 +01:00
const element = document.createElement(elementInfo.tag);
2021-05-07 23:08:02 +01:00
for (const key of Object.getOwnPropertyNames(elementInfo)) {
if (getObjectKeys(optionsFunctions).includes(key)) {
2021-05-10 11:35:14 +01:00
optionsFunctions[key](element, elementInfo[key]);
}
}
return element;
}
2021-05-10 11:35:14 +01:00
export function setElementAttributes(element: Element, attributes: Record<string, string>): void {
2021-05-07 23:08:02 +01:00
for (const key of Object.getOwnPropertyNames(attributes)) {
element.setAttribute(key, attributes[key]);
}
}
export const fileToBase64 = (file: File): Promise<string> => new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => resolve(reader.result as string);
reader.onerror = error => reject(error);
});