UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

453 lines 40.7 kB
var IgxCheckboxComponent_1; import { __decorate, __metadata } from "tslib"; import { Component, Directive, EventEmitter, forwardRef, HostBinding, Input, NgModule, Output, ViewChild, ElementRef } from '@angular/core'; import { CheckboxRequiredValidator, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms'; import { IgxRippleModule } from '../directives/ripple/ripple.directive'; import { isIE } from '../core/utils'; export var LabelPosition; (function (LabelPosition) { LabelPosition["BEFORE"] = "before"; LabelPosition["AFTER"] = "after"; })(LabelPosition || (LabelPosition = {})); const noop = () => { }; const ɵ0 = noop; let nextId = 0; /** * **Ignite UI for Angular Checkbox** - * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/checkbox.html) * * The Ignite UI Checkbox is a selection control that allows users to make a binary choice. It behaves similarly * to the native browser checkbox. * * Example: * ```html * <igx-checkbox checked="true"> * simple checkbox * </igx-checkbox> * ``` */ let IgxCheckboxComponent = IgxCheckboxComponent_1 = class IgxCheckboxComponent { constructor() { /** * Sets/gets the `id` of the checkbox component. * If not set, the `id` of the first checkbox component will be `"igx-checkbox-0"`. * ```html * <igx-checkbox id="my-first-checkbox"></igx-checkbox> * ``` * ```typescript * let checkboxId = this.checkbox.id; * ``` * @memberof IgxCheckboxComponent */ this.id = `igx-checkbox-${nextId++}`; /** * Sets/gets the id of the `label` element. * If not set, the id of the `label` in the first checkbox component will be `"igx-checkbox-0-label"`. * ```html * <igx-checkbox labelId = "Label1"></igx-checkbox> * ``` * ```typescript * let labelId = this.checkbox.labelId; * ``` * @memberof IgxCheckboxComponent */ this.labelId = `${this.id}-label`; /** * Sets/gets the value of the `tabindex` attribute. * ```html * <igx-checkbox [tabindex] = "1"></igx-checkbox> * ``` * ```typescript * let tabIndex = this.checkbox.tabindex; * ``` * @memberof IgxCheckboxComponent */ this.tabindex = null; /** * Sets/gets the position of the `label`. * If not set, the `labelPosition` will have value `"after"`. * ```html * <igx-checkbox labelPosition = "before"></igx-checkbox> * ``` * ```typescript * let labelPosition = this.checkbox.labelPosition; * ``` * @memberof IgxCheckboxComponent */ this.labelPosition = LabelPosition.AFTER; /** * Enables/Disables the ripple effect. * If not set, `disableRipple` will have value `false`. * ```html * <igx-checkbox [disableRipple] = "true"></igx-checkbox> * ``` * ```typescript * let isRippleDisabled = this.checkbox.desableRipple; * ``` * @memberof IgxCheckboxComponent */ this.disableRipple = false; /** * Sets/gets whether the checkbox is required. * If not set, `required` will have value `false`. * ```html * <igx-checkbox [required] = "true"></igx-checkbox> * ``` * ```typescript * let isRequired = this.checkbox.required; * ``` * @memberof IgxCheckboxComponent */ this.required = false; /** * Sets/gets the `aria-labelledby` attribute. * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute. * ```html * <igx-checkbox aria-labelledby = "Checkbox1"></igx-checkbox> * ``` * ```typescript * let ariaLabelledBy = this.checkbox.ariaLabelledBy; * ``` * @memberof IgxCheckboxComponent */ this.ariaLabelledBy = this.labelId; /** * Sets/gets the value of the `aria-label` attribute. * ```html * <igx-checkbox aria-label = "Checkbox1"></igx-checkbox> * ``` * ```typescript * let ariaLabel = this.checkbox.aruaLabel; * ``` * @memberof IgxCheckboxComponent */ this.ariaLabel = null; /** * An event that is emitted after the checkbox state is changed. * Provides references to the `IgxCheckboxComponent` and the `checked` property as event arguments. * @memberof IgxCheckboxComponent */ this.change = new EventEmitter(); /** * Returns the class of the checkbox component. * ```typescript * let class = this.checkbox.cssClass; * ``` * @memberof IgxCheckboxComponent */ this.cssClass = 'igx-checkbox'; /** * Sets/gets whether the checkbox component is on focus. * Default value is `false`. * ```typescript * this.checkbox.focused = true; * ``` * ```typescript * let isFocused = this.checkbox.focused; * ``` * @memberof IgxCheckboxComponent */ this.focused = false; /** * Sets/gets the checkbox indeterminate visual state. * Default value is `false`; * ```html * <igx-checkbox [indeterminate] = "true"></igx-checkbox> * ``` * ```typescript * let isIndeterminate = this.checkbox.indeterminate; * ``` * @memberof IgxCheckboxComponent */ this.indeterminate = false; /** * Sets/gets whether the checkbox is checked. * Default value is `false`. * ```html * <igx-checkbox [checked] = "true"></igx-checkbox> * ``` * ```typescript * let isChecked = this.checkbox.checked; * ``` * @memberof IgxCheckboxComponent */ this.checked = false; /** * Sets/gets whether the checkbox is disabled. * Default value is `false`. * ```html * <igx-checkbox [disabled] = "true"></igx-checkbox> * ``` * ```typescript * let isDisabled = this.checkbox.disabled; * ``` * @memberof IgxCheckboxComponent */ this.disabled = false; /** * Sets/gets whether the checkbox is readonly. * Default value is `false`. * ```html * <igx-checkbox [readonly]="true"></igx-checkbox> * ``` * ```typescript * let readonly = this.checkbox.readonly; * ``` * @memberof IgxCheckboxComponent */ this.readonly = false; /** * Sets/gets whether the checkbox should disable all css transitions. * Default value is `false`. * ```html * <igx-checkbox [disableTransitions]="true"></igx-checkbox> * ``` * ```typescript * let disableTransitions = this.checkbox.disableTransitions; * ``` * @memberof IgxCheckboxComponent */ this.disableTransitions = false; /** *@hidden */ this.inputId = `${this.id}-input`; /** *@hidden */ this._onTouchedCallback = noop; /** * @hidden */ this._onChangeCallback = noop; } /** * If `disabled` is `false`, switches the `checked` state. * ```typescript * this.checkbox.toggle(); * ``` * @memberof IgxCheckboxComponent */ toggle() { if (this.disabled || this.readonly) { return; } this.indeterminate = false; this.focused = false; this.checked = !this.checked; this.change.emit({ checked: this.checked, checkbox: this }); this._onChangeCallback(this.checked); } /** *@hidden */ _onCheckboxChange(event) { // We have to stop the original checkbox change event // from bubbling up since we emit our own change event event.stopPropagation(); } /** *@hidden */ _onCheckboxClick(event) { // Since the original checkbox is hidden and the label // is used for styling and to change the checked state of the checkbox, // we need to prevent the checkbox click event from bubbling up // as it gets triggered on label click event.stopPropagation(); if (this.readonly) { // readonly prevents the component from changing state (see toggle() method). // However, the native checkbox can still be activated through user interaction (focus + space, label click) // Prevent the native change so the input remains in sync event.preventDefault(); } if (isIE()) { this.nativeCheckbox.nativeElement.blur(); } this.toggle(); } /** *@hidden */ _onLabelClick(event) { // We use a span element as a placeholder label // in place of the native label, we need to emit // the change event separately here alongside // the click event emitted on click this.toggle(); } /** *@hidden */ onFocus(event) { this.focused = true; } /** *@hidden */ onBlur(event) { this.focused = false; this._onTouchedCallback(); } /** *@hidden */ writeValue(value) { this._value = value; this.checked = !!this._value; } /** *@hidden */ get labelClass() { switch (this.labelPosition) { case LabelPosition.BEFORE: return `${this.cssClass}__label--before`; case LabelPosition.AFTER: default: return `${this.cssClass}__label`; } } /** *@hidden */ registerOnChange(fn) { this._onChangeCallback = fn; } /** *@hidden */ registerOnTouched(fn) { this._onTouchedCallback = fn; } /** @hidden */ getEditElement() { return this.nativeCheckbox.nativeElement; } }; __decorate([ ViewChild('checkbox', { static: true }), __metadata("design:type", ElementRef) ], IgxCheckboxComponent.prototype, "nativeCheckbox", void 0); __decorate([ ViewChild('label', { static: true }), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "nativeLabel", void 0); __decorate([ ViewChild('placeholderLabel', { static: true }), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "placeholderLabel", void 0); __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "id", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "labelId", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "value", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxCheckboxComponent.prototype, "name", void 0); __decorate([ Input(), __metadata("design:type", Number) ], IgxCheckboxComponent.prototype, "tabindex", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxCheckboxComponent.prototype, "labelPosition", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "disableRipple", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "required", void 0); __decorate([ Input('aria-labelledby'), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "ariaLabelledBy", void 0); __decorate([ Input('aria-label'), __metadata("design:type", String) ], IgxCheckboxComponent.prototype, "ariaLabel", void 0); __decorate([ Output(), __metadata("design:type", EventEmitter) ], IgxCheckboxComponent.prototype, "change", void 0); __decorate([ HostBinding('class.igx-checkbox'), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "cssClass", void 0); __decorate([ HostBinding('class.igx-checkbox--focused'), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "focused", void 0); __decorate([ HostBinding('class.igx-checkbox--indeterminate'), Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "indeterminate", void 0); __decorate([ HostBinding('class.igx-checkbox--checked'), Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "checked", void 0); __decorate([ HostBinding('class.igx-checkbox--disabled'), Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "disabled", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "readonly", void 0); __decorate([ HostBinding('class.igx-checkbox--plain'), Input(), __metadata("design:type", Object) ], IgxCheckboxComponent.prototype, "disableTransitions", void 0); IgxCheckboxComponent = IgxCheckboxComponent_1 = __decorate([ Component({ providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxCheckboxComponent_1, multi: true }], selector: 'igx-checkbox', preserveWhitespaces: false, template: "<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-checked]=\"checked\"\n [attr.aria-labelledby]=\"ariaLabelledBy\"\n [attr.aria-label]=\"ariaLabel\"\n (change)=\"_onCheckboxChange($event)\"\n (click)=\"_onCheckboxClick($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\" />\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 <label #label class=\"igx-checkbox__composite\"\n [attr.for]=\"inputId\">\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 </label>\n\n <div class=\"igx-checkbox__ripple\"></div>\n</div>\n\n<span #placeholderLabel role=\"label\"\n [class]=\"labelClass\"\n [id]=\"labelId\"\n (click)=\"_onLabelClick($event)\">\n <ng-content></ng-content>\n</span>\n" }) ], IgxCheckboxComponent); export { IgxCheckboxComponent }; export const IGX_CHECKBOX_REQUIRED_VALIDATOR = { provide: NG_VALIDATORS, useExisting: forwardRef(() => IgxCheckboxRequiredDirective), multi: true }; /* tslint:disable directive-selector */ let IgxCheckboxRequiredDirective = class IgxCheckboxRequiredDirective extends CheckboxRequiredValidator { }; IgxCheckboxRequiredDirective = __decorate([ Directive({ selector: `igx-checkbox[required][formControlName], igx-checkbox[required][formControl], igx-checkbox[required][ngModel]`, providers: [IGX_CHECKBOX_REQUIRED_VALIDATOR] }) ], IgxCheckboxRequiredDirective); export { IgxCheckboxRequiredDirective }; /** * @hidden */ let IgxCheckboxModule = class IgxCheckboxModule { }; IgxCheckboxModule = __decorate([ NgModule({ declarations: [IgxCheckboxComponent, IgxCheckboxRequiredDirective], exports: [IgxCheckboxComponent, IgxCheckboxRequiredDirective], imports: [IgxRippleModule] }) ], IgxCheckboxModule); export { IgxCheckboxModule }; export { ɵ0 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/checkbox/checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Directive,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    NgModule,\n    Output,\n    Provider,\n    ViewChild,\n    ElementRef\n} from '@angular/core';\nimport { CheckboxRequiredValidator, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IgxRippleModule } from '../directives/ripple/ripple.directive';\nimport { isIE, IBaseEventArgs } from '../core/utils';\nimport { EditorProvider } from '../core/edit-provider';\n\nexport enum LabelPosition {\n    BEFORE = 'before',\n    AFTER = 'after'\n}\n\nexport interface IChangeCheckboxEventArgs extends IBaseEventArgs {\n    checked: boolean;\n    checkbox: IgxCheckboxComponent;\n}\n\nconst noop = () => { };\nlet nextId = 0;\n/**\n * **Ignite UI for Angular Checkbox** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/checkbox.html)\n *\n * The Ignite UI Checkbox is a selection control that allows users to make a binary choice. 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    providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxCheckboxComponent, multi: true }],\n    selector: 'igx-checkbox',\n    preserveWhitespaces: false,\n    templateUrl: 'checkbox.component.html'\n})\nexport class IgxCheckboxComponent implements ControlValueAccessor, EditorProvider {\n    /**\n     *@hidden\n     */\n    protected _value: any;\n    /**\n     * Returns reference to the native checkbox element.\n     * ```typescript\n     * let checkboxElement =  this.checkbox.checkboxElement;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('checkbox', { static: true }) public nativeCheckbox: ElementRef;\n    /**\n     * Returns reference to the native label element.\n     * ```typescript\n     * let labelElement =  this.checkbox.nativeLabel;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('label', { static: true }) public nativeLabel;\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     * let labelPlaceholder =  this.checkbox.placeholderLabel;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('placeholderLabel', { static: true }) public placeholderLabel;\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     * ```html\n     * <igx-checkbox id=\"my-first-checkbox\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let checkboxId =  this.checkbox.id;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('attr.id')\n    @Input() public id = `igx-checkbox-${nextId++}`;\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     * ```html\n     * <igx-checkbox labelId = \"Label1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelId =  this.checkbox.labelId;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public labelId = `${this.id}-label`;\n    /**\n     * Sets/gets the `value` attribute.\n     * ```html\n     * <igx-checkbox [value] = \"'CheckboxValue'\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let value =  this.checkbox.value;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public value: any;\n    /**\n     * Sets/gets the `name` attribute.\n     * ```html\n     * <igx-checkbox name = \"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let name =  this.checkbox.name;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public name: string;\n    /**\n     * Sets/gets the value of the `tabindex` attribute.\n     * ```html\n     * <igx-checkbox [tabindex] = \"1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.checkbox.tabindex;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public tabindex: number = null;\n    /**\n     *  Sets/gets the position of the `label`.\n     *  If not set, the `labelPosition` will have value `\"after\"`.\n     * ```html\n     * <igx-checkbox labelPosition = \"before\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.checkbox.labelPosition;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public labelPosition: LabelPosition | string = LabelPosition.AFTER;\n    /**\n     * Enables/Disables the ripple effect.\n     * If not set, `disableRipple` will have value `false`.\n     * ```html\n     * <igx-checkbox [disableRipple] = \"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRippleDisabled = this.checkbox.desableRipple;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public disableRipple = false;\n    /**\n     * Sets/gets whether the checkbox is required.\n     * If not set, `required` will have value `false`.\n     * ```html\n     * <igx-checkbox [required] = \"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRequired =  this.checkbox.required;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public required = false;\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     * ```html\n     * <igx-checkbox aria-labelledby = \"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy =  this.checkbox.ariaLabelledBy;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n    /**\n     * Sets/gets the value of the `aria-label` attribute.\n     * ```html\n     * <igx-checkbox aria-label = \"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabel = this.checkbox.aruaLabel;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\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     * @memberof IgxCheckboxComponent\n     */\n    @Output()\n    readonly change: EventEmitter<IChangeCheckboxEventArgs> = new EventEmitter<IChangeCheckboxEventArgs>();\n    /**\n     * Returns the class of the checkbox component.\n     * ```typescript\n     * let class =  this.checkbox.cssClass;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('class.igx-checkbox')\n    public cssClass = 'igx-checkbox';\n    /**\n     * Sets/gets whether the checkbox component is on focus.\n     * Default value is `false`.\n     * ```typescript\n     * this.checkbox.focused =  true;\n     * ```\n     * ```typescript\n     * let isFocused =  this.checkbox.focused;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('class.igx-checkbox--focused')\n    public focused = false;\n    /**\n     * Sets/gets the checkbox indeterminate visual state.\n     * Default value is `false`;\n     * ```html\n     * <igx-checkbox [indeterminate] = \"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isIndeterminate = this.checkbox.indeterminate;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('class.igx-checkbox--indeterminate')\n    @Input() public indeterminate = false;\n    /**\n     * Sets/gets whether the checkbox is checked.\n     * Default value is `false`.\n     * ```html\n     * <igx-checkbox [checked] = \"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isChecked =  this.checkbox.checked;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('class.igx-checkbox--checked')\n    @Input() public checked = false;\n    /**\n     * Sets/gets whether the checkbox is disabled.\n     * Default value is `false`.\n     * ```html\n     * <igx-checkbox [disabled] = \"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isDisabled = this.checkbox.disabled;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('class.igx-checkbox--disabled')\n    @Input() public disabled = false;\n    /**\n     * Sets/gets whether the checkbox is readonly.\n     * Default value is `false`.\n     * ```html\n     * <igx-checkbox [readonly]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let readonly = this.checkbox.readonly;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @Input() public readonly = false;\n    /**\n     * Sets/gets whether the checkbox should disable all css transitions.\n     * Default value is `false`.\n     * ```html\n     * <igx-checkbox [disableTransitions]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let disableTransitions = this.checkbox.disableTransitions;\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    @HostBinding('class.igx-checkbox--plain')\n    @Input() public disableTransitions = false;\n    /**\n     *@hidden\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     *@hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n    /**\n     * @hidden\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n    /**\n     * If `disabled` is `false`, switches the `checked` state.\n     * ```typescript\n     * this.checkbox.toggle();\n     * ```\n     * @memberof IgxCheckboxComponent\n     */\n    public toggle() {\n        if (this.disabled || this.readonly) {\n            return;\n        }\n\n        this.indeterminate = false;\n        this.focused = false;\n        this.checked = !this.checked;\n\n        this.change.emit({ checked: this.checked, checkbox: this });\n        this._onChangeCallback(this.checked);\n    }\n    /**\n     *@hidden\n     */\n    public _onCheckboxChange(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\n     */\n    public _onCheckboxClick(event) {\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        event.stopPropagation();\n\n        if (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        }\n\n        if (isIE()) {\n            this.nativeCheckbox.nativeElement.blur();\n        }\n\n        this.toggle();\n    }\n    /**\n     *@hidden\n     */\n    public _onLabelClick(event) {\n        // We use a span element as a placeholder label\n        // in place of the native label, we need to emit\n        // the change event separately here alongside\n        // the click event emitted on click\n        this.toggle();\n    }\n    /**\n     *@hidden\n     */\n    public onFocus(event) {\n        this.focused = true;\n    }\n    /**\n     *@hidden\n     */\n    public onBlur(event) {\n        this.focused = false;\n        this._onTouchedCallback();\n    }\n    /**\n     *@hidden\n     */\n    public writeValue(value) {\n        this._value = value;\n        this.checked = !!this._value;\n    }\n    /**\n     *@hidden\n     */\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\n     */\n    public registerOnChange(fn: (_: any) => void) { this._onChangeCallback = fn; }\n    /**\n     *@hidden\n     */\n    public registerOnTouched(fn: () => void) { this._onTouchedCallback = fn; }\n\n    /** @hidden */\n    getEditElement() {\n        return this.nativeCheckbox.nativeElement;\n    }\n}\n\nexport const IGX_CHECKBOX_REQUIRED_VALIDATOR: Provider = {\n    provide: NG_VALIDATORS,\n    useExisting: forwardRef(() => IgxCheckboxRequiredDirective),\n    multi: true\n};\n\n/* tslint:disable directive-selector */\n@Directive({\n    selector: `igx-checkbox[required][formControlName],\n    igx-checkbox[required][formControl],\n    igx-checkbox[required][ngModel]`,\n    providers: [IGX_CHECKBOX_REQUIRED_VALIDATOR]\n})\nexport class IgxCheckboxRequiredDirective extends CheckboxRequiredValidator { }\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxCheckboxComponent, IgxCheckboxRequiredDirective],\n    exports: [IgxCheckboxComponent, IgxCheckboxRequiredDirective],\n    imports: [IgxRippleModule]\n})\nexport class IgxCheckboxModule { }\n"]}