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
|
@@ -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,
|
|
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 ??
|