MapComplete/UI/Base/List.ts

53 lines
1.6 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { Utils } from "../../Utils"
import BaseUIElement from "../BaseUIElement"
import Translations from "../i18n/Translations"
2021-06-14 02:39:23 +02:00
export default class List extends BaseUIElement {
2022-09-08 21:40:48 +02:00
private readonly uiElements: BaseUIElement[]
private readonly _ordered: boolean
2021-06-14 02:39:23 +02:00
constructor(uiElements: (string | BaseUIElement)[], ordered = false) {
2022-09-08 21:40:48 +02:00
super()
this._ordered = ordered
this.uiElements = Utils.NoNull(uiElements).map((s) => Translations.W(s))
2021-06-14 02:39:23 +02:00
}
AsMarkdown(): string {
if (this._ordered) {
2022-09-08 21:40:48 +02:00
return (
"\n\n" +
this.uiElements
.map((el, i) => " " + i + ". " + el.AsMarkdown().replace(/\n/g, " \n"))
.join("\n") +
"\n"
)
} else {
2022-09-08 21:40:48 +02:00
return (
"\n\n" +
this.uiElements
.map((el) => " - " + el.AsMarkdown().replace(/\n/g, " \n"))
.join("\n") +
"\n"
)
}
}
2021-06-14 02:39:23 +02:00
protected InnerConstructElement(): HTMLElement {
const el = document.createElement(this._ordered ? "ol" : "ul")
for (const subEl of this.uiElements) {
if (subEl === undefined || subEl === null) {
2022-09-08 21:40:48 +02:00
continue
2021-06-14 02:39:23 +02:00
}
const subHtml = subEl.ConstructElement()
if (subHtml !== undefined) {
2021-06-14 02:39:23 +02:00
const item = document.createElement("li")
item.appendChild(subHtml)
el.appendChild(item)
}
}
2022-09-08 21:40:48 +02:00
return el
2021-06-14 02:39:23 +02:00
}
2022-09-08 21:40:48 +02:00
}