import {InputElement} from "./InputElement"; import {UIEventSource} from "../../Logic/UIEventSource"; export default class SimpleDatePicker extends InputElement { private readonly value: UIEventSource private readonly _element: HTMLElement; constructor( value?: UIEventSource ) { super(); this.value = value ?? new UIEventSource(undefined); const self = this; const el = document.createElement("input") this._element = el; el.type = "date" el.oninput = () => { // Already in YYYY-MM-DD value! self.value.setData(el.value); } this.value.addCallbackAndRun(v => { if(v === undefined){ return; } el.value = v; }); } protected InnerConstructElement(): HTMLElement { return this._element } GetValue(): UIEventSource { return this.value; } IsSelected: UIEventSource = new UIEventSource(false); IsValid(t: string): boolean { return false; } }