igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
485 lines • 36.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, NgModule, Input, QueryList, Output, EventEmitter, ContentChildren, HostBinding } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { IgxRadioComponent, RadioLabelPosition } from '../../radio/radio.component';
import { IgxRippleModule } from '../ripple/ripple.directive';
import { takeUntil } from 'rxjs/operators';
import { Subject } from 'rxjs';
/** @type {?} */
const noop = () => { };
const ɵ0 = noop;
/** @type {?} */
let nextId = 0;
/**
* **Ignite UI for Angular Radio Group** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/radio_button.html)
*
* The Ignite UI Radio Group allows the user to select a single option from an available set of options that are listed side by side.
*
* Example:
* ```html
* <igx-radio-group name="radioGroup">
* <igx-radio *ngFor="let item of ['Foo', 'Bar', 'Baz']" value="{{item}}">
* {{item}}
* </igx-radio>
* </igx-radio-group>
* ```
*/
export class IgxRadioGroupDirective {
constructor() {
/**
* An event that is emitted after the radio group `value` is changed.
* Provides references to the selected `IgxRadioComponent` and the `value` property as event arguments.
* \@memberof IgxRadioGroupDirective
*/
this.change = new EventEmitter();
/**
* @hidden
*/
this.cssClass = 'igx-radio-group';
/**
* @hidden
*/
this._onChangeCallback = noop;
/**
* @hidden
*/
this._name = `igx-radio-group-${nextId++}`;
/**
* @hidden
*/
this._value = null;
/**
* @hidden
*/
this._selected = null;
/**
* @hidden
*/
this._isInitialized = false;
/**
* @hidden
*/
this._labelPosition = 'after';
/**
* @hidden
*/
this._disabled = false;
/**
* @hidden
*/
this._required = false;
/**
* @hidden
*/
this.destroy$ = new Subject();
}
/**
* Sets/gets the `value` attribute.
* ```html
* <igx-radio-group [value] = "'radioButtonValue'"></igx-radio-group>
* ```
* ```typescript
* let value = this.radioGroup.value;
* ```
* \@memberof IgxRadioGroupDirective
* @return {?}
*/
get value() { return this._value; }
/**
* @param {?} newValue
* @return {?}
*/
set value(newValue) {
if (this._value !== newValue) {
this._value = newValue;
this._selectRadioButton();
}
}
/**
* Sets/gets the `name` attribute of the radio group component. All child radio buttons inherits this name.
* ```html
* <igx-radio-group name = "Radio1"></igx-radio-group>
* ```
* ```typescript
* let name = this.radioGroup.name;
* ```
* \@memberof IgxRadioGroupDirective
* @return {?}
*/
get name() { return this._name; }
/**
* @param {?} newValue
* @return {?}
*/
set name(newValue) {
if (this._name !== newValue) {
this._name = newValue;
this._setRadioButtonNames();
}
}
/**
* Sets/gets whether the radio group is required.
* If not set, `required` will have value `false`.
* ```html
* <igx-radio-group [required] = "true"></igx-radio-group>
* ```
* ```typescript
* let isRequired = this.radioGroup.required;
* ```
* \@memberof IgxRadioGroupDirective
* @return {?}
*/
get required() { return this._required; }
/**
* @param {?} newValue
* @return {?}
*/
set required(newValue) {
if (this._required !== newValue) {
this._required = newValue;
this._setRadioButtonsRequired();
}
}
/**
* An \@Input property that allows you to disable the radio group. By default it's false.
* ```html
* <igx-radio-group [disabled]="true"></igx-radio-group>
* ```
* \@memberof IgxRadioGroupDirective
* @return {?}
*/
get disabled() { return this._disabled; }
/**
* @param {?} newValue
* @return {?}
*/
set disabled(newValue) {
if (this._disabled !== newValue) {
this._disabled = newValue;
this._disableRadioButtons();
}
}
/**
* Sets/gets the position of the `label` in the child radio buttons.
* If not set, `labelPosition` will have value `"after"`.
* ```html
* <igx-radio-group labelPosition = "before"></igx-radio-group>
* ```
* ```typescript
* let labelPosition = this.radioGroup.labelPosition;
* ```
* \@memberof IgxRadioGroupDirective
* @return {?}
*/
get labelPosition() { return this._labelPosition; }
/**
* @param {?} newValue
* @return {?}
*/
set labelPosition(newValue) {
if (this._labelPosition !== newValue) {
this._labelPosition = newValue === RadioLabelPosition.BEFORE ? RadioLabelPosition.BEFORE : RadioLabelPosition.AFTER;
this._setRadioButtonLabelPosition();
}
}
/**
* Sets/gets the selected child radio button.
* ```typescript
* let selectedButton = this.radioGroup.selected;
* this.radioGroup.selected = selectedButton;
* ```
* \@memberof IgxRadioGroupDirective
* @return {?}
*/
get selected() { return this._selected; }
/**
* @param {?} selected
* @return {?}
*/
set selected(selected) {
if (this._selected !== selected) {
this._selected = selected;
this.value = selected ? selected.value : null;
}
}
/**
* @return {?}
*/
ngAfterContentInit() {
// The initial value can possibly be set by NgModel and it is possible that
// the OnInit of the NgModel occurs after the OnInit of this class.
this._isInitialized = true;
setTimeout(() => { this._initRadioButtons(); });
}
/**
* Checks whether the provided value is consistent to the current radio button.
* If it is, the checked attribute will have value `true` and selected property will contain the selected `IgxRadioComponent`.
* ```typescript
* this.radioGroup.writeValue('radioButtonValue');
* ```
* @param {?} value
* @return {?}
*/
writeValue(value) {
this.value = value;
}
/**
* @hidden
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) { this._onChangeCallback = fn; }
/**
* @hidden
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
button.registerOnTouched(fn);
});
}
}
/**
* @hidden
* @return {?}
*/
ngOnDestroy() {
this.destroy$.next(true);
this.destroy$.complete();
}
/**
* @hidden
* @private
* @return {?}
*/
_initRadioButtons() {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
button.name = this._name;
button.labelPosition = this._labelPosition;
button.disabled = this._disabled;
button.required = this._required;
if (this._value && button.value === this._value) {
button.checked = true;
this._selected = button;
}
button.change.pipe(takeUntil(this.destroy$)).subscribe((ev) => this._selectedRadioButtonChanged(ev));
});
}
}
/**
* @hidden
* @private
* @param {?} args
* @return {?}
*/
_selectedRadioButtonChanged(args) {
if (this._selected !== args.radio) {
if (this._selected) {
this._selected.checked = false;
}
this._selected = args.radio;
}
this._value = args.value;
if (this._isInitialized) {
this.change.emit(args);
this._onChangeCallback(this.value);
}
}
/**
* @hidden
* @private
* @return {?}
*/
_setRadioButtonNames() {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
button.name = this._name;
});
}
}
/**
* @hidden
* @private
* @return {?}
*/
_selectRadioButton() {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
if (!this._value) {
// no value - uncheck all radio buttons
if (button.checked) {
button.checked = false;
}
}
else {
if (this._value === button.value) {
// selected button
if (this._selected !== button) {
this._selected = button;
}
if (!button.checked) {
button.select();
}
}
else {
// non-selected button
if (button.checked) {
button.checked = false;
}
}
}
});
}
}
/**
* @hidden
* @private
* @return {?}
*/
_setRadioButtonLabelPosition() {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
button.labelPosition = this._labelPosition;
});
}
}
/**
* @hidden
* @private
* @return {?}
*/
_disableRadioButtons() {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
button.disabled = this._disabled;
});
}
}
/**
* @hidden
* @private
* @return {?}
*/
_setRadioButtonsRequired() {
if (this.radioButtons) {
this.radioButtons.forEach((button) => {
button.required = this._required;
});
}
}
}
IgxRadioGroupDirective.decorators = [
{ type: Directive, args: [{
selector: 'igx-radio-group, [igxRadioGroup]',
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxRadioGroupDirective, multi: true }]
},] }
];
IgxRadioGroupDirective.propDecorators = {
radioButtons: [{ type: ContentChildren, args: [IgxRadioComponent,] }],
value: [{ type: Input }],
name: [{ type: Input }],
required: [{ type: Input }],
disabled: [{ type: Input }],
labelPosition: [{ type: Input }],
selected: [{ type: Input }],
change: [{ type: Output }],
cssClass: [{ type: HostBinding, args: ['class.igx-radio-group',] }]
};
if (false) {
/**
* Returns reference to the child radio buttons.
* ```typescript
* let radioButtons = this.radioGroup.radioButtons;
* ```
* \@memberof IgxRadioGroupDirective
* @type {?}
*/
IgxRadioGroupDirective.prototype.radioButtons;
/**
* An event that is emitted after the radio group `value` is changed.
* Provides references to the selected `IgxRadioComponent` and the `value` property as event arguments.
* \@memberof IgxRadioGroupDirective
* @type {?}
*/
IgxRadioGroupDirective.prototype.change;
/**
* @hidden
* @type {?}
*/
IgxRadioGroupDirective.prototype.cssClass;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._onChangeCallback;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._name;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._value;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._selected;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._isInitialized;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._labelPosition;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._disabled;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype._required;
/**
* @hidden
* @type {?}
* @private
*/
IgxRadioGroupDirective.prototype.destroy$;
}
/**
* @hidden
*/
export class IgxRadioModule {
}
IgxRadioModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxRadioGroupDirective, IgxRadioComponent],
exports: [IgxRadioGroupDirective, IgxRadioComponent],
imports: [IgxRippleModule]
},] }
];
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/directives/radio/radio-group.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    NgModule,\n    Input,\n    QueryList,\n    Output,\n    EventEmitter,\n    AfterContentInit,\n    ContentChildren,\n    OnDestroy,\n    HostBinding\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IgxRadioComponent, RadioLabelPosition, IChangeRadioEventArgs } from '../../radio/radio.component';\nimport { IgxRippleModule } from '../ripple/ripple.directive';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\nconst noop = () => { };\nlet nextId = 0;\n\n/**\n * **Ignite UI for Angular Radio Group** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/radio_button.html)\n *\n * The Ignite UI Radio Group allows the user to select a single option from an available set of options that are listed side by side.\n *\n * Example:\n * ```html\n * <igx-radio-group name=\"radioGroup\">\n *   <igx-radio *ngFor=\"let item of ['Foo', 'Bar', 'Baz']\" value=\"{{item}}\">\n *      {{item}}\n *   </igx-radio>\n * </igx-radio-group>\n * ```\n */\n@Directive({\n    selector: 'igx-radio-group, [igxRadioGroup]',\n    providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxRadioGroupDirective, multi: true }]\n})\nexport class IgxRadioGroupDirective implements AfterContentInit, ControlValueAccessor, OnDestroy {\n    /**\n     * Returns reference to the child radio buttons.\n     * ```typescript\n     * let radioButtons =  this.radioGroup.radioButtons;\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @ContentChildren(IgxRadioComponent) public radioButtons: QueryList<IgxRadioComponent>;\n\n    /**\n     * Sets/gets the `value` attribute.\n     * ```html\n     * <igx-radio-group [value] = \"'radioButtonValue'\"></igx-radio-group>\n     * ```\n     * ```typescript\n     * let value =  this.radioGroup.value;\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @Input()\n    get value(): any { return this._value; }\n    set value(newValue: any) {\n        if (this._value !== newValue) {\n            this._value = newValue;\n            this._selectRadioButton();\n        }\n    }\n\n    /**\n     * Sets/gets the `name` attribute of the radio group component. All child radio buttons inherits this name.\n     * ```html\n     * <igx-radio-group name = \"Radio1\"></igx-radio-group>\n     *  ```\n     * ```typescript\n     * let name =  this.radioGroup.name;\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @Input()\n    get name(): string { return this._name; }\n    set name(newValue: string) {\n        if (this._name !== newValue) {\n            this._name = newValue;\n            this._setRadioButtonNames();\n        }\n    }\n\n    /**\n     * Sets/gets whether the radio group is required.\n     * If not set, `required` will have value `false`.\n     * ```html\n     * <igx-radio-group [required] = \"true\"></igx-radio-group>\n     * ```\n     * ```typescript\n     * let isRequired =  this.radioGroup.required;\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @Input()\n    get required(): boolean { return this._required; }\n    set required(newValue: boolean) {\n        if (this._required !== newValue) {\n            this._required = newValue;\n            this._setRadioButtonsRequired();\n        }\n    }\n\n    /**\n     * An @Input property that allows you to disable the radio group. By default it's false.\n     * ```html\n     * <igx-radio-group [disabled]=\"true\"></igx-radio-group>\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @Input()\n    get disabled(): boolean { return this._disabled; }\n    set disabled(newValue: boolean) {\n        if (this._disabled !== newValue) {\n            this._disabled = newValue;\n            this._disableRadioButtons();\n        }\n    }\n\n    /**\n     * Sets/gets the position of the `label` in the child radio buttons.\n     * If not set, `labelPosition` will have value `\"after\"`.\n     * ```html\n     * <igx-radio-group labelPosition = \"before\"></igx-radio-group>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.radioGroup.labelPosition;\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @Input()\n    get labelPosition(): RadioLabelPosition | string { return this._labelPosition; }\n    set labelPosition(newValue: RadioLabelPosition | string) {\n        if (this._labelPosition !== newValue) {\n            this._labelPosition = newValue === RadioLabelPosition.BEFORE ? RadioLabelPosition.BEFORE : RadioLabelPosition.AFTER;\n            this._setRadioButtonLabelPosition();\n        }\n    }\n\n    /**\n     * Sets/gets the selected child radio button.\n     * ```typescript\n     * let selectedButton = this.radioGroup.selected;\n     * this.radioGroup.selected = selectedButton;\n     * ```\n     * @memberof IgxRadioGroupDirective\n     */\n    @Input()\n    get selected() { return this._selected; }\n    set selected(selected: IgxRadioComponent | null) {\n        if (this._selected !== selected) {\n            this._selected = selected;\n            this.value = selected ? selected.value : null;\n        }\n    }\n\n    /**\n     * An event that is emitted after the radio group `value` is changed.\n     * Provides references to the selected `IgxRadioComponent` and the `value` property as event arguments.\n     * @memberof IgxRadioGroupDirective\n     */\n    @Output()\n    readonly change: EventEmitter<IChangeRadioEventArgs> = new EventEmitter<IChangeRadioEventArgs>();\n\n    /**\n     *@hidden\n     */\n    @HostBinding('class.igx-radio-group')\n    public cssClass = 'igx-radio-group';\n\n    /**\n     *@hidden\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n    /**\n     *@hidden\n     */\n    private _name = `igx-radio-group-${nextId++}`;\n    /**\n     *@hidden\n     */\n    private _value: any = null;\n    /**\n     *@hidden\n     */\n    private _selected: IgxRadioComponent | null = null;\n    /**\n     *@hidden\n     */\n    private _isInitialized = false;\n    /**\n     *@hidden\n     */\n    private _labelPosition: RadioLabelPosition | string = 'after';\n    /**\n     *@hidden\n     */\n    private _disabled = false;\n    /**\n     *@hidden\n     */\n    private _required = false;\n    /**\n     *@hidden\n     */\n    private destroy$ = new Subject<boolean>();\n\n    ngAfterContentInit() {\n        // The initial value can possibly be set by NgModel and it is possible that\n        // the OnInit of the NgModel occurs after the OnInit of this class.\n        this._isInitialized = true;\n\n        setTimeout(() => { this._initRadioButtons(); });\n    }\n\n    /**\n     * Checks whether the provided value is consistent to the current radio button.\n     * If it is, the checked attribute will have value `true` and selected property will contain the selected `IgxRadioComponent`.\n     * ```typescript\n     * this.radioGroup.writeValue('radioButtonValue');\n     * ```\n     */\n    public writeValue(value: any) {\n        this.value = value;\n    }\n\n    /**\n     *@hidden\n     */\n    public registerOnChange(fn: (_: any) => void) { this._onChangeCallback = fn; }\n\n    /**\n     *@hidden\n     */\n    public registerOnTouched(fn: () => void) {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                button.registerOnTouched(fn);\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     *@hidden\n     */\n    private _initRadioButtons() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                button.name = this._name;\n                button.labelPosition = this._labelPosition;\n                button.disabled = this._disabled;\n                button.required = this._required;\n\n                if (this._value && button.value === this._value) {\n                    button.checked = true;\n                    this._selected = button;\n                }\n\n                button.change.pipe(takeUntil(this.destroy$)).subscribe((ev) => this._selectedRadioButtonChanged(ev));\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private _selectedRadioButtonChanged(args: IChangeRadioEventArgs) {\n        if (this._selected !== args.radio) {\n            if (this._selected) {\n                this._selected.checked = false;\n            }\n            this._selected = args.radio;\n        }\n\n        this._value = args.value;\n\n        if (this._isInitialized) {\n            this.change.emit(args);\n            this._onChangeCallback(this.value);\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private _setRadioButtonNames() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                button.name = this._name;\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private _selectRadioButton() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                if (!this._value) {\n                    // no value - uncheck all radio buttons\n                    if (button.checked) {\n                        button.checked = false;\n                    }\n                } else {\n                    if (this._value === button.value) {\n                        // selected button\n                        if (this._selected !== button) {\n                            this._selected = button;\n                        }\n\n                        if (!button.checked) {\n                            button.select();\n                        }\n                    } else {\n                        // non-selected button\n                        if (button.checked) {\n                            button.checked = false;\n                        }\n                    }\n                }\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private _setRadioButtonLabelPosition() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                button.labelPosition = this._labelPosition;\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private _disableRadioButtons() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                button.disabled = this._disabled;\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private _setRadioButtonsRequired() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                button.required = this._required;\n            });\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxRadioGroupDirective, IgxRadioComponent],\n    exports: [IgxRadioGroupDirective, IgxRadioComponent],\n    imports: [IgxRippleModule]\n})\nexport class IgxRadioModule { }\n"]}