Files
azuredatastudio/src/sql/base/browser/ui/radioButton/radioButton.ts

122 lines
3.5 KiB
TypeScript

/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the Source EULA. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import { Event, Emitter } from 'vs/base/common/event';
import { Widget } from 'vs/base/browser/ui/widget';
import { withNullAsUndefined } from 'vs/base/common/types';
import { generateUuid } from 'vs/base/common/uuid';
export interface IRadioButtonOptions {
label: string;
enabled?: boolean;
checked?: boolean;
}
export class RadioButton extends Widget {
private inputElement: HTMLInputElement;
private _onClicked = new Emitter<void>();
public readonly onClicked: Event<void> = this._onClicked.event;
private _onChangedCheckedState = new Emitter<boolean>();
public readonly onDidChangeCheckedState: Event<boolean> = this._onChangedCheckedState.event;
private _label: HTMLSpanElement;
private _internalCheckedStateTracker: boolean = false;
constructor(container: HTMLElement, opts: IRadioButtonOptions) {
super();
const id = generateUuid();
this.inputElement = document.createElement('input');
this.inputElement.type = 'radio';
this.inputElement.style.verticalAlign = 'middle';
this.inputElement.style.margin = '3px';
this.inputElement.id = id;
this._label = document.createElement('label');
this._label.style.verticalAlign = 'middle';
this._label.setAttribute('for', id);
this.label = opts.label;
this.enabled = opts.enabled || true;
this.checked = opts.checked || false;
this.onclick(this.inputElement, () => {
this._onClicked.fire();
this.checked = true;
});
this.inputElement.addEventListener('change', () => {
if (this._internalCheckedStateTracker !== this.inputElement.checked) {
this._internalCheckedStateTracker = this.inputElement.checked;
this._onChangedCheckedState.fire(this._internalCheckedStateTracker);
}
});
container.appendChild(this.inputElement);
container.appendChild(this._label);
}
public set name(value: string | undefined) {
if (value) {
this.inputElement.setAttribute('name', value);
}
}
public get name(): string | undefined {
return withNullAsUndefined(this.inputElement.getAttribute('name'));
}
public set value(value: string | undefined) {
if (value) {
this.inputElement.setAttribute('value', value);
}
}
public get value(): string | undefined {
return withNullAsUndefined(this.inputElement.getAttribute('value'));
}
public set checked(val: boolean) {
if (val !== this._internalCheckedStateTracker) {
this.inputElement.checked = val;
const event = document.createEvent('HTMLEvents');
event.initEvent('change', true, true);
if (this.name) {
const buttonGroup = document.getElementsByName(this.name);
buttonGroup.forEach((button) => {
button.dispatchEvent(event);
});
} else {
this.inputElement.dispatchEvent(event);
}
}
}
public get checked(): boolean {
return this.inputElement.checked;
}
public set enabled(val: boolean) {
this.inputElement.disabled = !val;
}
public get enabled(): boolean {
return !this.inputElement.disabled;
}
public isEnabled(): boolean {
return !this.inputElement.hasAttribute('disabled');
}
public set label(val: string) {
this._label.innerText = val;
this.inputElement.setAttribute('aria-label', val);
}
public focus(): void {
this.inputElement.focus();
}
public blur(): void {
this.inputElement.blur();
}
}