import {UIElement} from "../UI/UIElement"; import {SubtleButton} from "../UI/Base/SubtleButton"; import {VariableUiElement} from "../UI/Base/VariableUIElement"; import SingleSetting from "../UI/CustomGenerator/SingleSetting"; import Combine from "../UI/Base/Combine"; import {UIEventSource} from "../Logic/UIEventSource"; export default class HelpText extends UIElement { private helpText: UIElement; private returnButton: UIElement; constructor(currentSetting: UIEventSource>) { super(); this.returnButton = new SubtleButton("./assets/close.svg", new VariableUiElement( currentSetting.map(currentSetting => { if (currentSetting === undefined) { return ""; } return "Return to general help"; } ) )) .ListenTo(currentSetting) .onClick(() => currentSetting.setData(undefined)); this.helpText = new VariableUiElement(currentSetting.map((setting: SingleSetting) => { if (setting === undefined) { return "

Welcome to the Custom Theme Builder

" + "Here, one can make their own custom mapcomplete themes.
" + "Fill out the fields to get a working mapcomplete theme. More information on the selected field will appear here when you click it"; } return new Combine(["

", setting._name, "

", setting._description.Render()]).Render(); })) } InnerRender(): string { return new Combine([this.helpText, this.returnButton, ]).Render(); } }