igniteui-angular 15.0.14 → 15.0.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/directives/radio/radio-group.directive.mjs +52 -6
- package/esm2020/lib/grids/grid-base.directive.mjs +3 -2
- package/esm2020/lib/radio/radio.component.mjs +13 -2
- package/fesm2015/igniteui-angular.mjs +123 -66
- package/fesm2015/igniteui-angular.mjs.map +1 -1
- package/fesm2020/igniteui-angular.mjs +121 -64
- package/fesm2020/igniteui-angular.mjs.map +1 -1
- package/lib/directives/radio/radio-group.directive.d.ts +5 -0
- package/lib/radio/radio.component.d.ts +10 -1
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ContentChildren, Directive, EventEmitter, HostBinding, Input, NgModule, Output } from '@angular/core';
|
|
1
|
+
import { ContentChildren, Directive, EventEmitter, HostBinding, HostListener, Input, NgModule, Output } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
import { noop, Subject } from 'rxjs';
|
|
4
4
|
import { startWith, takeUntil } from 'rxjs/operators';
|
|
@@ -6,6 +6,7 @@ import { mkenum } from '../../core/utils';
|
|
|
6
6
|
import { IgxRadioComponent } from '../../radio/radio.component';
|
|
7
7
|
import { IgxRippleModule } from '../ripple/ripple.directive';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../services/direction/directionality";
|
|
9
10
|
/**
|
|
10
11
|
* Determines the Radio Group alignment
|
|
11
12
|
*/
|
|
@@ -38,7 +39,8 @@ let nextId = 0;
|
|
|
38
39
|
* ```
|
|
39
40
|
*/
|
|
40
41
|
export class IgxRadioGroupDirective {
|
|
41
|
-
constructor() {
|
|
42
|
+
constructor(_directionality) {
|
|
43
|
+
this._directionality = _directionality;
|
|
42
44
|
/**
|
|
43
45
|
* An event that is emitted after the radio group `value` is changed.
|
|
44
46
|
*
|
|
@@ -180,6 +182,44 @@ export class IgxRadioGroupDirective {
|
|
|
180
182
|
this.value = selected ? selected.value : null;
|
|
181
183
|
}
|
|
182
184
|
}
|
|
185
|
+
handleClick(event) {
|
|
186
|
+
event.stopPropagation();
|
|
187
|
+
this.selected.nativeElement.focus();
|
|
188
|
+
}
|
|
189
|
+
handleKeyDown(event) {
|
|
190
|
+
const { key } = event;
|
|
191
|
+
if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(key)) {
|
|
192
|
+
const buttons = this.radioButtons.filter(radio => !radio.disabled);
|
|
193
|
+
const checked = buttons.find((radio) => radio.checked);
|
|
194
|
+
let index = checked ? buttons.indexOf(checked) : -1;
|
|
195
|
+
const ltr = this._directionality.value === 'ltr';
|
|
196
|
+
switch (key) {
|
|
197
|
+
case 'ArrowUp':
|
|
198
|
+
index += -1;
|
|
199
|
+
break;
|
|
200
|
+
case 'ArrowLeft':
|
|
201
|
+
index += ltr ? -1 : 1;
|
|
202
|
+
break;
|
|
203
|
+
case 'ArrowRight':
|
|
204
|
+
index += ltr ? 1 : -1;
|
|
205
|
+
break;
|
|
206
|
+
default:
|
|
207
|
+
index += 1;
|
|
208
|
+
}
|
|
209
|
+
if (index < 0)
|
|
210
|
+
index = buttons.length - 1;
|
|
211
|
+
if (index > buttons.length - 1)
|
|
212
|
+
index = 0;
|
|
213
|
+
buttons.forEach((radio) => {
|
|
214
|
+
radio.deselect();
|
|
215
|
+
radio.nativeElement.blur();
|
|
216
|
+
});
|
|
217
|
+
buttons[index].focused = true;
|
|
218
|
+
buttons[index].nativeElement.focus();
|
|
219
|
+
buttons[index].select();
|
|
220
|
+
event.preventDefault();
|
|
221
|
+
}
|
|
222
|
+
}
|
|
183
223
|
/**
|
|
184
224
|
* Returns the alignment of the `igx-radio-group`.
|
|
185
225
|
* ```typescript
|
|
@@ -353,8 +393,8 @@ export class IgxRadioGroupDirective {
|
|
|
353
393
|
}
|
|
354
394
|
}
|
|
355
395
|
}
|
|
356
|
-
IgxRadioGroupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxRadioGroupDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
357
|
-
IgxRadioGroupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.0", type: IgxRadioGroupDirective, selector: "igx-radio-group, [igxRadioGroup]", inputs: { value: "value", name: "name", required: "required", selected: "selected", alignment: "alignment" }, outputs: { change: "change" }, host: { properties: { "class.igx-radio-group": "this.cssClass", "class.igx-radio-group--vertical": "this.vertical" } }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxRadioGroupDirective, multi: true }], queries: [{ propertyName: "radioButtons", predicate: IgxRadioComponent, descendants: true }], exportAs: ["igxRadioGroup"], ngImport: i0 });
|
|
396
|
+
IgxRadioGroupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxRadioGroupDirective, deps: [{ token: i1.IgxDirectionality }], target: i0.ɵɵFactoryTarget.Directive });
|
|
397
|
+
IgxRadioGroupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.0", type: IgxRadioGroupDirective, selector: "igx-radio-group, [igxRadioGroup]", inputs: { value: "value", name: "name", required: "required", selected: "selected", alignment: "alignment" }, outputs: { change: "change" }, host: { listeners: { "click": "handleClick($event)", "keydown": "handleKeyDown($event)" }, properties: { "class.igx-radio-group": "this.cssClass", "class.igx-radio-group--vertical": "this.vertical" } }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxRadioGroupDirective, multi: true }], queries: [{ propertyName: "radioButtons", predicate: IgxRadioComponent, descendants: true }], exportAs: ["igxRadioGroup"], ngImport: i0 });
|
|
358
398
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxRadioGroupDirective, decorators: [{
|
|
359
399
|
type: Directive,
|
|
360
400
|
args: [{
|
|
@@ -362,7 +402,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
|
|
|
362
402
|
selector: 'igx-radio-group, [igxRadioGroup]',
|
|
363
403
|
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxRadioGroupDirective, multi: true }]
|
|
364
404
|
}]
|
|
365
|
-
}], propDecorators: { radioButtons: [{
|
|
405
|
+
}], ctorParameters: function () { return [{ type: i1.IgxDirectionality }]; }, propDecorators: { radioButtons: [{
|
|
366
406
|
type: ContentChildren,
|
|
367
407
|
args: [IgxRadioComponent, { descendants: true }]
|
|
368
408
|
}], value: [{
|
|
@@ -381,6 +421,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
|
|
|
381
421
|
}], vertical: [{
|
|
382
422
|
type: HostBinding,
|
|
383
423
|
args: ['class.igx-radio-group--vertical']
|
|
424
|
+
}], handleClick: [{
|
|
425
|
+
type: HostListener,
|
|
426
|
+
args: ['click', ['$event']]
|
|
427
|
+
}], handleKeyDown: [{
|
|
428
|
+
type: HostListener,
|
|
429
|
+
args: ['keydown', ['$event']]
|
|
384
430
|
}], alignment: [{
|
|
385
431
|
type: Input
|
|
386
432
|
}] } });
|
|
@@ -400,4 +446,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
|
|
|
400
446
|
imports: [IgxRippleModule]
|
|
401
447
|
}]
|
|
402
448
|
}] });
|
|
403
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/radio/radio-group.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ContentChildren, Directive, EventEmitter, HostBinding, Input, NgModule, OnDestroy, Output, QueryList\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\nimport { mkenum } from '../../core/utils';\nimport { IChangeRadioEventArgs, IgxRadioComponent } from '../../radio/radio.component';\nimport { IgxRippleModule } from '../ripple/ripple.directive';\n\n/**\n * Determines the Radio Group alignment\n */\nexport const RadioGroupAlignment = mkenum({\n    horizontal: 'horizontal',\n    vertical: 'vertical'\n});\nexport type RadioGroupAlignment = typeof RadioGroupAlignment[keyof typeof RadioGroupAlignment];\n\nlet nextId = 0;\n\n/**\n * Radio group directive renders set of radio buttons.\n *\n * @igxModule IgxRadioModule\n *\n * @igxTheme igx-radio-theme\n *\n * @igxKeywords radiogroup, radio, button, input\n *\n * @igxGroup Data Entry & Display\n *\n * @remarks\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    exportAs: 'igxRadioGroup',\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    private static ngAcceptInputType_required: boolean | '';\n    /**\n     * Returns reference to the child radio buttons.\n     *\n     * @example\n     * ```typescript\n     * let radioButtons =  this.radioGroup.radioButtons;\n     * ```\n     */\n    @ContentChildren(IgxRadioComponent, { descendants: true }) public radioButtons: QueryList<IgxRadioComponent>;\n\n    /**\n     * Sets/gets the `value` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group [value] = \"'radioButtonValue'\"></igx-radio-group>\n     * ```\n     */\n    @Input()\n    public get value(): any {\n        return this._value;\n    }\n    public 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     *\n     * @example\n     * ```html\n     * <igx-radio-group name = \"Radio1\"></igx-radio-group>\n     *  ```\n     */\n    @Input()\n    public get name(): string {\n        return this._name;\n    }\n    public 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     *\n     * @remarks\n     * If not set, `required` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group [required] = \"true\"></igx-radio-group>\n     * ```\n     */\n    @Input()\n    public get required(): boolean {\n        return this._required;\n    }\n    public set required(value: boolean) {\n        this._required = (value as any) === '' || value;\n        this._setRadioButtonsRequired();\n    }\n\n    /**\n     * Sets/gets the selected child radio button.\n     *\n     * @example\n     * ```typescript\n     * let selectedButton = this.radioGroup.selected;\n     * this.radioGroup.selected = selectedButton;\n     * ```\n     */\n    @Input()\n    public get selected() {\n        return this._selected;\n    }\n    public 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     *\n     * @remarks\n     * Provides references to the selected `IgxRadioComponent` and the `value` property as event arguments.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group (change)=\"handler($event)\"></igx-radio-group>\n     * ```\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeRadioEventArgs> = new EventEmitter<IChangeRadioEventArgs>();\n\n    /**\n     * The css class applied to the component.\n     *\n     * @hidden\n     * @internal\n     */\n    @HostBinding('class.igx-radio-group')\n    public cssClass = 'igx-radio-group';\n\n    /**\n     * Sets vertical alignment to the radio group, if `alignment` is set to `vertical`.\n     * By default the alignment is horizontal.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group alignment=\"vertical\"></igx-radio-group>\n     * ```\n     */\n    @HostBinding('class.igx-radio-group--vertical')\n    private vertical = false;\n\n    /**\n     * Returns the alignment of the `igx-radio-group`.\n     * ```typescript\n     * @ViewChild(\"MyRadioGroup\")\n     * public radioGroup: IgxRadioGroupDirective;\n     * ngAfterViewInit(){\n     *    let radioAlignment = this.radioGroup.alignment;\n     * }\n     * ```\n     */\n    @Input()\n    public get alignment(): RadioGroupAlignment {\n        return this.vertical ? RadioGroupAlignment.vertical : RadioGroupAlignment.horizontal;\n    }\n    /**\n     * Allows you to set the radio group alignment.\n     * Available options are `RadioGroupAlignment.horizontal` (default) and `RadioGroupAlignment.vertical`.\n     * ```typescript\n     * public alignment = RadioGroupAlignment.vertical;\n     * //..\n     * ```\n     * ```html\n     * <igx-radio-group [alignment]=\"alignment\"></igx-radio-group>\n     * ```\n     */\n    public set alignment(value: RadioGroupAlignment) {\n        this.vertical = value === RadioGroupAlignment.vertical;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _name = `igx-radio-group-${nextId++}`;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _value: any = null;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _selected: IgxRadioComponent | null = null;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _isInitialized = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private destroy$ = new Subject<boolean>();\n    /**\n     * @hidden\n     * @internal\n     */\n    private queryChange$ = new Subject();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public 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        this.radioButtons.changes.pipe(startWith(0), takeUntil(this.destroy$)).subscribe(() => {\n            this.queryChange$.next();\n            setTimeout(() => this._initRadioButtons());\n        });\n    }\n\n    /**\n     * Sets the \"checked\" property value on the radio input element.\n     *\n     * @remarks\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     *\n     * @example\n     * ```typescript\n     * this.radioGroup.writeValue('radioButtonValue');\n     * ```\n     */\n    public writeValue(value: any) {\n        this.value = value;\n    }\n\n    /**\n     * Registers a function called when the control value changes.\n     *\n     * @hidden\n     * @internal\n     */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /**\n     * Registers a function called when the control is touched.\n     *\n     * @hidden\n     * @internal\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     * @internal\n     */\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _initRadioButtons() {\n        if (this.radioButtons) {\n            const props = { name: this._name, required: this._required };\n            this.radioButtons.forEach((button) => {\n                Object.assign(button, props);\n\n                if (button.value === this._value) {\n                    button.checked = true;\n                    this._selected = button;\n                }\n\n                button.change.pipe(\n                    takeUntil(button.destroy$),\n                    takeUntil(this.destroy$),\n                    takeUntil(this.queryChange$)\n                ).subscribe((ev) => this._selectedRadioButtonChanged(ev));\n            });\n        }\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _selectedRadioButtonChanged(args: IChangeRadioEventArgs) {\n        this.radioButtons.forEach((button) => {\n            button.checked = button.id === args.radio.id;\n        });\n\n        this._selected = args.radio;\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     * @internal\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     * @internal\n     */\n    private _selectRadioButton() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                if (this._value === null) {\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     * @internal\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"]}
|
|
449
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/radio/radio-group.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit, \n    ContentChildren,\n    Directive,\n    EventEmitter,\n    HostBinding, \n    HostListener, \n    Input, \n    NgModule, \n    OnDestroy, \n    Output, \n    QueryList\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\nimport { mkenum } from '../../core/utils';\nimport { IChangeRadioEventArgs, IgxRadioComponent } from '../../radio/radio.component';\nimport { IgxDirectionality } from '../../services/direction/directionality';\nimport { IgxRippleModule } from '../ripple/ripple.directive';\n\n/**\n * Determines the Radio Group alignment\n */\nexport const RadioGroupAlignment = mkenum({\n    horizontal: 'horizontal',\n    vertical: 'vertical'\n});\nexport type RadioGroupAlignment = typeof RadioGroupAlignment[keyof typeof RadioGroupAlignment];\n\nlet nextId = 0;\n\n/**\n * Radio group directive renders set of radio buttons.\n *\n * @igxModule IgxRadioModule\n *\n * @igxTheme igx-radio-theme\n *\n * @igxKeywords radiogroup, radio, button, input\n *\n * @igxGroup Data Entry & Display\n *\n * @remarks\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    exportAs: 'igxRadioGroup',\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    private static ngAcceptInputType_required: boolean | '';\n    /**\n     * Returns reference to the child radio buttons.\n     *\n     * @example\n     * ```typescript\n     * let radioButtons =  this.radioGroup.radioButtons;\n     * ```\n     */\n    @ContentChildren(IgxRadioComponent, { descendants: true }) public radioButtons: QueryList<IgxRadioComponent>;\n\n    /**\n     * Sets/gets the `value` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group [value] = \"'radioButtonValue'\"></igx-radio-group>\n     * ```\n     */\n    @Input()\n    public get value(): any {\n        return this._value;\n    }\n    public 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     *\n     * @example\n     * ```html\n     * <igx-radio-group name = \"Radio1\"></igx-radio-group>\n     *  ```\n     */\n    @Input()\n    public get name(): string {\n        return this._name;\n    }\n    public 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     *\n     * @remarks\n     * If not set, `required` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group [required] = \"true\"></igx-radio-group>\n     * ```\n     */\n    @Input()\n    public get required(): boolean {\n        return this._required;\n    }\n    public set required(value: boolean) {\n        this._required = (value as any) === '' || value;\n        this._setRadioButtonsRequired();\n    }\n\n    /**\n     * Sets/gets the selected child radio button.\n     *\n     * @example\n     * ```typescript\n     * let selectedButton = this.radioGroup.selected;\n     * this.radioGroup.selected = selectedButton;\n     * ```\n     */\n    @Input()\n    public get selected() {\n        return this._selected;\n    }\n    public 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     *\n     * @remarks\n     * Provides references to the selected `IgxRadioComponent` and the `value` property as event arguments.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group (change)=\"handler($event)\"></igx-radio-group>\n     * ```\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeRadioEventArgs> = new EventEmitter<IChangeRadioEventArgs>();\n\n    /**\n     * The css class applied to the component.\n     *\n     * @hidden\n     * @internal\n     */\n    @HostBinding('class.igx-radio-group')\n    public cssClass = 'igx-radio-group';\n\n    /**\n     * Sets vertical alignment to the radio group, if `alignment` is set to `vertical`.\n     * By default the alignment is horizontal.\n     *\n     * @example\n     * ```html\n     * <igx-radio-group alignment=\"vertical\"></igx-radio-group>\n     * ```\n     */\n    @HostBinding('class.igx-radio-group--vertical')\n    private vertical = false;\n\n    @HostListener('click', ['$event'])\n    protected handleClick(event: MouseEvent) {\n        event.stopPropagation();\n        this.selected.nativeElement.focus();\n    }\n\n    @HostListener('keydown', ['$event'])\n    protected handleKeyDown(event: KeyboardEvent) {\n        const { key } = event;\n\n        if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(key)) {\n            const buttons = this.radioButtons.filter(radio => !radio.disabled);\n            const checked = buttons.find((radio) => radio.checked);\n            let index = checked ? buttons.indexOf(checked!) : -1;\n            const ltr = this._directionality.value === 'ltr';\n\n            switch (key) {\n                case 'ArrowUp':\n                    index += -1;\n                    break;\n                case 'ArrowLeft':\n                    index += ltr ? -1 : 1;\n                    break;\n                case 'ArrowRight':\n                    index += ltr ? 1 : -1;\n                    break;\n                default:\n                    index += 1;\n            }\n\n            if (index < 0) index = buttons.length - 1;\n            if (index > buttons.length - 1) index = 0;\n\n            buttons.forEach((radio) => {\n                radio.deselect();\n                radio.nativeElement.blur();\n            });\n\n            buttons[index].focused = true;\n            buttons[index].nativeElement.focus();\n            buttons[index].select();\n            event.preventDefault();\n        }\n    }\n\n    /**\n     * Returns the alignment of the `igx-radio-group`.\n     * ```typescript\n     * @ViewChild(\"MyRadioGroup\")\n     * public radioGroup: IgxRadioGroupDirective;\n     * ngAfterViewInit(){\n     *    let radioAlignment = this.radioGroup.alignment;\n     * }\n     * ```\n     */\n    @Input()\n    public get alignment(): RadioGroupAlignment {\n        return this.vertical ? RadioGroupAlignment.vertical : RadioGroupAlignment.horizontal;\n    }\n    /**\n     * Allows you to set the radio group alignment.\n     * Available options are `RadioGroupAlignment.horizontal` (default) and `RadioGroupAlignment.vertical`.\n     * ```typescript\n     * public alignment = RadioGroupAlignment.vertical;\n     * //..\n     * ```\n     * ```html\n     * <igx-radio-group [alignment]=\"alignment\"></igx-radio-group>\n     * ```\n     */\n    public set alignment(value: RadioGroupAlignment) {\n        this.vertical = value === RadioGroupAlignment.vertical;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _name = `igx-radio-group-${nextId++}`;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _value: any = null;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _selected: IgxRadioComponent | null = null;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _isInitialized = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private destroy$ = new Subject<boolean>();\n    /**\n     * @hidden\n     * @internal\n     */\n    private queryChange$ = new Subject();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public 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        this.radioButtons.changes.pipe(startWith(0), takeUntil(this.destroy$)).subscribe(() => {\n            this.queryChange$.next();\n            setTimeout(() => this._initRadioButtons());\n        });\n    }\n\n    /**\n     * Sets the \"checked\" property value on the radio input element.\n     *\n     * @remarks\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     *\n     * @example\n     * ```typescript\n     * this.radioGroup.writeValue('radioButtonValue');\n     * ```\n     */\n    public writeValue(value: any) {\n        this.value = value;\n    }\n\n    /**\n     * Registers a function called when the control value changes.\n     *\n     * @hidden\n     * @internal\n     */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /**\n     * Registers a function called when the control is touched.\n     *\n     * @hidden\n     * @internal\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     * @internal\n     */\n    public ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    constructor(private _directionality: IgxDirectionality) {}\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _initRadioButtons() {\n        if (this.radioButtons) {\n            const props = { name: this._name, required: this._required };\n            this.radioButtons.forEach((button) => {\n                Object.assign(button, props);\n\n                if (button.value === this._value) {\n                    button.checked = true;\n                    this._selected = button;\n                }\n\n                button.change.pipe(\n                    takeUntil(button.destroy$),\n                    takeUntil(this.destroy$),\n                    takeUntil(this.queryChange$)\n                ).subscribe((ev) => this._selectedRadioButtonChanged(ev));\n            });\n        }\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _selectedRadioButtonChanged(args: IChangeRadioEventArgs) {\n        this.radioButtons.forEach((button) => {\n            button.checked = button.id === args.radio.id;\n        });\n\n        this._selected = args.radio;\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     * @internal\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     * @internal\n     */\n    private _selectRadioButton() {\n        if (this.radioButtons) {\n            this.radioButtons.forEach((button) => {\n                if (this._value === null) {\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     * @internal\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"]}
|