import {UIEventSource} from "../UIEventSource"; import {UIElement} from "../UIElement"; import {InputElement} from "./InputElement"; import instantiate = WebAssembly.instantiate; import {FixedUiElement} from "../Base/FixedUiElement"; export class DropDown extends InputElement { private readonly _label: string; private readonly _values: { value: T; shown: UIElement }[]; private readonly _value; constructor(label: string, values: { value: T, shown: string | UIElement }[], value: UIEventSource = undefined) { super(undefined); this._value = value ?? new UIEventSource(undefined); this._label = label; this._values = values.map(v => { return { value: v.value, shown: v.shown instanceof UIElement ? v.shown : new FixedUiElement(v.shown) } } ); this.ListenTo(this._value) } GetValue(): UIEventSource { return this._value; } ShowValue(t: T): boolean { if (!this.IsValid(t)) { return false; } this._value.setData(t); } IsValid(t: T): boolean { for (const value of this._values) { if (value.value === t) { return true; } } return false } InnerRender(): string { if(this._values.length <=1){ return ""; } let options = ""; for (let i = 0; i < this._values.length; i++) { options += "" } return "
" + "" + "" + "
"; } protected InnerUpdate(element) { var e = document.getElementById("dropdown-" + this.id); if(e === null){ return; } const self = this; e.onchange = (() => { // @ts-ignore var index = parseInt(e.selectedIndex); self._value.setData(self._values[index].value); }); var t = this._value.data; for (let i = 0; i < this._values.length ; i++) { const value = this._values[i]; if (value.value == t) { // @ts-ignore e.selectedIndex = i; } } } }