import BaseUIElement from "../BaseUIElement"; import {FixedUiElement} from "./FixedUiElement"; import {Utils} from "../../Utils"; export default class Title extends BaseUIElement { public readonly title: BaseUIElement; public readonly level: number; public readonly id: string private static readonly defaultClassesPerLevel = ["", "text-3xl font-bold", "text-2xl font-bold", "text-xl font-bold", "text-lg font-bold"] constructor(embedded: string | BaseUIElement, level: number = 3) { super() if (embedded === undefined) { throw "A title should have some content. Undefined is not allowed" } if (typeof embedded === "string") { this.title = new FixedUiElement(embedded) } else { this.title = embedded } this.level = level; let innerText: string = undefined; if (typeof embedded === "string") { innerText = embedded } else if (embedded instanceof FixedUiElement) { innerText = embedded.content } else { if (Utils.runningFromConsole) { console.log("Not constructing an anchor for title with embedded content of " + embedded) } else { innerText = embedded.ConstructElement()?.innerText } } this.id = innerText?.replace(/ /g, '-') ?.replace(/[?#.;:/]/, "") ?.toLowerCase() ?? "" this.SetClass(Title.defaultClassesPerLevel[level] ?? "") } AsMarkdown(): string { const embedded = " " + this.title.AsMarkdown() + " "; if (this.level == 1) { return "\n\n" + embedded + "\n" + "=".repeat(embedded.length) + "\n\n" } if (this.level == 2) { return "\n\n" + embedded + "\n" + "-".repeat(embedded.length) + "\n\n" } return "\n\n" + "#".repeat(this.level) + embedded + "\n\n"; } protected InnerConstructElement(): HTMLElement { const el = this.title.ConstructElement() if (el === undefined) { return undefined; } const h = document.createElement("h" + this.level) h.appendChild(el) el.id = this.id return h; } }