igniteui-angular 17.0.3 → 17.0.4

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.
@@ -540,4 +540,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
540
540
  type: HostListener,
541
541
  args: ['blur']
542
542
  }] } });
543
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.ts","../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostListener,\n    HostBinding,\n    Input,\n    Output,\n    ViewChild,\n    ElementRef,\n    AfterViewInit,\n    ChangeDetectorRef,\n    Renderer2,\n    Optional,\n    Self,\n    booleanAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl, Validators } from '@angular/forms';\nimport { IgxRippleDirective } from '../directives/ripple/ripple.directive';\nimport { IBaseEventArgs, mkenum } from '../core/utils';\nimport { EditorProvider, EDITOR_PROVIDER } from '../core/edit-provider';\nimport { noop, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nexport const LabelPosition = mkenum({\n    BEFORE: 'before',\n    AFTER: 'after'\n});\nexport type LabelPosition = typeof LabelPosition[keyof typeof LabelPosition];\n\nexport interface IChangeCheckboxEventArgs extends IBaseEventArgs {\n    checked?: boolean;\n    value?: any;\n}\n\nlet nextId = 0;\n/**\n * Allows users to make a binary choice for a certain condition.\n *\n * @igxModule IgxCheckboxModule\n *\n * @igxTheme igx-checkbox-theme\n *\n * @igxKeywords checkbox, label\n *\n * @igxGroup Data entry and display\n *\n * @remarks\n * The Ignite UI Checkbox is a selection control that allows users to make a binary choice for a certain condition.It behaves similarly\n * to the native browser checkbox.\n *\n * @example\n * ```html\n * <igx-checkbox [checked]=\"true\">\n *   simple checkbox\n * </igx-checkbox>\n * ```\n */\n@Component({\n    selector: 'igx-checkbox',\n    providers: [{\n        provide: EDITOR_PROVIDER,\n        useExisting: IgxCheckboxComponent,\n        multi: true\n    }],\n    preserveWhitespaces: false,\n    templateUrl: 'checkbox.component.html',\n    standalone: true,\n    imports: [IgxRippleDirective]\n})\nexport class IgxCheckboxComponent implements EditorProvider, AfterViewInit, ControlValueAccessor {\n\n    /**\n     * An event that is emitted after the checkbox state is changed.\n     * Provides references to the `IgxCheckboxComponent` and the `checked` property as event arguments.\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeCheckboxEventArgs> = new EventEmitter<IChangeCheckboxEventArgs>();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public destroy$ = new Subject<boolean>();\n\n    /**\n     * Returns reference to the native checkbox element.\n     *\n     * @example\n     * ```typescript\n     * let checkboxElement =  this.component.checkboxElement;\n     * ```\n     */\n    @ViewChild('checkbox', { static: true })\n    public nativeInput: ElementRef;\n\n    /**\n     * Returns reference to the native label element.\n     * ```typescript\n     *\n     * @example\n     * let labelElement =  this.component.nativeLabel;\n     * ```\n     */\n    @ViewChild('label', { static: true })\n    public nativeLabel: ElementRef;\n\n    /**\n     * Returns reference to the `nativeElement` of the igx-checkbox/igx-switch.\n     *\n     * @example\n     * ```typescript\n     * let nativeElement = this.component.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     *\n     * @example\n     * let labelPlaceholder =  this.component.placeholderLabel;\n     * ```\n     */\n    @ViewChild('placeholderLabel', { static: true })\n    public placeholderLabel: ElementRef;\n\n    /**\n     * Sets/gets the `id` of the checkbox component.\n     * If not set, the `id` of the first checkbox component will be `\"igx-checkbox-0\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox id=\"my-first-checkbox\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let checkboxId =  this.checkbox.id;\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-checkbox-${nextId++}`;\n\n    /**\n     * Sets/gets the id of the `label` element.\n     * If not set, the id of the `label` in the first checkbox component will be `\"igx-checkbox-0-label\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelId=\"Label1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelId =  this.component.labelId;\n     * ```\n     */\n    @Input() public labelId = `${this.id}-label`;\n\n    /**\n     * Sets/gets the `value` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [value]=\"'CheckboxValue'\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let value =  this.checkbox.value;\n     * ```\n     */\n    @Input() public value: any;\n\n    /**\n     * Sets/gets the `name` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox name=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let name =  this.checkbox.name;\n     * ```\n     */\n    @Input() public name: string;\n\n    /**\n     * Sets/gets the value of the `tabindex` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [tabindex]=\"1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.checkbox.tabindex;\n     * ```\n     */\n    @Input() public tabindex: number = null;\n\n    /**\n     *  Sets/gets the position of the `label`.\n     *  If not set, the `labelPosition` will have value `\"after\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelPosition=\"before\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.checkbox.labelPosition;\n     * ```\n     */\n    @Input()\n    public labelPosition: LabelPosition | string = LabelPosition.AFTER;\n\n    /**\n     * Enables/Disables the ripple effect.\n     * If not set, `disableRipple` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableRipple]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRippleDisabled = this.checkbox.desableRipple;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public disableRipple = false;\n\n    /**\n     * Sets/gets whether the checkbox is required.\n     * If not set, `required` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox required></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRequired = this.checkbox.required;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public get required(): boolean {\n        return this._required || this.nativeElement.hasAttribute('required');\n    }\n    public set required(value: boolean) {\n        this._required = value;\n    }\n\n    /**\n     * Sets/gets the `aria-labelledby` attribute.\n     * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-labelledby=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.checkbox.ariaLabelledBy;\n     * ```\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n\n    /**\n     * Sets/gets the value of the `aria-label` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-label=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabel = this.checkbox.ariaLabel;\n     * ```\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n\n    /**\n     * Returns the class of the checkbox component.\n     *\n     * @example\n     * ```typescript\n     * let class = this.checkbox.cssClass;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox')\n    public cssClass = 'igx-checkbox';\n\n    /**\n     * Sets/gets whether the checkbox component is on focus.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.checkbox.focused =  true;\n     * ```\n     * ```typescript\n     * let isFocused = this.checkbox.focused;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--focused')\n    public focused = false;\n\n    /**\n     * Sets/gets the checkbox indeterminate visual state.\n     * Default value is `false`;\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [indeterminate]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isIndeterminate = this.checkbox.indeterminate;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--indeterminate')\n    @Input({ transform: booleanAttribute })\n    public indeterminate = false;\n\n    /**\n     * Sets/gets whether the checkbox is checked.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [checked]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isChecked =  this.checkbox.checked;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--checked')\n    @Input({ transform: booleanAttribute })\n    public get checked() {\n        return this._checked;\n    }\n    public set checked(value: boolean) {\n        if (this._checked !== value) {\n            this._checked = value;\n            this._onChangeCallback(this._checked);\n        }\n    }\n\n    /**\n     * Sets/gets whether the checkbox is disabled.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox disabled></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isDisabled = this.checkbox.disabled;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--disabled')\n    @Input({ transform: booleanAttribute })\n    public disabled = false;\n\n    /**\n     * Sets/gets whether the checkbox is invalid.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox invalid></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isInvalid = this.checkbox.invalid;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--invalid')\n    @Input({ transform: booleanAttribute })\n    public invalid = false\n\n    /**\n     * Sets/gets whether the checkbox is readonly.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [readonly]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let readonly = this.checkbox.readonly;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public readonly = false;\n\n    /**\n     * Sets/gets whether the checkbox should disable all css transitions.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableTransitions]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let disableTransitions = this.checkbox.disableTransitions;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--plain')\n    @Input({ transform: booleanAttribute })\n    public disableTransitions = false;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     * @hidden\n     */\n    protected _onChangeCallback: (_: any) => void = noop;\n    /**\n     * @hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n    /**\n     * @hidden\n     * @internal\n     */\n    protected _checked = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected renderer: Renderer2,\n        @Optional() @Self() public ngControl: NgControl,\n    ) {\n        if (this.ngControl !== null) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    /**\n     * @hidden\n     * @internal\n    */\n    public ngAfterViewInit() {\n        if (this.ngControl) {\n            this.ngControl.statusChanges.pipe(takeUntil(this.destroy$)).subscribe(this.updateValidityState.bind(this));\n\n            if (this.ngControl.control.validator || this.ngControl.control.asyncValidator) {\n                this._required = this.ngControl?.control?.hasValidator(Validators.required);\n                this.cdr.detectChanges();\n            }\n        }\n    }\n\n    /** @hidden @internal */\n    @HostListener('keyup', ['$event'])\n    public onKeyUp(event: KeyboardEvent) {\n        event.stopPropagation();\n        this.focused = true;\n    }\n\n    /** @hidden @internal */\n    @HostListener('click', ['$event'])\n    public _onCheckboxClick(event: PointerEvent | MouseEvent) {\n        // Since the original checkbox is hidden and the label\n        // is used for styling and to change the checked state of the checkbox,\n        // we need to prevent the checkbox click event from bubbling up\n        // as it gets triggered on label click\n        // NOTE: The above is no longer valid, as the native checkbox is not labeled\n        // by the SVG anymore.\n        if (this.disabled || this.readonly) {\n            // readonly prevents the component from changing state (see toggle() method).\n            // However, the native checkbox can still be activated through user interaction (focus + space, label click)\n            // Prevent the native change so the input remains in sync\n            event.preventDefault();\n            return;\n        }\n\n        this.nativeInput.nativeElement.focus();\n\n        this.indeterminate = false;\n        this.checked = !this.checked;\n        this.updateValidityState();\n\n        // K.D. March 23, 2021 Emitting on click and not on the setter because otherwise every component\n        // bound on change would have to perform self checks for weather the value has changed because\n        // of the initial set on initialization\n        this.change.emit({ checked: this.checked, value: this.value, owner: this });\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get ariaChecked() {\n        if (this.indeterminate) {\n            return 'mixed';\n        } else {\n            return this.checked;\n        }\n    }\n\n    /** @hidden @internal */\n    public _onCheckboxChange(event: Event) {\n        // We have to stop the original checkbox change event\n        // from bubbling up since we emit our own change event\n        event.stopPropagation();\n    }\n\n    /** @hidden @internal */\n    @HostListener('blur')\n    public onBlur() {\n        this.focused = false;\n        this._onTouchedCallback();\n        this.updateValidityState();\n    }\n\n    /** @hidden @internal */\n    public writeValue(value: boolean) {\n        this._checked = value;\n    }\n\n    /** @hidden @internal */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case LabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case LabelPosition.AFTER:\n            default:\n                return `${this.cssClass}__label`;\n        }\n    }\n\n    /** @hidden @internal */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden @internal */\n    public getEditElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected updateValidityState() {\n        if (this.ngControl) {\n            if (!this.disabled && !this.readonly &&\n                (this.ngControl.control.touched || this.ngControl.control.dirty)) {\n                // the control is not disabled and is touched or dirty\n                this.invalid = this.ngControl.invalid;\n            } else {\n                //  if the control is untouched, pristine, or disabled, its state is initial. This is when the user did not interact\n                //  with the checkbox or when the form/control is reset\n                this.invalid = false;\n            }\n        } else {\n            this.checkNativeValidity();\n        }\n    }\n\n    /**\n     * A function to assign a native validity property of a checkbox.\n     * This should be used when there's no ngControl\n     *\n     * @hidden\n     * @internal\n     */\n    private checkNativeValidity() {\n        if (!this.disabled && this._required && !this.checked && !this.readonly) {\n            this.invalid = true;\n        } else {\n            this.invalid = false;\n        }\n    }\n}\n","<input #checkbox class=\"igx-checkbox__input\"\n    type=\"checkbox\"\n    [id]=\"inputId\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [tabindex]=\"tabindex\"\n    [disabled]=\"disabled\"\n    [indeterminate]=\"indeterminate\"\n    [checked]=\"checked\"\n    [required]=\"required\"\n    [attr.aria-required]=\"required\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-checked]=\"ariaChecked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (change)=\"_onCheckboxChange($event)\"\n    (blur)=\"onBlur()\" />\n\n<div\n    igxRipple\n    igxRippleTarget=\".igx-checkbox__ripple\"\n    [igxRippleDisabled]=\"disableRipple\"\n    [igxRippleCentered]=\"true\"\n    [igxRippleDuration]=\"300\"\n    class=\"igx-checkbox__composite-wrapper\"\n>\n    <span #label class=\"igx-checkbox__composite\">\n        <svg class=\"igx-checkbox__composite-mark\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n            <path d=\"M4.1,12.7 9,17.6 20.3,6.3\" />\n        </svg>\n    </span>\n\n    <div class=\"igx-checkbox__ripple\"></div>\n</div>\n\n<span #placeholderLabel\n    [class]=\"labelClass\"\n    [id]=\"labelId\">\n    <ng-content></ng-content>\n</span>\n"]}
543
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.ts","../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostListener,\n    HostBinding,\n    Input,\n    Output,\n    ViewChild,\n    ElementRef,\n    AfterViewInit,\n    ChangeDetectorRef,\n    Renderer2,\n    Optional,\n    Self,\n    booleanAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl, Validators } from '@angular/forms';\nimport { IgxRippleDirective } from '../directives/ripple/ripple.directive';\nimport { IBaseEventArgs, mkenum } from '../core/utils';\nimport { EditorProvider, EDITOR_PROVIDER } from '../core/edit-provider';\nimport { noop, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nexport const LabelPosition = mkenum({\n    BEFORE: 'before',\n    AFTER: 'after'\n});\nexport type LabelPosition = typeof LabelPosition[keyof typeof LabelPosition];\n\nexport interface IChangeCheckboxEventArgs extends IBaseEventArgs {\n    checked: boolean;\n    value?: any;\n}\n\nlet nextId = 0;\n/**\n * Allows users to make a binary choice for a certain condition.\n *\n * @igxModule IgxCheckboxModule\n *\n * @igxTheme igx-checkbox-theme\n *\n * @igxKeywords checkbox, label\n *\n * @igxGroup Data entry and display\n *\n * @remarks\n * The Ignite UI Checkbox is a selection control that allows users to make a binary choice for a certain condition.It behaves similarly\n * to the native browser checkbox.\n *\n * @example\n * ```html\n * <igx-checkbox [checked]=\"true\">\n *   simple checkbox\n * </igx-checkbox>\n * ```\n */\n@Component({\n    selector: 'igx-checkbox',\n    providers: [{\n        provide: EDITOR_PROVIDER,\n        useExisting: IgxCheckboxComponent,\n        multi: true\n    }],\n    preserveWhitespaces: false,\n    templateUrl: 'checkbox.component.html',\n    standalone: true,\n    imports: [IgxRippleDirective]\n})\nexport class IgxCheckboxComponent implements EditorProvider, AfterViewInit, ControlValueAccessor {\n\n    /**\n     * An event that is emitted after the checkbox state is changed.\n     * Provides references to the `IgxCheckboxComponent` and the `checked` property as event arguments.\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeCheckboxEventArgs> = new EventEmitter<IChangeCheckboxEventArgs>();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public destroy$ = new Subject<boolean>();\n\n    /**\n     * Returns reference to the native checkbox element.\n     *\n     * @example\n     * ```typescript\n     * let checkboxElement =  this.component.checkboxElement;\n     * ```\n     */\n    @ViewChild('checkbox', { static: true })\n    public nativeInput: ElementRef;\n\n    /**\n     * Returns reference to the native label element.\n     * ```typescript\n     *\n     * @example\n     * let labelElement =  this.component.nativeLabel;\n     * ```\n     */\n    @ViewChild('label', { static: true })\n    public nativeLabel: ElementRef;\n\n    /**\n     * Returns reference to the `nativeElement` of the igx-checkbox/igx-switch.\n     *\n     * @example\n     * ```typescript\n     * let nativeElement = this.component.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     *\n     * @example\n     * let labelPlaceholder =  this.component.placeholderLabel;\n     * ```\n     */\n    @ViewChild('placeholderLabel', { static: true })\n    public placeholderLabel: ElementRef;\n\n    /**\n     * Sets/gets the `id` of the checkbox component.\n     * If not set, the `id` of the first checkbox component will be `\"igx-checkbox-0\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox id=\"my-first-checkbox\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let checkboxId =  this.checkbox.id;\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-checkbox-${nextId++}`;\n\n    /**\n     * Sets/gets the id of the `label` element.\n     * If not set, the id of the `label` in the first checkbox component will be `\"igx-checkbox-0-label\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelId=\"Label1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelId =  this.component.labelId;\n     * ```\n     */\n    @Input() public labelId = `${this.id}-label`;\n\n    /**\n     * Sets/gets the `value` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [value]=\"'CheckboxValue'\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let value =  this.checkbox.value;\n     * ```\n     */\n    @Input() public value: any;\n\n    /**\n     * Sets/gets the `name` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox name=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let name =  this.checkbox.name;\n     * ```\n     */\n    @Input() public name: string;\n\n    /**\n     * Sets/gets the value of the `tabindex` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [tabindex]=\"1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.checkbox.tabindex;\n     * ```\n     */\n    @Input() public tabindex: number = null;\n\n    /**\n     *  Sets/gets the position of the `label`.\n     *  If not set, the `labelPosition` will have value `\"after\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelPosition=\"before\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.checkbox.labelPosition;\n     * ```\n     */\n    @Input()\n    public labelPosition: LabelPosition | string = LabelPosition.AFTER;\n\n    /**\n     * Enables/Disables the ripple effect.\n     * If not set, `disableRipple` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableRipple]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRippleDisabled = this.checkbox.desableRipple;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public disableRipple = false;\n\n    /**\n     * Sets/gets whether the checkbox is required.\n     * If not set, `required` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox required></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRequired = this.checkbox.required;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public get required(): boolean {\n        return this._required || this.nativeElement.hasAttribute('required');\n    }\n    public set required(value: boolean) {\n        this._required = value;\n    }\n\n    /**\n     * Sets/gets the `aria-labelledby` attribute.\n     * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-labelledby=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.checkbox.ariaLabelledBy;\n     * ```\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n\n    /**\n     * Sets/gets the value of the `aria-label` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-label=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabel = this.checkbox.ariaLabel;\n     * ```\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n\n    /**\n     * Returns the class of the checkbox component.\n     *\n     * @example\n     * ```typescript\n     * let class = this.checkbox.cssClass;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox')\n    public cssClass = 'igx-checkbox';\n\n    /**\n     * Sets/gets whether the checkbox component is on focus.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.checkbox.focused =  true;\n     * ```\n     * ```typescript\n     * let isFocused = this.checkbox.focused;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--focused')\n    public focused = false;\n\n    /**\n     * Sets/gets the checkbox indeterminate visual state.\n     * Default value is `false`;\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [indeterminate]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isIndeterminate = this.checkbox.indeterminate;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--indeterminate')\n    @Input({ transform: booleanAttribute })\n    public indeterminate = false;\n\n    /**\n     * Sets/gets whether the checkbox is checked.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [checked]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isChecked =  this.checkbox.checked;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--checked')\n    @Input({ transform: booleanAttribute })\n    public get checked() {\n        return this._checked;\n    }\n    public set checked(value: boolean) {\n        if (this._checked !== value) {\n            this._checked = value;\n            this._onChangeCallback(this._checked);\n        }\n    }\n\n    /**\n     * Sets/gets whether the checkbox is disabled.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox disabled></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isDisabled = this.checkbox.disabled;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--disabled')\n    @Input({ transform: booleanAttribute })\n    public disabled = false;\n\n    /**\n     * Sets/gets whether the checkbox is invalid.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox invalid></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isInvalid = this.checkbox.invalid;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--invalid')\n    @Input({ transform: booleanAttribute })\n    public invalid = false\n\n    /**\n     * Sets/gets whether the checkbox is readonly.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [readonly]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let readonly = this.checkbox.readonly;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public readonly = false;\n\n    /**\n     * Sets/gets whether the checkbox should disable all css transitions.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableTransitions]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let disableTransitions = this.checkbox.disableTransitions;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--plain')\n    @Input({ transform: booleanAttribute })\n    public disableTransitions = false;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     * @hidden\n     */\n    protected _onChangeCallback: (_: any) => void = noop;\n    /**\n     * @hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n    /**\n     * @hidden\n     * @internal\n     */\n    protected _checked = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected renderer: Renderer2,\n        @Optional() @Self() public ngControl: NgControl,\n    ) {\n        if (this.ngControl !== null) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    /**\n     * @hidden\n     * @internal\n    */\n    public ngAfterViewInit() {\n        if (this.ngControl) {\n            this.ngControl.statusChanges.pipe(takeUntil(this.destroy$)).subscribe(this.updateValidityState.bind(this));\n\n            if (this.ngControl.control.validator || this.ngControl.control.asyncValidator) {\n                this._required = this.ngControl?.control?.hasValidator(Validators.required);\n                this.cdr.detectChanges();\n            }\n        }\n    }\n\n    /** @hidden @internal */\n    @HostListener('keyup', ['$event'])\n    public onKeyUp(event: KeyboardEvent) {\n        event.stopPropagation();\n        this.focused = true;\n    }\n\n    /** @hidden @internal */\n    @HostListener('click', ['$event'])\n    public _onCheckboxClick(event: PointerEvent | MouseEvent) {\n        // Since the original checkbox is hidden and the label\n        // is used for styling and to change the checked state of the checkbox,\n        // we need to prevent the checkbox click event from bubbling up\n        // as it gets triggered on label click\n        // NOTE: The above is no longer valid, as the native checkbox is not labeled\n        // by the SVG anymore.\n        if (this.disabled || this.readonly) {\n            // readonly prevents the component from changing state (see toggle() method).\n            // However, the native checkbox can still be activated through user interaction (focus + space, label click)\n            // Prevent the native change so the input remains in sync\n            event.preventDefault();\n            return;\n        }\n\n        this.nativeInput.nativeElement.focus();\n\n        this.indeterminate = false;\n        this.checked = !this.checked;\n        this.updateValidityState();\n\n        // K.D. March 23, 2021 Emitting on click and not on the setter because otherwise every component\n        // bound on change would have to perform self checks for weather the value has changed because\n        // of the initial set on initialization\n        this.change.emit({ checked: this.checked, value: this.value, owner: this });\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get ariaChecked() {\n        if (this.indeterminate) {\n            return 'mixed';\n        } else {\n            return this.checked;\n        }\n    }\n\n    /** @hidden @internal */\n    public _onCheckboxChange(event: Event) {\n        // We have to stop the original checkbox change event\n        // from bubbling up since we emit our own change event\n        event.stopPropagation();\n    }\n\n    /** @hidden @internal */\n    @HostListener('blur')\n    public onBlur() {\n        this.focused = false;\n        this._onTouchedCallback();\n        this.updateValidityState();\n    }\n\n    /** @hidden @internal */\n    public writeValue(value: boolean) {\n        this._checked = value;\n    }\n\n    /** @hidden @internal */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case LabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case LabelPosition.AFTER:\n            default:\n                return `${this.cssClass}__label`;\n        }\n    }\n\n    /** @hidden @internal */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden @internal */\n    public getEditElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected updateValidityState() {\n        if (this.ngControl) {\n            if (!this.disabled && !this.readonly &&\n                (this.ngControl.control.touched || this.ngControl.control.dirty)) {\n                // the control is not disabled and is touched or dirty\n                this.invalid = this.ngControl.invalid;\n            } else {\n                //  if the control is untouched, pristine, or disabled, its state is initial. This is when the user did not interact\n                //  with the checkbox or when the form/control is reset\n                this.invalid = false;\n            }\n        } else {\n            this.checkNativeValidity();\n        }\n    }\n\n    /**\n     * A function to assign a native validity property of a checkbox.\n     * This should be used when there's no ngControl\n     *\n     * @hidden\n     * @internal\n     */\n    private checkNativeValidity() {\n        if (!this.disabled && this._required && !this.checked && !this.readonly) {\n            this.invalid = true;\n        } else {\n            this.invalid = false;\n        }\n    }\n}\n","<input #checkbox class=\"igx-checkbox__input\"\n    type=\"checkbox\"\n    [id]=\"inputId\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [tabindex]=\"tabindex\"\n    [disabled]=\"disabled\"\n    [indeterminate]=\"indeterminate\"\n    [checked]=\"checked\"\n    [required]=\"required\"\n    [attr.aria-required]=\"required\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-checked]=\"ariaChecked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (change)=\"_onCheckboxChange($event)\"\n    (blur)=\"onBlur()\" />\n\n<div\n    igxRipple\n    igxRippleTarget=\".igx-checkbox__ripple\"\n    [igxRippleDisabled]=\"disableRipple\"\n    [igxRippleCentered]=\"true\"\n    [igxRippleDuration]=\"300\"\n    class=\"igx-checkbox__composite-wrapper\"\n>\n    <span #label class=\"igx-checkbox__composite\">\n        <svg class=\"igx-checkbox__composite-mark\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n            <path d=\"M4.1,12.7 9,17.6 20.3,6.3\" />\n        </svg>\n    </span>\n\n    <div class=\"igx-checkbox__ripple\"></div>\n</div>\n\n<span #placeholderLabel\n    [class]=\"labelClass\"\n    [id]=\"labelId\">\n    <ng-content></ng-content>\n</span>\n"]}
@@ -114,7 +114,7 @@ export class IgxRadioComponent extends IgxCheckboxComponent {
114
114
  select() {
115
115
  if (!this.checked) {
116
116
  this.checked = true;
117
- this.change.emit({ value: this.value, owner: this });
117
+ this.change.emit({ value: this.value, owner: this, checked: this.checked });
118
118
  this._onChangeCallback(this.value);
119
119
  }
120
120
  }
@@ -204,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
204
204
  type: HostListener,
205
205
  args: ['blur']
206
206
  }] } });
207
- //# 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    AfterViewInit,\n    Component,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    booleanAttribute\n} from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { EditorProvider, EDITOR_PROVIDER } from '../core/edit-provider';\nimport { IgxRippleDirective } from '../directives/ripple/ripple.directive';\nimport { IgxCheckboxComponent } from '../checkbox/checkbox.component';\n\n\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    selector: 'igx-radio',\n    providers: [{\n        provide: EDITOR_PROVIDER,\n        useExisting: IgxRadioComponent,\n        multi: true\n    }],\n    templateUrl: 'radio.component.html',\n    standalone: true,\n    imports: [IgxRippleDirective]\n})\nexport class IgxRadioComponent extends IgxCheckboxComponent implements AfterViewInit, ControlValueAccessor, EditorProvider {\n    /** @hidden @internal */\n    public blurRadio = new EventEmitter();\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 override 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({ transform: booleanAttribute })\n    public override set checked(value: boolean) {\n        this._checked = value;\n    }\n    public override get checked() {\n        return this._checked;\n    }\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({ transform: booleanAttribute })\n    public override disabled = false;\n\n    /**\n     * Sets/gets whether the radio button is invalid.\n     * Default value is `false`.\n     * ```html\n     * <igx-radio invalid></igx-radio>\n     * ```\n     * ```typescript\n     * let isInvalid =  this.radio.invalid;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--invalid')\n    @Input({ transform: booleanAttribute })\n    public override invalid = false;\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 override focused = false;\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     */\n    @HostListener('click')\n    public override _onCheckboxClick() {\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, owner: 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 override writeValue(value: any) {\n        this.value = this.value ?? value;\n\n        if (value === this.value) {\n            if (!this.checked) {\n                this.checked = true;\n            }\n        } else {\n            this.deselect();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('blur')\n    public override onBlur() {\n        super.onBlur();\n        this.blurRadio.emit();\n    }\n}\n","<input #checkbox 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-required]=\"required\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-checked]=\"checked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (blur)=\"onBlur()\" />\n\n<span #label 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"]}
207
+ //# 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    AfterViewInit,\n    Component,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    booleanAttribute\n} from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { EditorProvider, EDITOR_PROVIDER } from '../core/edit-provider';\nimport { IgxRippleDirective } from '../directives/ripple/ripple.directive';\nimport { IgxCheckboxComponent } from '../checkbox/checkbox.component';\n\n\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    selector: 'igx-radio',\n    providers: [{\n        provide: EDITOR_PROVIDER,\n        useExisting: IgxRadioComponent,\n        multi: true\n    }],\n    templateUrl: 'radio.component.html',\n    standalone: true,\n    imports: [IgxRippleDirective]\n})\nexport class IgxRadioComponent extends IgxCheckboxComponent implements AfterViewInit, ControlValueAccessor, EditorProvider {\n    /** @hidden @internal */\n    public blurRadio = new EventEmitter();\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 override 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({ transform: booleanAttribute })\n    public override set checked(value: boolean) {\n        this._checked = value;\n    }\n    public override get checked() {\n        return this._checked;\n    }\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({ transform: booleanAttribute })\n    public override disabled = false;\n\n    /**\n     * Sets/gets whether the radio button is invalid.\n     * Default value is `false`.\n     * ```html\n     * <igx-radio invalid></igx-radio>\n     * ```\n     * ```typescript\n     * let isInvalid =  this.radio.invalid;\n     * ```\n     *\n     * @memberof IgxRadioComponent\n     */\n    @HostBinding('class.igx-radio--invalid')\n    @Input({ transform: booleanAttribute })\n    public override invalid = false;\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 override focused = false;\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     */\n    @HostListener('click')\n    public override _onCheckboxClick() {\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, owner: this, checked: this.checked });\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 override writeValue(value: any) {\n        this.value = this.value ?? value;\n\n        if (value === this.value) {\n            if (!this.checked) {\n                this.checked = true;\n            }\n        } else {\n            this.deselect();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('blur')\n    public override onBlur() {\n        super.onBlur();\n        this.blurRadio.emit();\n    }\n}\n","<input #checkbox 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-required]=\"required\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-checked]=\"checked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (blur)=\"onBlur()\" />\n\n<span #label 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"]}
@@ -15967,7 +15967,7 @@ class IgxRadioComponent extends IgxCheckboxComponent {
15967
15967
  select() {
15968
15968
  if (!this.checked) {
15969
15969
  this.checked = true;
15970
- this.change.emit({ value: this.value, owner: this });
15970
+ this.change.emit({ value: this.value, owner: this, checked: this.checked });
15971
15971
  this._onChangeCallback(this.value);
15972
15972
  }
15973
15973
  }