import {InputElement} from "./InputElement"; import {UIElement} from "../UIElement"; import {FixedUiElement} from "../Base/FixedUiElement"; import {UIEventSource} from "../../Logic/UIEventSource"; export class FixedInputElement extends InputElement { private readonly rendering: UIElement; private readonly value: UIEventSource; public readonly IsSelected : UIEventSource = new UIEventSource(false); private readonly _comparator: (t0: T, t1: T) => boolean; constructor(rendering: UIElement | string, value: T, comparator: ((t0: T, t1: T) => boolean ) = undefined) { super(undefined); this._comparator = comparator ?? ((t0, t1) => t0 == t1); this.value = new UIEventSource(value); this.rendering = typeof (rendering) === 'string' ? new FixedUiElement(rendering) : rendering; } GetValue(): UIEventSource { return this.value; } InnerRender(): string { return this.rendering.Render(); } IsValid(t: T): boolean { return this._comparator(t, this.value.data); } protected InnerUpdate(htmlElement: HTMLElement) { super.InnerUpdate(htmlElement); const self = this; htmlElement.addEventListener("mouseenter", () => self.IsSelected.setData(true)); htmlElement.addEventListener("mouseout", () => self.IsSelected.setData(false)) } }