@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
465 lines • 42.2 kB
JavaScript
import { __decorate, __extends, __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 = {}));
var noop = function () { };
var ɵ0 = noop;
var 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>
* ```
*/
var IgxCheckboxComponent = /** @class */ (function () {
function IgxCheckboxComponent() {
/**
* 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;
}
IgxCheckboxComponent_1 = IgxCheckboxComponent;
/**
* If `disabled` is `false`, switches the `checked` state.
* ```typescript
* this.checkbox.toggle();
* ```
* @memberof IgxCheckboxComponent
*/
IgxCheckboxComponent.prototype.toggle = function () {
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
*/
IgxCheckboxComponent.prototype._onCheckboxChange = function (event) {
// We have to stop the original checkbox change event
// from bubbling up since we emit our own change event
event.stopPropagation();
};
/**
*@hidden
*/
IgxCheckboxComponent.prototype._onCheckboxClick = function (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
*/
IgxCheckboxComponent.prototype._onLabelClick = function (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
*/
IgxCheckboxComponent.prototype.onFocus = function (event) {
this.focused = true;
};
/**
*@hidden
*/
IgxCheckboxComponent.prototype.onBlur = function (event) {
this.focused = false;
this._onTouchedCallback();
};
/**
*@hidden
*/
IgxCheckboxComponent.prototype.writeValue = function (value) {
this._value = value;
this.checked = !!this._value;
};
Object.defineProperty(IgxCheckboxComponent.prototype, "labelClass", {
/**
*@hidden
*/
get: function () {
switch (this.labelPosition) {
case LabelPosition.BEFORE:
return this.cssClass + "__label--before";
case LabelPosition.AFTER:
default:
return this.cssClass + "__label";
}
},
enumerable: true,
configurable: true
});
/**
*@hidden
*/
IgxCheckboxComponent.prototype.registerOnChange = function (fn) { this._onChangeCallback = fn; };
/**
*@hidden
*/
IgxCheckboxComponent.prototype.registerOnTouched = function (fn) { this._onTouchedCallback = fn; };
/** @hidden */
IgxCheckboxComponent.prototype.getEditElement = function () {
return this.nativeCheckbox.nativeElement;
};
var IgxCheckboxComponent_1;
__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);
return IgxCheckboxComponent;
}());
export { IgxCheckboxComponent };
export var IGX_CHECKBOX_REQUIRED_VALIDATOR = {
provide: NG_VALIDATORS,
useExisting: forwardRef(function () { return IgxCheckboxRequiredDirective; }),
multi: true
};
/* tslint:disable directive-selector */
var IgxCheckboxRequiredDirective = /** @class */ (function (_super) {
__extends(IgxCheckboxRequiredDirective, _super);
function IgxCheckboxRequiredDirective() {
return _super !== null && _super.apply(this, arguments) || this;
}
IgxCheckboxRequiredDirective = __decorate([
Directive({
selector: "igx-checkbox[required][formControlName],\n igx-checkbox[required][formControl],\n igx-checkbox[required][ngModel]",
providers: [IGX_CHECKBOX_REQUIRED_VALIDATOR]
})
], IgxCheckboxRequiredDirective);
return IgxCheckboxRequiredDirective;
}(CheckboxRequiredValidator));
export { IgxCheckboxRequiredDirective };
/**
* @hidden
*/
var IgxCheckboxModule = /** @class */ (function () {
function IgxCheckboxModule() {
}
IgxCheckboxModule = __decorate([
NgModule({
declarations: [IgxCheckboxComponent, IgxCheckboxRequiredDirective],
exports: [IgxCheckboxComponent, IgxCheckboxRequiredDirective],
imports: [IgxRippleModule]
})
], IgxCheckboxModule);
return 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"]}