Make ui components more chainable
This commit is contained in:
		| @@ -61,11 +61,13 @@ export class AudioRecorder extends UINode { | |||||||
|             const customEvent = event as CustomEvent; |             const customEvent = event as CustomEvent; | ||||||
|             callback(customEvent.detail.audioUrl); |             callback(customEvent.detail.audioUrl); | ||||||
|         }); |         }); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected triggerRecordingComplete(audioUrl: string) { |     protected triggerRecordingComplete(audioUrl: string) { | ||||||
|         const event = new CustomEvent("recording-complete", { detail: { audioUrl } }); |         const event = new CustomEvent("recording-complete", { detail: { audioUrl } }); | ||||||
|         this.element.dispatchEvent(event); |         this.element.dispatchEvent(event); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getRecording() { |     public getRecording() { | ||||||
|   | |||||||
| @@ -26,33 +26,41 @@ export class Audio extends UINode { | |||||||
|         } else if (src instanceof MediaStream) { |         } else if (src instanceof MediaStream) { | ||||||
|             this.audioElement.srcObject = src; |             this.audioElement.srcObject = src; | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public play() { |     public play() { | ||||||
|         this.audioElement.play(); |         this.audioElement.play(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public pause() { |     public pause() { | ||||||
|         this.audioElement.pause(); |         this.audioElement.pause(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setControls(show: boolean) { |     public setControls(show: boolean) { | ||||||
|         this.audioElement.controls = show; |         this.audioElement.controls = show; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setLoop(loop: boolean) { |     public setLoop(loop: boolean) { | ||||||
|         this.audioElement.loop = loop; |         this.audioElement.loop = loop; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setMuted(muted: boolean) { |     public setMuted(muted: boolean) { | ||||||
|         this.audioElement.muted = muted; |         this.audioElement.muted = muted; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setAutoplay(autoplay: boolean) { |     public setAutoplay(autoplay: boolean) { | ||||||
|         this.audioElement.autoplay = autoplay; |         this.audioElement.autoplay = autoplay; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setVolume(volume: number) { |     public setVolume(volume: number) { | ||||||
|         this.audioElement.volume = volume; |         this.audioElement.volume = volume; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -13,10 +13,12 @@ export class Button extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.buttonElement.focus(); |         this.buttonElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.buttonElement.click(); |         this.buttonElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -27,9 +29,11 @@ export class Button extends UINode { | |||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.buttonElement.innerText = text; |         this.buttonElement.innerText = text; | ||||||
|         this.element.setAttribute("aria-label", this.title); |         this.element.setAttribute("aria-label", this.title); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setDisabled(val: boolean) { |     public setDisabled(val: boolean) { | ||||||
|         this.buttonElement.disabled = val; |         this.buttonElement.disabled = val; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -12,10 +12,12 @@ export class Canvas extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.canvasElement.focus(); |         this.canvasElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.canvasElement.click(); |         this.canvasElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
|   | |||||||
| @@ -19,10 +19,12 @@ export class Checkbox extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.checkboxElement.focus(); |         this.checkboxElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.checkboxElement.click(); |         this.checkboxElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -34,6 +36,7 @@ export class Checkbox extends UINode { | |||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|         this.element.setAttribute("aria-label", this.title); |         this.element.setAttribute("aria-label", this.title); | ||||||
|         this.element.setAttribute("aria-roledescription", "checkbox"); |         this.element.setAttribute("aria-roledescription", "checkbox"); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public isChecked(): boolean { |     public isChecked(): boolean { | ||||||
| @@ -42,5 +45,6 @@ export class Checkbox extends UINode { | |||||||
|  |  | ||||||
|     public setChecked(value: boolean) { |     public setChecked(value: boolean) { | ||||||
|         this.checkboxElement.checked = value; |         this.checkboxElement.checked = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -21,9 +21,10 @@ export class CollapsableContainer extends Container { | |||||||
|         return this.wrapperElement; |         return this.wrapperElement; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setTitle(text: string): void { |     public setTitle(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.summaryElement.innerText = text; |         this.summaryElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public isCollapsed(): boolean { |     public isCollapsed(): boolean { | ||||||
| @@ -36,5 +37,6 @@ export class CollapsableContainer extends Container { | |||||||
|         } else { |         } else { | ||||||
|             this.detailsElement.removeAttribute("open"); |             this.detailsElement.removeAttribute("open"); | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -15,6 +15,7 @@ export class Container extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.containerElement.focus(); |         this.containerElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public _onFocus() { |     public _onFocus() { | ||||||
| @@ -45,7 +46,8 @@ export class Container extends UINode { | |||||||
|         return this.containerElement; |         return this.containerElement; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setAriaLabel(text: string): void { |     public setAriaLabel(text: string) { | ||||||
|         this.containerElement.setAttribute("aria-label", text); |         this.containerElement.setAttribute("aria-label", text); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -20,6 +20,7 @@ export class DatePicker extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.inputElement.focus(); |         this.inputElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -29,6 +30,7 @@ export class DatePicker extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getValue(): string { |     public getValue(): string { | ||||||
| @@ -37,5 +39,6 @@ export class DatePicker extends UINode { | |||||||
|  |  | ||||||
|     public setValue(value: string) { |     public setValue(value: string) { | ||||||
|         this.inputElement.value = value; |         this.inputElement.value = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -31,20 +31,22 @@ export class Dialog<T> extends UIWindow { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setOkAction(action: () => T): void { |     public setOkAction(action: () => T) { | ||||||
|         if (!this.okButton) return; |         if (!this.okButton) return; | ||||||
|         this.okButton.onClick(() => { |         this.okButton.onClick(() => { | ||||||
|             const result = action(); |             const result = action(); | ||||||
|             this.choose(result); |             this.choose(result); | ||||||
|         }); |         }); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setCancelAction(action: () => void): void { |     public setCancelAction(action: () => void) { | ||||||
|         if (!this.cancelButton) return; |         if (!this.cancelButton) return; | ||||||
|         this.cancelButton.onClick(() => { |         this.cancelButton.onClick(() => { | ||||||
|             action(); |             action(); | ||||||
|             this.cancel(); |             this.cancel(); | ||||||
|         }); |         }); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public choose(item: T | undefined) { |     public choose(item: T | undefined) { | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ export class Dropdown extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.selectElement.focus(); |         this.selectElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -30,6 +31,7 @@ export class Dropdown extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getSelectedValue(): string { |     public getSelectedValue(): string { | ||||||
| @@ -38,6 +40,7 @@ export class Dropdown extends UINode { | |||||||
|  |  | ||||||
|     public setSelectedValue(value: string) { |     public setSelectedValue(value: string) { | ||||||
|         this.selectElement.value = value; |         this.selectElement.value = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setOptions(options: { key: string; value: string }[]) { |     public setOptions(options: { key: string; value: string }[]) { | ||||||
| @@ -45,6 +48,7 @@ export class Dropdown extends UINode { | |||||||
|         options.forEach((option) => { |         options.forEach((option) => { | ||||||
|             this.addOption(option.key, option.value); |             this.addOption(option.key, option.value); | ||||||
|         }); |         }); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public addOption(key: string, value: string) { |     public addOption(key: string, value: string) { | ||||||
| @@ -52,6 +56,7 @@ export class Dropdown extends UINode { | |||||||
|         optionElement.value = key; |         optionElement.value = key; | ||||||
|         optionElement.innerText = value; |         optionElement.innerText = value; | ||||||
|         this.selectElement.appendChild(optionElement); |         this.selectElement.appendChild(optionElement); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public removeOption(key: string) { |     public removeOption(key: string) { | ||||||
| @@ -60,11 +65,13 @@ export class Dropdown extends UINode { | |||||||
|         if (optionToRemove) { |         if (optionToRemove) { | ||||||
|             this.selectElement.removeChild(optionToRemove); |             this.selectElement.removeChild(optionToRemove); | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public clearOptions() { |     public clearOptions() { | ||||||
|         while (this.selectElement.firstChild) { |         while (this.selectElement.firstChild) { | ||||||
|             this.selectElement.removeChild(this.selectElement.firstChild); |             this.selectElement.removeChild(this.selectElement.firstChild); | ||||||
|         } |         } | ||||||
|  |         return this | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ export class FileInput extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.inputElement.focus(); |         this.inputElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -32,6 +33,7 @@ export class FileInput extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getFiles(): FileList | null { |     public getFiles(): FileList | null { | ||||||
| @@ -40,5 +42,6 @@ export class FileInput extends UINode { | |||||||
|  |  | ||||||
|     public setAccept(accept: string) { |     public setAccept(accept: string) { | ||||||
|         this.inputElement.accept = accept; |         this.inputElement.accept = accept; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -18,13 +18,16 @@ export class Image extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.element.setAttribute("aria-label", text); |         this.element.setAttribute("aria-label", text); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setSource(src: string) { |     public setSource(src: string) { | ||||||
|         this.imgElement.src = src; |         this.imgElement.src = src; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setAltText(altText: string) { |     public setAltText(altText: string) { | ||||||
|         this.imgElement.alt = altText; |         this.imgElement.alt = altText; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -15,10 +15,12 @@ export class ListItem extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.listElement.focus(); |         this.listElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.listElement.click(); |         this.listElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -30,5 +32,6 @@ export class ListItem extends UINode { | |||||||
|         this.listElement.innerText = text; |         this.listElement.innerText = text; | ||||||
|         this.element.setAttribute("aria-label", this.title); |         this.element.setAttribute("aria-label", this.title); | ||||||
|         this.listElement.setAttribute("aria-label", this.title); |         this.listElement.setAttribute("aria-label", this.title); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -23,6 +23,7 @@ export class List extends UINode { | |||||||
|         this.listElement.appendChild(node.render()); |         this.listElement.appendChild(node.render()); | ||||||
|         if (this.children.length === 1) this.calculateTabIndex(); |         if (this.children.length === 1) this.calculateTabIndex(); | ||||||
|         node.onFocus(() => this.calculateFocused(node)); |         node.onFocus(() => this.calculateFocused(node)); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public addNodeAtIndex(node: UINode, index: number) { |     public addNodeAtIndex(node: UINode, index: number) { | ||||||
| @@ -32,6 +33,7 @@ export class List extends UINode { | |||||||
|         this.listElement.insertBefore(node.render(), this.listElement.children[index]); |         this.listElement.insertBefore(node.render(), this.listElement.children[index]); | ||||||
|         if (this.children.length === 1) this.calculateTabIndex(); |         if (this.children.length === 1) this.calculateTabIndex(); | ||||||
|         node.onFocus(() => this.calculateFocused(node)); |         node.onFocus(() => this.calculateFocused(node)); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public remove(node: UINode) { |     public remove(node: UINode) { | ||||||
| @@ -43,11 +45,13 @@ export class List extends UINode { | |||||||
|             if (this.focused > 0) this.focused--; |             if (this.focused > 0) this.focused--; | ||||||
|             this.calculateTabIndex(); |             this.calculateTabIndex(); | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public _onFocus() { |     public _onFocus() { | ||||||
|         super._onFocus(); |         super._onFocus(); | ||||||
|         this.children[this.focused].focus(); |         this.children[this.focused].focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public _onClick() { |     public _onClick() { | ||||||
| @@ -133,6 +137,7 @@ export class List extends UINode { | |||||||
|         this.children = []; |         this.children = []; | ||||||
|         this.listElement.innerHTML = ''; |         this.listElement.innerHTML = ''; | ||||||
|         this.focused = 0; |         this.focused = 0; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getFocusedChild() { |     public getFocusedChild() { | ||||||
| @@ -145,6 +150,7 @@ export class List extends UINode { | |||||||
|  |  | ||||||
|     public onSelect(f: (id: number) => void) { |     public onSelect(f: (id: number) => void) { | ||||||
|         this.selectCallback = f; |         this.selectCallback = f; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected calculateFocused(node: UINode) { |     protected calculateFocused(node: UINode) { | ||||||
| @@ -160,5 +166,6 @@ export class List extends UINode { | |||||||
|         // set the focused element for tab index without focusing directly. |         // set the focused element for tab index without focusing directly. | ||||||
|         this.focused = this.children.length - 1; |         this.focused = this.children.length - 1; | ||||||
|         this.children[this.focused].setTabbable(true); |         this.children[this.focused].setTabbable(true); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -18,10 +18,12 @@ export class MultilineInput extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.textareaElement.focus(); |         this.textareaElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.textareaElement.click(); |         this.textareaElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -31,6 +33,7 @@ export class MultilineInput extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getValue(): string { |     public getValue(): string { | ||||||
| @@ -39,5 +42,6 @@ export class MultilineInput extends UINode { | |||||||
|  |  | ||||||
|     public setValue(value: string) { |     public setValue(value: string) { | ||||||
|         this.textareaElement.value = value; |         this.textareaElement.value = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -100,6 +100,7 @@ export class UINode { | |||||||
|         this.positionType = type; |         this.positionType = type; | ||||||
|         this.calculateOwnStyle = true; |         this.calculateOwnStyle = true; | ||||||
|         this.calculateStyle(); |         this.calculateStyle(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public onClick(f: () => void) { |     public onClick(f: () => void) { | ||||||
| @@ -131,14 +132,17 @@ export class UINode { | |||||||
|         this.getElement().setAttribute("tabindex",  |         this.getElement().setAttribute("tabindex",  | ||||||
|         (val === true) ? "0" : |         (val === true) ? "0" : | ||||||
|         "-1"); |         "-1"); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setAriaLabel(text: string) { |     public setAriaLabel(text: string) { | ||||||
|         this.element.setAttribute("aria-label", text); |         this.element.setAttribute("aria-label", text); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setRole(role: string) { |     public setRole(role: string) { | ||||||
|         this.getElement().setAttribute("role", role); |         this.getElement().setAttribute("role", role); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getUserData(): any { |     public getUserData(): any { | ||||||
| @@ -147,9 +151,11 @@ export class UINode { | |||||||
|  |  | ||||||
|     public setUserData(obj: any) { |     public setUserData(obj: any) { | ||||||
|         this.userdata = obj; |         this.userdata = obj; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setAccessKey(key: string) { |     public setAccessKey(key: string) { | ||||||
|         this.getElement().accessKey = key; |         this.getElement().accessKey = key; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -17,6 +17,7 @@ export class ProgressBar extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.element.setAttribute("aria-label", text); |         this.element.setAttribute("aria-label", text); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getValue(): number { |     public getValue(): number { | ||||||
| @@ -25,6 +26,7 @@ export class ProgressBar extends UINode { | |||||||
|  |  | ||||||
|     public setValue(value: number) { |     public setValue(value: number) { | ||||||
|         this.progressElement.value = value; |         this.progressElement.value = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getMax(): number { |     public getMax(): number { | ||||||
| @@ -33,5 +35,6 @@ export class ProgressBar extends UINode { | |||||||
|  |  | ||||||
|     public setMax(max: number) { |     public setMax(max: number) { | ||||||
|         this.progressElement.max = max; |         this.progressElement.max = max; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -47,6 +47,7 @@ export class RadioGroup extends UINode { | |||||||
|         if (firstRadioElement) { |         if (firstRadioElement) { | ||||||
|             firstRadioElement.focus(); |             firstRadioElement.focus(); | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -56,6 +57,7 @@ export class RadioGroup extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getSelectedValue(): string | null { |     public getSelectedValue(): string | null { | ||||||
| @@ -72,5 +74,6 @@ export class RadioGroup extends UINode { | |||||||
|         if (radioElement) { |         if (radioElement) { | ||||||
|             radioElement.checked = true; |             radioElement.checked = true; | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -22,10 +22,12 @@ export class Slider extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.sliderElement.focus(); |         this.sliderElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.sliderElement.click(); |         this.sliderElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -35,6 +37,7 @@ export class Slider extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getValue(): number { |     public getValue(): number { | ||||||
| @@ -43,5 +46,6 @@ export class Slider extends UINode { | |||||||
|  |  | ||||||
|     public setValue(value: number) { |     public setValue(value: number) { | ||||||
|         this.sliderElement.value = value.toString(); |         this.sliderElement.value = value.toString(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -23,10 +23,12 @@ export class TabBar extends UINode { | |||||||
|  |  | ||||||
|     public _onFocus() { |     public _onFocus() { | ||||||
|         this.tabs[this.focused].focus(); |         this.tabs[this.focused].focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.tabs[this.focused].focus(); |         this.tabs[this.focused].focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public add(title: string) { |     public add(title: string) { | ||||||
| @@ -39,10 +41,12 @@ export class TabBar extends UINode { | |||||||
|         this.tabBarContainer.appendChild(elem.render()); |         this.tabBarContainer.appendChild(elem.render()); | ||||||
|         elem._onConnect(); |         elem._onConnect(); | ||||||
|         if (this.tabs.length === 1) this.calculateTabIndex(); |         if (this.tabs.length === 1) this.calculateTabIndex(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public onTabChange(f: (index: number) => void) { |     public onTabChange(f: (index: number) => void) { | ||||||
|         this.onTabChangeCallback = f; |         this.onTabChangeCallback = f; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private selectTab(idx: number) { |     private selectTab(idx: number) { | ||||||
| @@ -93,5 +97,6 @@ export class TabBar extends UINode { | |||||||
|      |      | ||||||
|     public calculateTabIndex() { |     public calculateTabIndex() { | ||||||
|         this.tabs[this.focused].setTabbable(true); |         this.tabs[this.focused].setTabbable(true); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -18,10 +18,12 @@ export class UITab extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.textElement.focus(); |         this.textElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.textElement.click(); |         this.textElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -31,10 +33,12 @@ export class UITab extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.textElement.innerText = text; |         this.textElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setSelected(val: boolean) { |     public setSelected(val: boolean) { | ||||||
|         this.selected = val; |         this.selected = val; | ||||||
|         this.textElement.setAttribute("aria-selected", this.selected.toString()); |         this.textElement.setAttribute("aria-selected", this.selected.toString()); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -26,6 +26,7 @@ export class TabbedView extends UINode { | |||||||
|         this.bar.add(name); |         this.bar.add(name); | ||||||
|         container.setRole("tabpanel"); |         container.setRole("tabpanel"); | ||||||
|         this.containers.push(container); |         this.containers.push(container); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private onTabChanged(idx: number) { |     private onTabChanged(idx: number) { | ||||||
|   | |||||||
| @@ -19,10 +19,12 @@ export class TextInput extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.inputElement.focus(); |         this.inputElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.inputElement.click(); |         this.inputElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -32,6 +34,7 @@ export class TextInput extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getValue(): string { |     public getValue(): string { | ||||||
| @@ -40,5 +43,6 @@ export class TextInput extends UINode { | |||||||
|  |  | ||||||
|     public setValue(value: string) { |     public setValue(value: string) { | ||||||
|         this.inputElement.value = value; |         this.inputElement.value = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -12,10 +12,12 @@ export class Text extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.textElement.focus(); |         this.textElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public click() { |     public click() { | ||||||
|         this.textElement.click(); |         this.textElement.click(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -25,5 +27,6 @@ export class Text extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.textElement.innerText = text; |         this.textElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -19,6 +19,7 @@ export class TimePicker extends UINode { | |||||||
|  |  | ||||||
|     public focus() { |     public focus() { | ||||||
|         this.inputElement.focus(); |         this.inputElement.focus(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getElement(): HTMLElement { |     public getElement(): HTMLElement { | ||||||
| @@ -28,6 +29,7 @@ export class TimePicker extends UINode { | |||||||
|     public setText(text: string) { |     public setText(text: string) { | ||||||
|         this.title = text; |         this.title = text; | ||||||
|         this.titleElement.innerText = text; |         this.titleElement.innerText = text; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public getValue(): string { |     public getValue(): string { | ||||||
| @@ -36,5 +38,6 @@ export class TimePicker extends UINode { | |||||||
|  |  | ||||||
|     public setValue(value: string) { |     public setValue(value: string) { | ||||||
|         this.inputElement.value = value; |         this.inputElement.value = value; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -26,29 +26,36 @@ export class Video extends UINode { | |||||||
|         } else if (src instanceof MediaStream) { |         } else if (src instanceof MediaStream) { | ||||||
|             this.videoElement.srcObject = src; |             this.videoElement.srcObject = src; | ||||||
|         } |         } | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public play() { |     public play() { | ||||||
|         this.videoElement.play(); |         this.videoElement.play(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public pause() { |     public pause() { | ||||||
|         this.videoElement.pause(); |         this.videoElement.pause(); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setControls(show: boolean) { |     public setControls(show: boolean) { | ||||||
|         this.videoElement.controls = show; |         this.videoElement.controls = show; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setLoop(loop: boolean) { |     public setLoop(loop: boolean) { | ||||||
|         this.videoElement.loop = loop; |         this.videoElement.loop = loop; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setMuted(muted: boolean) { |     public setMuted(muted: boolean) { | ||||||
|         this.videoElement.muted = muted; |         this.videoElement.muted = muted; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public setAutoplay(autoplay: boolean) { |     public setAutoplay(autoplay: boolean) { | ||||||
|         this.videoElement.autoplay = autoplay; |         this.videoElement.autoplay = autoplay; | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -30,10 +30,12 @@ export class UIWindow { | |||||||
|  |  | ||||||
|     public add(node: UINode) { |     public add(node: UINode) { | ||||||
|         this.container.add(node); |         this.container.add(node); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public remove(node: UINode) { |     public remove(node: UINode) { | ||||||
|         if (this.container.children.includes(node)) this.container.remove(node); |         if (this.container.children.includes(node)) this.container.remove(node); | ||||||
|  |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public show(): HTMLElement|undefined { |     public show(): HTMLElement|undefined { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user