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
 | |
|     }
 | |
| }
 |