forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { Utils } from "../../Utils"
 | 
						|
import BaseUIElement from "../BaseUIElement"
 | 
						|
import Translations from "../i18n/Translations"
 | 
						|
 | 
						|
export default class List extends BaseUIElement {
 | 
						|
    private readonly uiElements: BaseUIElement[]
 | 
						|
    private readonly _ordered: boolean
 | 
						|
 | 
						|
    constructor(uiElements: (string | BaseUIElement)[], ordered = false) {
 | 
						|
        super()
 | 
						|
        this._ordered = ordered
 | 
						|
        this.uiElements = Utils.NoNull(uiElements).map((s) => Translations.W(s))
 | 
						|
    }
 | 
						|
 | 
						|
    AsMarkdown(): string {
 | 
						|
        if (this._ordered) {
 | 
						|
            return (
 | 
						|
                "\n\n" +
 | 
						|
                this.uiElements
 | 
						|
                    .map((el, i) => "  " + i + ". " + el.AsMarkdown().replace(/\n/g, "  \n"))
 | 
						|
                    .join("\n") +
 | 
						|
                "\n"
 | 
						|
            )
 | 
						|
        } else {
 | 
						|
            return (
 | 
						|
                "\n\n" +
 | 
						|
                this.uiElements
 | 
						|
                    .map((el) => "  - " + el.AsMarkdown().replace(/\n/g, "  \n"))
 | 
						|
                    .join("\n") +
 | 
						|
                "\n"
 | 
						|
            )
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    protected InnerConstructElement(): HTMLElement {
 | 
						|
        const el = document.createElement(this._ordered ? "ol" : "ul")
 | 
						|
 | 
						|
        for (const subEl of this.uiElements) {
 | 
						|
            if (subEl === undefined || subEl === null) {
 | 
						|
                continue
 | 
						|
            }
 | 
						|
            const subHtml = subEl.ConstructElement()
 | 
						|
            if (subHtml !== undefined) {
 | 
						|
                const item = document.createElement("li")
 | 
						|
                item.appendChild(subHtml)
 | 
						|
                el.appendChild(item)
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return el
 | 
						|
    }
 | 
						|
}
 |