UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

485 lines 36.4 kB
/** * @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"]}