import {InputElement} from "./InputElement"; import {UIEventSource} from "../../Logic/UIEventSource"; import Translations from "../i18n/Translations"; import BaseUIElement from "../BaseUIElement"; export class FixedInputElement extends InputElement { public readonly IsSelected: UIEventSource = new UIEventSource(false); private readonly value: UIEventSource; private readonly _comparator: (t0: T, t1: T) => boolean; private readonly _el: HTMLElement; constructor(rendering: BaseUIElement | string, value: T, comparator: ((t0: T, t1: T) => boolean) = undefined) { super(); this._comparator = comparator ?? ((t0, t1) => t0 == t1); this.value = new UIEventSource(value); const selected = this.IsSelected; this._el = document.createElement("span") this._el.addEventListener("mouseout", () => selected.setData(false)) const e = Translations.W(rendering)?.ConstructElement() if (e) { this._el.appendChild(e) } this.onClick(() => { selected.setData(true) }) } GetValue(): UIEventSource { return this.value; } IsValid(t: T): boolean { return this._comparator(t, this.value.data); } protected InnerConstructElement(): HTMLElement { return this._el; } }