MapComplete/UI/Base/Title.ts

73 lines
2.1 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import BaseUIElement from "../BaseUIElement"
import { FixedUiElement } from "./FixedUiElement"
import { Utils } from "../../Utils"
export default class Title extends BaseUIElement {
2022-09-08 21:40:48 +02:00
private static readonly defaultClassesPerLevel = [
"",
"text-3xl font-bold",
"text-2xl font-bold",
"text-xl font-bold",
"text-lg font-bold",
]
public readonly title: BaseUIElement
public readonly level: number
2022-01-18 18:52:42 +01:00
public readonly id: string
constructor(embedded: string | BaseUIElement, level: number = 3) {
super()
2022-01-18 18:52:42 +01:00
if (embedded === undefined) {
throw "A title should have some content. Undefined is not allowed"
}
2021-11-07 16:34:51 +01:00
if (typeof embedded === "string") {
2021-11-25 22:16:00 +01:00
this.title = new FixedUiElement(embedded)
2021-11-07 16:34:51 +01:00
} else {
2021-11-25 22:16:00 +01:00
this.title = embedded
2021-09-13 01:16:56 +02:00
}
2022-09-08 21:40:48 +02:00
this.level = level
2022-01-18 18:52:42 +01:00
2022-09-08 21:40:48 +02:00
let text: string = undefined
2022-01-18 18:52:42 +01:00
if (typeof embedded === "string") {
text = embedded
2022-01-18 18:52:42 +01:00
} else if (embedded instanceof FixedUiElement) {
text = embedded.content
2022-01-18 18:52:42 +01:00
} else {
2022-06-19 13:53:24 +02:00
if (!Utils.runningFromConsole) {
text = embedded.ConstructElement()?.textContent
}
2021-11-30 22:50:48 +01:00
}
2022-01-18 18:52:42 +01:00
2022-09-08 21:40:48 +02:00
this.id =
text
?.replace(/ /g, "-")
?.replace(/[?#.;:/]/, "")
?.toLowerCase() ?? ""
this.SetClass(Title.defaultClassesPerLevel[level] ?? "")
}
AsMarkdown(): string {
2022-09-08 21:40:48 +02:00
const embedded = " " + this.title.AsMarkdown() + " "
2021-11-25 22:16:00 +01:00
if (this.level == 1) {
2021-11-08 02:36:01 +01:00
return "\n\n" + embedded + "\n" + "=".repeat(embedded.length) + "\n\n"
}
2021-11-25 22:16:00 +01:00
if (this.level == 2) {
2021-11-08 02:36:01 +01:00
return "\n\n" + embedded + "\n" + "-".repeat(embedded.length) + "\n\n"
}
2022-09-08 21:40:48 +02:00
return "\n\n" + "#".repeat(this.level) + embedded + "\n\n"
}
protected InnerConstructElement(): HTMLElement {
2021-11-25 22:16:00 +01:00
const el = this.title.ConstructElement()
if (el === undefined) {
2022-09-08 21:40:48 +02:00
return undefined
}
2021-11-25 22:16:00 +01:00
const h = document.createElement("h" + this.level)
h.appendChild(el)
el.id = this.id
2022-09-08 21:40:48 +02:00
return h
}
2022-09-08 21:40:48 +02:00
}