igniteui-angular 14.0.11 → 14.0.14
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/core/utils.mjs +3 -3
- package/esm2020/lib/date-picker/date-picker.component.mjs +2 -1
- package/esm2020/lib/date-range-picker/date-range-picker.component.mjs +3 -3
- package/esm2020/lib/directives/drag-drop/drag-drop.directive.mjs +8 -6
- package/esm2020/lib/directives/radio/radio-group.directive.mjs +11 -5
- package/esm2020/lib/grids/grid/grid.component.mjs +2 -2
- package/esm2020/lib/grids/grid-navigation.service.mjs +8 -3
- package/esm2020/lib/grids/selection/selection.service.mjs +9 -4
- package/esm2020/lib/paginator/paginator.component.mjs +3 -3
- package/esm2020/lib/radio/radio.component.mjs +15 -2
- package/esm2020/lib/time-picker/time-picker.component.mjs +3 -2
- package/esm2020/lib/tree/tree-node/tree-node.component.mjs +7 -1
- package/fesm2015/igniteui-angular.mjs +61 -22
- package/fesm2015/igniteui-angular.mjs.map +1 -1
- package/fesm2020/igniteui-angular.mjs +61 -22
- package/fesm2020/igniteui-angular.mjs.map +1 -1
- package/lib/core/utils.d.ts +1 -1
- package/lib/directives/drag-drop/drag-drop.directive.d.ts +1 -1
- package/lib/directives/radio/radio-group.directive.d.ts +5 -0
- package/lib/grids/selection/selection.service.d.ts +2 -1
- package/lib/radio/radio.component.d.ts +13 -2
- package/package.json +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { noop } from 'rxjs';
|
|
3
|
+
import { noop, Subject } from 'rxjs';
|
|
4
4
|
import { mkenum } from '../core/utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "../directives/ripple/ripple.directive";
|
|
@@ -25,6 +25,11 @@ let nextId = 0;
|
|
|
25
25
|
export class IgxRadioComponent {
|
|
26
26
|
constructor(cdr) {
|
|
27
27
|
this.cdr = cdr;
|
|
28
|
+
/**
|
|
29
|
+
* @hidden
|
|
30
|
+
* @internal
|
|
31
|
+
*/
|
|
32
|
+
this.destroy$ = new Subject();
|
|
28
33
|
/**
|
|
29
34
|
* Sets/gets the `id` of the radio component.
|
|
30
35
|
* If not set, the `id` of the first radio component will be `"igx-radio-0"`.
|
|
@@ -198,6 +203,14 @@ export class IgxRadioComponent {
|
|
|
198
203
|
set disabled(value) {
|
|
199
204
|
this._disabled = (value === '') || value;
|
|
200
205
|
}
|
|
206
|
+
/**
|
|
207
|
+
* @hidden
|
|
208
|
+
* @internal
|
|
209
|
+
*/
|
|
210
|
+
ngOnDestroy() {
|
|
211
|
+
this.destroy$.next(true);
|
|
212
|
+
this.destroy$.complete();
|
|
213
|
+
}
|
|
201
214
|
/**
|
|
202
215
|
* @hidden
|
|
203
216
|
* @internal
|
|
@@ -388,4 +401,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImpor
|
|
|
388
401
|
type: HostListener,
|
|
389
402
|
args: ['click']
|
|
390
403
|
}] } });
|
|
391
|
-
//# 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    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { noop } 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 {\n    private static ngAcceptInputType_required: boolean | '';\n    private static ngAcceptInputType_disabled: boolean | '';\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      @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        this.nativeRadio.nativeElement.focus();\n\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"]}
|
|
404
|
+
//# 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        this.nativeRadio.nativeElement.focus();\n\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"]}
|