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.
@@ -167,6 +167,17 @@ export class IgxRadioComponent {
167
167
  */
168
168
  this._onChangeCallback = noop;
169
169
  }
170
+ /**
171
+ * Gets the `nativeElement` of the igx-radio.
172
+ *
173
+ * @example
174
+ * ```typescript
175
+ * let igxRadioNativeElement = this.igxRadio.nativeElement;
176
+ * ```
177
+ */
178
+ get nativeElement() {
179
+ return this.nativeRadio.nativeElement;
180
+ }
170
181
  /**
171
182
  * Sets/gets whether the radio button is required.
172
183
  * If not set, `required` will have value `false`.
@@ -215,7 +226,7 @@ export class IgxRadioComponent {
215
226
  * @hidden
216
227
  * @internal
217
228
  */
218
- _changed() {
229
+ _changed(event) {
219
230
  if (event instanceof Event) {
220
231
  event.preventDefault();
221
232
  }
@@ -400,4 +411,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
400
411
  type: HostListener,
401
412
  args: ['click']
402
413
  }] } });
403
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/radio/radio.component.ts","../../../../../projects/igniteui-angular/src/lib/radio/radio.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef, Component, ElementRef, EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop, Subject } from 'rxjs';\nimport { EditorProvider } from '../core/edit-provider';\nimport { IBaseEventArgs, mkenum } from '../core/utils';\n\nexport interface IChangeRadioEventArgs extends IBaseEventArgs {\n    value: any;\n    radio: IgxRadioComponent;\n}\n\nexport const RadioLabelPosition = mkenum({\n    BEFORE: 'before',\n    AFTER: 'after'\n});\nexport type RadioLabelPosition = (typeof RadioLabelPosition)[keyof typeof RadioLabelPosition];\n\nlet nextId = 0;\n/**\n * **Ignite UI for Angular Radio Button** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/radio_button.html)\n *\n * The Ignite UI Radio Button 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>\n *   Simple radio button\n * </igx-radio>\n * ```\n */\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxRadioComponent,\n            multi: true,\n        },\n    ],\n    selector: 'igx-radio',\n    templateUrl: 'radio.component.html'\n})\nexport class IgxRadioComponent implements ControlValueAccessor, EditorProvider, OnDestroy {\n    private static ngAcceptInputType_required: boolean | '';\n    private static ngAcceptInputType_disabled: boolean | '';\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public destroy$ = new Subject<boolean>();\n\n    /**\n     * Returns reference to native radio element.\n     * ```typescript\n     * let radioElement =  this.radio.nativeRadio;\n     * ```\n     *\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('radio', { static: true })\n    public nativeRadio: ElementRef;\n\n    /**\n     * Returns reference to native label element.\n     * ```typescript\n     * let labelElement =  this.radio.nativeLabel;\n     * ```\n     *\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('nativeLabel', { static: true })\n    public nativeLabel: ElementRef;\n\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     * let labelPlaceholder =  this.radio.placeholderLabel;\n     * ```\n     *\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('placeholderLabel', { static: true })\n    public placeholderLabel: ElementRef;\n\n    /**\n     * Sets/gets the `id` of the radio component.\n     * If not set, the `id` of the first radio component will be `\"igx-radio-0\"`.\n     * ```html\n     * <igx-radio id = \"my-first-radio\"></igx-radio>\n     * ```\n     * ```typescript\n     * let radioId =  this.radio.id;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-radio-${nextId++}`;\n\n    /**\n     * Sets/gets the id of the `label` element in the radio component.\n     * If not set, the id of the `label` in the first radio component will be `\"igx-radio-0-label\"`.\n     * ```html\n     * <igx-radio labelId = \"Label1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let labelId =  this.radio.labelId;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public labelId = `${this.id}-label`;\n\n    /**\n     * Sets/gets the position of the `label` in the radio component.\n     * If not set, `labelPosition` will have value `\"after\"`.\n     * ```html\n     * <igx-radio labelPosition = \"before\"></igx-radio>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.radio.labelPosition;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public labelPosition: RadioLabelPosition | string;\n\n    /**\n     * Sets/gets the `value` attribute.\n     * ```html\n     * <igx-radio [value] = \"'radioButtonValue'\"></igx-radio>\n     * ```\n     * ```typescript\n     * let value =  this.radio.value;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public value: any;\n\n    /**\n     * Sets/gets the `name` attribute of the radio component.\n     * ```html\n     * <igx-radio name = \"Radio1\"></igx-radio>\n     *  ```\n     * ```typescript\n     * let name =  this.radio.name;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public name: string;\n\n    /**\n     * Sets the value of the `tabindex` attribute.\n     * ```html\n     * <igx-radio [tabindex] = \"1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.radio.tabindex;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public tabindex: number = null;\n\n    /**\n     * Enables/disables the ripple effect on the radio button..\n     * If not set, the `disableRipple` will have value `false`.\n     * ```html\n     * <igx-radio [disableRipple] = \"true\"></igx-radio>\n     * ```\n     * ```typescript\n     * let isDisabledRipple =  this.radio.disableRipple;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public disableRipple = false;\n\n    /**\n     * Sets/gets whether the radio button is required.\n     * If not set, `required` will have value `false`.\n     * ```html\n     * <igx-radio required></igx-radio>\n     * ```\n     * ```typescript\n     * let isRequired =  this.radio.required;\n     * ```\n     *\n     * @memberof IgxRadioComponent\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     }\n\n    /**\n     * Sets/gets the `aria-labelledby` attribute of the radio component.\n     * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute.\n     * ```html\n     * <igx-radio aria-labelledby = \"Radio1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.radio.ariaLabelledBy;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n\n    /**\n     * Sets/gets the `aria-label` attribute of the radio component.\n     * ```html\n     * <igx-radio aria-label = \"Radio1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let ariaLabel =  this.radio.ariaLabel;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n\n    /**\n     * An event that is emitted after the radio `value` is changed.\n     * Provides references to the `IgxRadioComponent` and the `value` property as event arguments.\n     *\n     * @memberof IgxRadioComponent\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeRadioEventArgs> = new EventEmitter<IChangeRadioEventArgs>();\n\n    /**\n     * Returns the class of the radio component.\n     * ```typescript\n     * let radioClass = this.radio.cssClass;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio')\n    public cssClass = 'igx-radio';\n\n    /**\n     * Sets/gets  the `checked` attribute.\n     * Default value is `false`.\n     * ```html\n     * <igx-radio [checked] = \"true\"></igx-radio>\n     * ```\n     * ```typescript\n     * let isChecked =  this.radio.checked;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--checked')\n    @Input()\n    public checked = false;\n\n    /**\n     * Sets/gets  the `disabled` attribute.\n     * Default value is `false`.\n     * ```html\n     * <igx-radio disabled></igx-radio>\n     * ```\n     * ```typescript\n     * let isDisabled =  this.radio.disabled;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--disabled')\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled || false;\n    }\n    public set disabled(value: boolean) {\n        this._disabled = (value as any === '') || value;\n    }\n\n    /**\n     * Sets/gets whether the radio component is on focus.\n     * Default value is `false`.\n     * ```typescript\n     * this.radio.focus = true;\n     * ```\n     * ```typescript\n     * let isFocused =  this.radio.focused;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--focused')\n    public focused = false;\n\n    /**\n     * @hidden\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _disabled: boolean;\n    /**\n     * @hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n\n    /**\n     * @hidden\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n\n    constructor(private cdr: ChangeDetectorRef) { }\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      @HostListener('change', ['$event'])\n      public _changed(){\n          if(event instanceof Event){\n            event.preventDefault();\n          }\n      }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostListener('keyup', ['$event'])\n    public onKeyUp(event: KeyboardEvent) {\n        event.stopPropagation();\n        this.focused = true;\n        this.select();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click')\n    public _clicked() {\n        this.select();\n    }\n\n    /**\n     * Selects the current radio button.\n     * ```typescript\n     * this.radio.select();\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    public select() {\n        if(!this.checked) {\n            this.checked = true;\n            this.change.emit({ value: this.value, radio: this });\n            this._onChangeCallback(this.value);\n        }\n    }\n\n    /**\n     * Deselects the current radio button.\n     * ```typescript\n     * this.radio.deselect();\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    public deselect() {\n        this.checked = false;\n        this.focused = false;\n        this.cdr.markForCheck();\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`;\n     * ```typescript\n     * this.radio.writeValue('radioButtonValue');\n     * ```\n     */\n    public writeValue(value: any) {\n        this.value = this.value || value;\n\n        if (value === this.value) {\n            this.select();\n        } else {\n            this.deselect();\n        }\n    }\n\n    /** @hidden */\n    public getEditElement() {\n        return this.nativeRadio.nativeElement;\n    }\n\n    /**\n     * @hidden\n     */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case RadioLabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case RadioLabelPosition.AFTER:\n            default:\n                return `${this.cssClass}__label`;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public onBlur() {\n        this.focused = false;\n        this._onTouchedCallback();\n    }\n\n    /**\n     * @hidden\n     */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /**\n     * @hidden\n     */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /**\n     * @hidden\n     */\n    public setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n}\n","<input #radio class=\"igx-radio__input\" type=\"radio\"\n    [id]=\"inputId\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [tabindex]=\"tabindex\"\n    [disabled]=\"disabled\"\n    [checked]=\"checked\"\n    [required]=\"required\"\n    [attr.aria-checked]=\"checked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (blur)=\"onBlur()\" />\n\n<span #nativeLabel class=\"igx-radio__composite\" igxRipple\n    igxRippleTarget=\".igx-radio__ripple\"\n    [igxRippleDisabled]=\"disableRipple\"\n    [igxRippleCentered]=\"true\"\n    [igxRippleDuration]=\"300\">\n    <div class=\"igx-radio__ripple\"></div>\n</span>\n\n<span #placeholderLabel\n    [id]=\"labelId\"\n    [class]=\"labelClass\">\n    <ng-content></ng-content>\n</span>\n"]}
414
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/radio/radio.component.ts","../../../../../projects/igniteui-angular/src/lib/radio/radio.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop, Subject } from 'rxjs';\nimport { EditorProvider } from '../core/edit-provider';\nimport { IBaseEventArgs, mkenum } from '../core/utils';\n\nexport interface IChangeRadioEventArgs extends IBaseEventArgs {\n    value: any;\n    radio: IgxRadioComponent;\n}\n\nexport const RadioLabelPosition = mkenum({\n    BEFORE: 'before',\n    AFTER: 'after'\n});\nexport type RadioLabelPosition = (typeof RadioLabelPosition)[keyof typeof RadioLabelPosition];\n\nlet nextId = 0;\n/**\n * **Ignite UI for Angular Radio Button** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/radio_button.html)\n *\n * The Ignite UI Radio Button 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>\n *   Simple radio button\n * </igx-radio>\n * ```\n */\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxRadioComponent,\n            multi: true,\n        },\n    ],\n    selector: 'igx-radio',\n    templateUrl: 'radio.component.html'\n})\nexport class IgxRadioComponent implements ControlValueAccessor, EditorProvider, OnDestroy {\n    private static ngAcceptInputType_required: boolean | '';\n    private static ngAcceptInputType_disabled: boolean | '';\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public destroy$ = new Subject<boolean>();\n\n    /**\n     * Returns reference to native radio element.\n     * ```typescript\n     * let radioElement =  this.radio.nativeRadio;\n     * ```\n     *\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('radio', { static: true })\n    public nativeRadio: ElementRef;\n\n    /**\n     * Returns reference to native label element.\n     * ```typescript\n     * let labelElement =  this.radio.nativeLabel;\n     * ```\n     *\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('nativeLabel', { static: true })\n    public nativeLabel: ElementRef;\n\n    /**\n     * Gets the `nativeElement` of the igx-radio.\n     *\n     * @example\n     * ```typescript\n     * let igxRadioNativeElement = this.igxRadio.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.nativeRadio.nativeElement;\n    }\n\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     * let labelPlaceholder =  this.radio.placeholderLabel;\n     * ```\n     *\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('placeholderLabel', { static: true })\n    public placeholderLabel: ElementRef;\n\n    /**\n     * Sets/gets the `id` of the radio component.\n     * If not set, the `id` of the first radio component will be `\"igx-radio-0\"`.\n     * ```html\n     * <igx-radio id = \"my-first-radio\"></igx-radio>\n     * ```\n     * ```typescript\n     * let radioId =  this.radio.id;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-radio-${nextId++}`;\n\n    /**\n     * Sets/gets the id of the `label` element in the radio component.\n     * If not set, the id of the `label` in the first radio component will be `\"igx-radio-0-label\"`.\n     * ```html\n     * <igx-radio labelId = \"Label1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let labelId =  this.radio.labelId;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public labelId = `${this.id}-label`;\n\n    /**\n     * Sets/gets the position of the `label` in the radio component.\n     * If not set, `labelPosition` will have value `\"after\"`.\n     * ```html\n     * <igx-radio labelPosition = \"before\"></igx-radio>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.radio.labelPosition;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public labelPosition: RadioLabelPosition | string;\n\n    /**\n     * Sets/gets the `value` attribute.\n     * ```html\n     * <igx-radio [value] = \"'radioButtonValue'\"></igx-radio>\n     * ```\n     * ```typescript\n     * let value =  this.radio.value;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public value: any;\n\n    /**\n     * Sets/gets the `name` attribute of the radio component.\n     * ```html\n     * <igx-radio name = \"Radio1\"></igx-radio>\n     *  ```\n     * ```typescript\n     * let name =  this.radio.name;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public name: string;\n\n    /**\n     * Sets the value of the `tabindex` attribute.\n     * ```html\n     * <igx-radio [tabindex] = \"1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.radio.tabindex;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public tabindex: number = null;\n\n    /**\n     * Enables/disables the ripple effect on the radio button..\n     * If not set, the `disableRipple` will have value `false`.\n     * ```html\n     * <igx-radio [disableRipple] = \"true\"></igx-radio>\n     * ```\n     * ```typescript\n     * let isDisabledRipple =  this.radio.disableRipple;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input()\n    public disableRipple = false;\n\n    /**\n     * Sets/gets whether the radio button is required.\n     * If not set, `required` will have value `false`.\n     * ```html\n     * <igx-radio required></igx-radio>\n     * ```\n     * ```typescript\n     * let isRequired =  this.radio.required;\n     * ```\n     *\n     * @memberof IgxRadioComponent\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     }\n\n    /**\n     * Sets/gets the `aria-labelledby` attribute of the radio component.\n     * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute.\n     * ```html\n     * <igx-radio aria-labelledby = \"Radio1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.radio.ariaLabelledBy;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n\n    /**\n     * Sets/gets the `aria-label` attribute of the radio component.\n     * ```html\n     * <igx-radio aria-label = \"Radio1\"></igx-radio>\n     * ```\n     * ```typescript\n     * let ariaLabel =  this.radio.ariaLabel;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n\n    /**\n     * An event that is emitted after the radio `value` is changed.\n     * Provides references to the `IgxRadioComponent` and the `value` property as event arguments.\n     *\n     * @memberof IgxRadioComponent\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeRadioEventArgs> = new EventEmitter<IChangeRadioEventArgs>();\n\n    /**\n     * Returns the class of the radio component.\n     * ```typescript\n     * let radioClass = this.radio.cssClass;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio')\n    public cssClass = 'igx-radio';\n\n    /**\n     * Sets/gets  the `checked` attribute.\n     * Default value is `false`.\n     * ```html\n     * <igx-radio [checked] = \"true\"></igx-radio>\n     * ```\n     * ```typescript\n     * let isChecked =  this.radio.checked;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--checked')\n    @Input()\n    public checked = false;\n\n    /**\n     * Sets/gets  the `disabled` attribute.\n     * Default value is `false`.\n     * ```html\n     * <igx-radio disabled></igx-radio>\n     * ```\n     * ```typescript\n     * let isDisabled =  this.radio.disabled;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--disabled')\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled || false;\n    }\n    public set disabled(value: boolean) {\n        this._disabled = (value as any === '') || value;\n    }\n\n    /**\n     * Sets/gets whether the radio component is on focus.\n     * Default value is `false`.\n     * ```typescript\n     * this.radio.focus = true;\n     * ```\n     * ```typescript\n     * let isFocused =  this.radio.focused;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--focused')\n    public focused = false;\n\n    /**\n     * @hidden\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _disabled: boolean;\n    /**\n     * @hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n\n    /**\n     * @hidden\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n\n    constructor(private cdr: ChangeDetectorRef) { }\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      @HostListener('change', ['$event'])\n      public _changed(event: Event){\n          if(event instanceof Event){\n            event.preventDefault();\n          }\n      }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostListener('keyup', ['$event'])\n    public onKeyUp(event: KeyboardEvent) {\n        event.stopPropagation();\n        this.focused = true;\n        this.select();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click')\n    public _clicked() {\n        this.select();\n    }\n\n    /**\n     * Selects the current radio button.\n     * ```typescript\n     * this.radio.select();\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    public select() {\n        if(!this.checked) {\n            this.checked = true;\n            this.change.emit({ value: this.value, radio: this });\n            this._onChangeCallback(this.value);\n        }\n    }\n\n    /**\n     * Deselects the current radio button.\n     * ```typescript\n     * this.radio.deselect();\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    public deselect() {\n        this.checked = false;\n        this.focused = false;\n        this.cdr.markForCheck();\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`;\n     * ```typescript\n     * this.radio.writeValue('radioButtonValue');\n     * ```\n     */\n    public writeValue(value: any) {\n        this.value = this.value || value;\n\n        if (value === this.value) {\n            this.select();\n        } else {\n            this.deselect();\n        }\n    }\n\n    /** @hidden */\n    public getEditElement() {\n        return this.nativeRadio.nativeElement;\n    }\n\n    /**\n     * @hidden\n     */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case RadioLabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case RadioLabelPosition.AFTER:\n            default:\n                return `${this.cssClass}__label`;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public onBlur() {\n        this.focused = false;\n        this._onTouchedCallback();\n    }\n\n    /**\n     * @hidden\n     */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /**\n     * @hidden\n     */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /**\n     * @hidden\n     */\n    public setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n}\n","<input #radio class=\"igx-radio__input\" type=\"radio\"\n    [id]=\"inputId\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [tabindex]=\"tabindex\"\n    [disabled]=\"disabled\"\n    [checked]=\"checked\"\n    [required]=\"required\"\n    [attr.aria-checked]=\"checked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (blur)=\"onBlur()\" />\n\n<span #nativeLabel class=\"igx-radio__composite\" igxRipple\n    igxRippleTarget=\".igx-radio__ripple\"\n    [igxRippleDisabled]=\"disableRipple\"\n    [igxRippleCentered]=\"true\"\n    [igxRippleDuration]=\"300\">\n    <div class=\"igx-radio__ripple\"></div>\n</span>\n\n<span #placeholderLabel\n    [id]=\"labelId\"\n    [class]=\"labelClass\">\n    <ng-content></ng-content>\n</span>\n"]}
@@ -1,7 +1,7 @@
1
1
  import * as i1 from '@angular/animations';
2
2
  import { style, animate, animation, keyframes, useAnimation, trigger, transition } from '@angular/animations';
3
3
  import * as i0 from '@angular/core';
4
- import { Injectable, Directive, Input, HostListener, NgModule, isDevMode, PLATFORM_ID, Inject, EventEmitter, ElementRef, Optional, Output, HostBinding, InjectionToken, Component, ViewContainerRef, ViewChild, ContentChildren, forwardRef, ContentChild, Self, SecurityContext, TemplateRef, Pipe, LOCALE_ID, QueryList, ViewChildren, Host, ChangeDetectionStrategy, inject, SkipSelf, SimpleChange, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
4
+ import { Injectable, Directive, Input, HostListener, NgModule, isDevMode, PLATFORM_ID, Inject, EventEmitter, ElementRef, Optional, Output, HostBinding, InjectionToken, Component, ViewContainerRef, ViewChild, ContentChildren, forwardRef, ContentChild, Self, SecurityContext, TemplateRef, Pipe, inject, LOCALE_ID, QueryList, ViewChildren, Host, ChangeDetectionStrategy, SkipSelf, SimpleChange, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
5
5
  import * as i5 from '@angular/forms';
6
6
  import { NgModel, FormControlName, NG_VALUE_ACCESSOR, NG_VALIDATORS, CheckboxRequiredValidator, FormGroup, FormsModule, NgControl, ReactiveFormsModule, FormControl, RequiredValidator, MinValidator, MaxValidator, EmailValidator, MinLengthValidator, MaxLengthValidator, PatternValidator } from '@angular/forms';
7
7
  import * as i1$1 from '@angular/common';
@@ -18372,6 +18372,17 @@ class IgxRadioComponent {
18372
18372
  */
18373
18373
  this._onChangeCallback = noop;
18374
18374
  }
18375
+ /**
18376
+ * Gets the `nativeElement` of the igx-radio.
18377
+ *
18378
+ * @example
18379
+ * ```typescript
18380
+ * let igxRadioNativeElement = this.igxRadio.nativeElement;
18381
+ * ```
18382
+ */
18383
+ get nativeElement() {
18384
+ return this.nativeRadio.nativeElement;
18385
+ }
18375
18386
  /**
18376
18387
  * Sets/gets whether the radio button is required.
18377
18388
  * If not set, `required` will have value `false`.
@@ -18420,7 +18431,7 @@ class IgxRadioComponent {
18420
18431
  * @hidden
18421
18432
  * @internal
18422
18433
  */
18423
- _changed() {
18434
+ _changed(event) {
18424
18435
  if (event instanceof Event) {
18425
18436
  event.preventDefault();
18426
18437
  }
@@ -18606,6 +18617,65 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
18606
18617
  args: ['click']
18607
18618
  }] } });
18608
18619
 
18620
+ /**
18621
+ * @hidden
18622
+ */
18623
+ function DIR_DOCUMENT_FACTORY() {
18624
+ return inject(DOCUMENT);
18625
+ }
18626
+ /**
18627
+ * Injection token is used to inject the document into Directionality
18628
+ * which factory could be faked for testing purposes.
18629
+ *
18630
+ * We can't provide and mock the DOCUMENT token from platform-browser because configureTestingModule
18631
+ * allows override of the default providers, directive, pipes, modules of the test injector
18632
+ * which causes errors.
18633
+ *
18634
+ * @hidden
18635
+ */
18636
+ const DIR_DOCUMENT = new InjectionToken('dir-doc', {
18637
+ providedIn: 'root',
18638
+ factory: DIR_DOCUMENT_FACTORY
18639
+ });
18640
+ /**
18641
+ * @hidden
18642
+ *
18643
+ * Bidirectional service that extracts the value of the direction attribute on the body or html elements.
18644
+ *
18645
+ * The dir attribute over the body element takes precedence.
18646
+ */
18647
+ class IgxDirectionality {
18648
+ constructor(document) {
18649
+ this._document = document;
18650
+ const bodyDir = this._document.body ? this._document.body.dir : null;
18651
+ const htmlDir = this._document.documentElement ? this._document.documentElement.dir : null;
18652
+ const extractedDir = bodyDir || htmlDir;
18653
+ this._dir = (extractedDir === 'ltr' || extractedDir === 'rtl') ? extractedDir : 'ltr';
18654
+ }
18655
+ get value() {
18656
+ return this._dir;
18657
+ }
18658
+ get document() {
18659
+ return this._document;
18660
+ }
18661
+ get rtl() {
18662
+ return this._dir === 'rtl';
18663
+ }
18664
+ }
18665
+ IgxDirectionality.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxDirectionality, deps: [{ token: DIR_DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
18666
+ IgxDirectionality.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxDirectionality, providedIn: 'root' });
18667
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxDirectionality, decorators: [{
18668
+ type: Injectable,
18669
+ args: [{
18670
+ providedIn: 'root'
18671
+ }]
18672
+ }], ctorParameters: function () {
18673
+ return [{ type: undefined, decorators: [{
18674
+ type: Inject,
18675
+ args: [DIR_DOCUMENT]
18676
+ }] }];
18677
+ } });
18678
+
18609
18679
  /**
18610
18680
  * Determines the Radio Group alignment
18611
18681
  */
@@ -18638,7 +18708,8 @@ let nextId$2 = 0;
18638
18708
  * ```
18639
18709
  */
18640
18710
  class IgxRadioGroupDirective {
18641
- constructor() {
18711
+ constructor(_directionality) {
18712
+ this._directionality = _directionality;
18642
18713
  /**
18643
18714
  * An event that is emitted after the radio group `value` is changed.
18644
18715
  *
@@ -18780,6 +18851,44 @@ class IgxRadioGroupDirective {
18780
18851
  this.value = selected ? selected.value : null;
18781
18852
  }
18782
18853
  }
18854
+ handleClick(event) {
18855
+ event.stopPropagation();
18856
+ this.selected.nativeElement.focus();
18857
+ }
18858
+ handleKeyDown(event) {
18859
+ const { key } = event;
18860
+ if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(key)) {
18861
+ const buttons = this.radioButtons.filter(radio => !radio.disabled);
18862
+ const checked = buttons.find((radio) => radio.checked);
18863
+ let index = checked ? buttons.indexOf(checked) : -1;
18864
+ const ltr = this._directionality.value === 'ltr';
18865
+ switch (key) {
18866
+ case 'ArrowUp':
18867
+ index += -1;
18868
+ break;
18869
+ case 'ArrowLeft':
18870
+ index += ltr ? -1 : 1;
18871
+ break;
18872
+ case 'ArrowRight':
18873
+ index += ltr ? 1 : -1;
18874
+ break;
18875
+ default:
18876
+ index += 1;
18877
+ }
18878
+ if (index < 0)
18879
+ index = buttons.length - 1;
18880
+ if (index > buttons.length - 1)
18881
+ index = 0;
18882
+ buttons.forEach((radio) => {
18883
+ radio.deselect();
18884
+ radio.nativeElement.blur();
18885
+ });
18886
+ buttons[index].focused = true;
18887
+ buttons[index].nativeElement.focus();
18888
+ buttons[index].select();
18889
+ event.preventDefault();
18890
+ }
18891
+ }
18783
18892
  /**
18784
18893
  * Returns the alignment of the `igx-radio-group`.
18785
18894
  * ```typescript
@@ -18953,8 +19062,8 @@ class IgxRadioGroupDirective {
18953
19062
  }
18954
19063
  }
18955
19064
  }
18956
- IgxRadioGroupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxRadioGroupDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
18957
- 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 });
19065
+ IgxRadioGroupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxRadioGroupDirective, deps: [{ token: IgxDirectionality }], target: i0.ɵɵFactoryTarget.Directive });
19066
+ 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 });
18958
19067
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxRadioGroupDirective, decorators: [{
18959
19068
  type: Directive,
18960
19069
  args: [{
@@ -18962,7 +19071,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
18962
19071
  selector: 'igx-radio-group, [igxRadioGroup]',
18963
19072
  providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxRadioGroupDirective, multi: true }]
18964
19073
  }]
18965
- }], propDecorators: { radioButtons: [{
19074
+ }], ctorParameters: function () { return [{ type: IgxDirectionality }]; }, propDecorators: { radioButtons: [{
18966
19075
  type: ContentChildren,
18967
19076
  args: [IgxRadioComponent, { descendants: true }]
18968
19077
  }], value: [{
@@ -18981,6 +19090,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
18981
19090
  }], vertical: [{
18982
19091
  type: HostBinding,
18983
19092
  args: ['class.igx-radio-group--vertical']
19093
+ }], handleClick: [{
19094
+ type: HostListener,
19095
+ args: ['click', ['$event']]
19096
+ }], handleKeyDown: [{
19097
+ type: HostListener,
19098
+ args: ['keydown', ['$event']]
18984
19099
  }], alignment: [{
18985
19100
  type: Input
18986
19101
  }] } });
@@ -45196,65 +45311,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
45196
45311
  }]
45197
45312
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
45198
45313
 
45199
- /**
45200
- * @hidden
45201
- */
45202
- function DIR_DOCUMENT_FACTORY() {
45203
- return inject(DOCUMENT);
45204
- }
45205
- /**
45206
- * Injection token is used to inject the document into Directionality
45207
- * which factory could be faked for testing purposes.
45208
- *
45209
- * We can't provide and mock the DOCUMENT token from platform-browser because configureTestingModule
45210
- * allows override of the default providers, directive, pipes, modules of the test injector
45211
- * which causes errors.
45212
- *
45213
- * @hidden
45214
- */
45215
- const DIR_DOCUMENT = new InjectionToken('dir-doc', {
45216
- providedIn: 'root',
45217
- factory: DIR_DOCUMENT_FACTORY
45218
- });
45219
- /**
45220
- * @hidden
45221
- *
45222
- * Bidirectional service that extracts the value of the direction attribute on the body or html elements.
45223
- *
45224
- * The dir attribute over the body element takes precedence.
45225
- */
45226
- class IgxDirectionality {
45227
- constructor(document) {
45228
- this._document = document;
45229
- const bodyDir = this._document.body ? this._document.body.dir : null;
45230
- const htmlDir = this._document.documentElement ? this._document.documentElement.dir : null;
45231
- const extractedDir = bodyDir || htmlDir;
45232
- this._dir = (extractedDir === 'ltr' || extractedDir === 'rtl') ? extractedDir : 'ltr';
45233
- }
45234
- get value() {
45235
- return this._dir;
45236
- }
45237
- get document() {
45238
- return this._document;
45239
- }
45240
- get rtl() {
45241
- return this._dir === 'rtl';
45242
- }
45243
- }
45244
- IgxDirectionality.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxDirectionality, deps: [{ token: DIR_DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
45245
- IgxDirectionality.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxDirectionality, providedIn: 'root' });
45246
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: IgxDirectionality, decorators: [{
45247
- type: Injectable,
45248
- args: [{
45249
- providedIn: 'root'
45250
- }]
45251
- }], ctorParameters: function () {
45252
- return [{ type: undefined, decorators: [{
45253
- type: Inject,
45254
- args: [DIR_DOCUMENT]
45255
- }] }];
45256
- } });
45257
-
45258
45314
  const ONE_PERCENT = 0.01;
45259
45315
  const MIN_VALUE = 0;
45260
45316
  const IgxTextAlign = mkenum({
@@ -64759,8 +64815,8 @@ class IgxGridBaseDirective extends DisplayDensityBase {
64759
64815
  // commit pending states prior to adding a row
64760
64816
  this.crudService.endEdit(true);
64761
64817
  this.gridAPI.addRowToData(data);
64762
- this.rowAddedNotifier.next({ data: data, owner: this });
64763
64818
  this.pipeTrigger++;
64819
+ this.rowAddedNotifier.next({ data: data, owner: this });
64764
64820
  this.notifyChanges();
64765
64821
  }
64766
64822
  /**
@@ -65048,6 +65104,7 @@ class IgxGridBaseDirective extends DisplayDensityBase {
65048
65104
  this.crudService.endEdit(true);
65049
65105
  this.selectionService.clearHeaderCBState();
65050
65106
  this.summaryService.clearSummaryCache();
65107
+ this.summaryPipeTrigger++;
65051
65108
  this.cdr.detectChanges();
65052
65109
  }
65053
65110
  // TODO: We have return values here. Move them to event args ??