UNPKG

igniteui-angular

Version:

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

661 lines 44.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ 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'; /** @enum {string} */ const LabelPosition = { BEFORE: 'before', AFTER: 'after', }; export { LabelPosition }; /** * @record */ export function IChangeCheckboxEventArgs() { } if (false) { /** @type {?} */ IChangeCheckboxEventArgs.prototype.checked; /** @type {?} */ IChangeCheckboxEventArgs.prototype.checkbox; } /** @type {?} */ const noop = () => { }; const ɵ0 = noop; /** @type {?} */ 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> * ``` */ export 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 isDesabled = this.checkbox.disabled; * ``` * \@memberof IgxCheckboxComponent */ this.disabled = 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 * @return {?} */ toggle() { if (this.disabled) { return; } this.indeterminate = false; this.focused = false; this.checked = !this.checked; this.change.emit({ checked: this.checked, checkbox: this }); this._onChangeCallback(this.checked); } /** * @hidden * @param {?} event * @return {?} */ _onCheckboxChange(event) { // We have to stop the original checkbox change event // from bubbling up since we emit our own change event event.stopPropagation(); } /** * @hidden * @param {?} event * @return {?} */ _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 (isIE()) { this.nativeCheckbox.nativeElement.blur(); } this.toggle(); } /** * @hidden * @param {?} event * @return {?} */ _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 * @param {?} event * @return {?} */ onFocus(event) { this.focused = true; } /** * @hidden * @param {?} event * @return {?} */ onBlur(event) { this.focused = false; this._onTouchedCallback(); } /** * @hidden * @param {?} value * @return {?} */ writeValue(value) { this._value = value; this.checked = !!this._value; } /** * @hidden * @return {?} */ get labelClass() { switch (this.labelPosition) { case LabelPosition.BEFORE: return `${this.cssClass}__label--before`; case LabelPosition.AFTER: default: return `${this.cssClass}__label`; } } /** * @hidden * @param {?} fn * @return {?} */ registerOnChange(fn) { this._onChangeCallback = fn; } /** * @hidden * @param {?} fn * @return {?} */ registerOnTouched(fn) { this._onTouchedCallback = fn; } /** * @hidden * @return {?} */ getEditElement() { return this.nativeCheckbox.nativeElement; } } IgxCheckboxComponent.decorators = [ { type: Component, args: [{ providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxCheckboxComponent, 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<label #label class=\"igx-checkbox__composite\"\n igxRipple\n igxRippleTarget=\".igx-checkbox__ripple\"\n [igxRippleDisabled]=\"disableRipple\"\n [igxRippleCentered]=\"true\"\n [igxRippleDuration]=\"300\"\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 <div class=\"igx-checkbox__ripple\"></div>\n</label>\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.propDecorators = { nativeCheckbox: [{ type: ViewChild, args: ['checkbox',] }], nativeLabel: [{ type: ViewChild, args: ['label',] }], placeholderLabel: [{ type: ViewChild, args: ['placeholderLabel',] }], id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], labelId: [{ type: Input }], value: [{ type: Input }], name: [{ type: Input }], tabindex: [{ type: Input }], labelPosition: [{ type: Input }], disableRipple: [{ type: Input }], required: [{ type: Input }], ariaLabelledBy: [{ type: Input, args: ['aria-labelledby',] }], ariaLabel: [{ type: Input, args: ['aria-label',] }], change: [{ type: Output }], cssClass: [{ type: HostBinding, args: ['class.igx-checkbox',] }], focused: [{ type: HostBinding, args: ['class.igx-checkbox--focused',] }], indeterminate: [{ type: HostBinding, args: ['class.igx-checkbox--indeterminate',] }, { type: Input }], checked: [{ type: HostBinding, args: ['class.igx-checkbox--checked',] }, { type: Input }], disabled: [{ type: HostBinding, args: ['class.igx-checkbox--disabled',] }, { type: Input }], disableTransitions: [{ type: HostBinding, args: ['class.igx-checkbox--plain',] }, { type: Input }] }; if (false) { /** * @hidden * @type {?} * @protected */ IgxCheckboxComponent.prototype._value; /** * Returns reference to the native checkbox element. * ```typescript * let checkboxElement = this.checkbox.checkboxElement; * ``` * \@memberof IgxSwitchComponent * @type {?} */ IgxCheckboxComponent.prototype.nativeCheckbox; /** * Returns reference to the native label element. * ```typescript * let labelElement = this.checkbox.nativeLabel; * ``` * \@memberof IgxSwitchComponent * @type {?} */ IgxCheckboxComponent.prototype.nativeLabel; /** * Returns reference to the label placeholder element. * ```typescript * let labelPlaceholder = this.checkbox.placeholderLabel; * ``` * \@memberof IgxSwitchComponent * @type {?} */ IgxCheckboxComponent.prototype.placeholderLabel; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.id; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.labelId; /** * Sets/gets the `value` attribute. * ```html * <igx-checkbox [value] = "'CheckboxValue'"></igx-checkbox> * ``` * ```typescript * let value = this.checkbox.value; * ``` * \@memberof IgxCheckboxComponent * @type {?} */ IgxCheckboxComponent.prototype.value; /** * Sets/gets the `name` attribute. * ```html * <igx-checkbox name = "Checkbox1"></igx-checkbox> * ``` * ```typescript * let name = this.checkbox.name; * ``` * \@memberof IgxCheckboxComponent * @type {?} */ IgxCheckboxComponent.prototype.name; /** * Sets/gets the value of the `tabindex` attribute. * ```html * <igx-checkbox [tabindex] = "1"></igx-checkbox> * ``` * ```typescript * let tabIndex = this.checkbox.tabindex; * ``` * \@memberof IgxCheckboxComponent * @type {?} */ IgxCheckboxComponent.prototype.tabindex; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.labelPosition; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.disableRipple; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.required; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.ariaLabelledBy; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.ariaLabel; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.change; /** * Returns the class of the checkbox component. * ```typescript * let class = this.checkbox.cssClass; * ``` * \@memberof IgxCheckboxComponent * @type {?} */ IgxCheckboxComponent.prototype.cssClass; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.focused; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.indeterminate; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.checked; /** * Sets/gets whether the checkbox is disabled. * Default value is `false`. * ```html * <igx-checkbox [disabled] = "true"></igx-checkbox> * ``` * ```typescript * let isDesabled = this.checkbox.disabled; * ``` * \@memberof IgxCheckboxComponent * @type {?} */ IgxCheckboxComponent.prototype.disabled; /** * 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 * @type {?} */ IgxCheckboxComponent.prototype.disableTransitions; /** * @hidden * @type {?} */ IgxCheckboxComponent.prototype.inputId; /** * @hidden * @type {?} * @private */ IgxCheckboxComponent.prototype._onTouchedCallback; /** * @hidden * @type {?} * @private */ IgxCheckboxComponent.prototype._onChangeCallback; } /** @type {?} */ export const IGX_CHECKBOX_REQUIRED_VALIDATOR = { provide: NG_VALIDATORS, useExisting: forwardRef(() => IgxCheckboxRequiredDirective), multi: true }; /* tslint:disable directive-selector */ export class IgxCheckboxRequiredDirective extends CheckboxRequiredValidator { } IgxCheckboxRequiredDirective.decorators = [ { type: Directive, args: [{ selector: `igx-checkbox[required][formControlName], igx-checkbox[required][formControl], igx-checkbox[required][ngModel]`, providers: [IGX_CHECKBOX_REQUIRED_VALIDATOR] },] } ]; /** * @hidden */ export class IgxCheckboxModule { } IgxCheckboxModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxCheckboxComponent, IgxCheckboxRequiredDirective], exports: [IgxCheckboxComponent, IgxCheckboxRequiredDirective], imports: [IgxRippleModule] },] } ]; 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":";;;;AAAA,OAAO,EACH,SAAS,EACT,SAAS,EACT,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EACL,QAAQ,EACR,MAAM,EAEN,SAAS,EACT,UAAU,EACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,yBAAyB,EAAwB,aAAa,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnH,OAAO,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AACxE,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;;;IAIjC,QAAS,QAAQ;IACjB,OAAQ,OAAO;;;;;;AAGnB,8CAGC;;;IAFG,2CAAiB;;IACjB,4CAA+B;;;MAG7B,IAAI,GAAG,GAAG,EAAE,GAAG,CAAC;;;IAClB,MAAM,GAAG,CAAC;;;;;;;;;;;;;;;AAqBd,MAAM,OAAO,oBAAoB;IANjC;;;;;;;;;;;;QA+CoB,OAAE,GAAG,gBAAgB,MAAM,EAAE,EAAE,CAAC;;;;;;;;;;;;QAYhC,YAAO,GAAG,GAAG,IAAI,CAAC,EAAE,QAAQ,CAAC;;;;;;;;;;;QAiC7B,aAAQ,GAAW,IAAI,CAAC;;;;;;;;;;;;QAYxB,kBAAa,GAA2B,aAAa,CAAC,KAAK,CAAC;;;;;;;;;;;;QAY5D,kBAAa,GAAG,KAAK,CAAC;;;;;;;;;;;;QAYtB,aAAQ,GAAG,KAAK,CAAC;;;;;;;;;;;;QAa1B,mBAAc,GAAG,IAAI,CAAC,OAAO,CAAC;;;;;;;;;;;QAY9B,cAAS,GAAkB,IAAI,CAAC;;;;;;QAO9B,WAAM,GAA2C,IAAI,YAAY,EAA4B,CAAC;;;;;;;;QAShG,aAAQ,GAAG,cAAc,CAAC;;;;;;;;;;;;QAa1B,YAAO,GAAG,KAAK,CAAC;;;;;;;;;;;;QAaP,kBAAa,GAAG,KAAK,CAAC;;;;;;;;;;;;QAatB,YAAO,GAAG,KAAK,CAAC;;;;;;;;;;;;QAahB,aAAQ,GAAG,KAAK,CAAC;;;;;;;;;;;;QAajB,uBAAkB,GAAG,KAAK,CAAC;;;;QAIpC,YAAO,GAAG,GAAG,IAAI,CAAC,EAAE,QAAQ,CAAC;;;;QAI5B,uBAAkB,GAAe,IAAI,CAAC;;;;QAItC,sBAAiB,GAAqB,IAAI,CAAC;IAmGvD,CAAC;;;;;;;;;IA3FU,MAAM;QACT,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAO;SACV;QAED,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;QAE7B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;;;;;;IAIM,iBAAiB,CAAC,KAAK;QAC1B,qDAAqD;QACrD,sDAAsD;QACtD,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;;;;;;IAIM,gBAAgB,CAAC,KAAK;QACzB,sDAAsD;QACtD,uEAAuE;QACvE,+DAA+D;QAC/D,sCAAsC;QACtC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,IAAI,EAAE,EAAE;YACR,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;SAC5C;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;;;;;;IAIM,aAAa,CAAC,KAAK;QACtB,+CAA+C;QAC/C,gDAAgD;QAChD,6CAA6C;QAC7C,mCAAmC;QACnC,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;;;;;;IAIM,OAAO,CAAC,KAAK;QAChB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACxB,CAAC;;;;;;IAIM,MAAM,CAAC,KAAK;QACf,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;;;;;;IAIM,UAAU,CAAC,KAAK;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;IACjC,CAAC;;;;;IAID,IAAW,UAAU;QACjB,QAAQ,IAAI,CAAC,aAAa,EAAE;YACxB,KAAK,aAAa,CAAC,MAAM;gBACrB,OAAO,GAAG,IAAI,CAAC,QAAQ,iBAAiB,CAAC;YAC7C,KAAK,aAAa,CAAC,KAAK,CAAC;YACzB;gBACI,OAAO,GAAG,IAAI,CAAC,QAAQ,SAAS,CAAC;SACxC;IACL,CAAC;;;;;;IAIM,gBAAgB,CAAC,EAAoB,IAAI,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC,CAAC,CAAC;;;;;;IAIvE,iBAAiB,CAAC,EAAc,IAAI,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC,CAAC,CAAC;;;;;IAG1E,cAAc;QACV,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;IAC7C,CAAC;;;YAxVJ,SAAS,SAAC;gBACP,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,oBAAoB,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;gBAC3F,QAAQ,EAAE,cAAc;gBACxB,mBAAmB,EAAE,KAAK;gBAC1B,6sCAAsC;aACzC;;;6BAaI,SAAS,SAAC,UAAU;0BAQpB,SAAS,SAAC,OAAO;+BAQjB,SAAS,SAAC,kBAAkB;iBAY5B,WAAW,SAAC,SAAS,cACrB,KAAK;sBAYL,KAAK;oBAWL,KAAK;mBAWL,KAAK;uBAWL,KAAK;4BAYL,KAAK;4BAYL,KAAK;uBAYL,KAAK;6BAYL,KAAK,SAAC,iBAAiB;wBAYvB,KAAK,SAAC,YAAY;qBAOlB,MAAM;uBASN,WAAW,SAAC,oBAAoB;sBAahC,WAAW,SAAC,6BAA6B;4BAazC,WAAW,SAAC,mCAAmC,cAC/C,KAAK;sBAYL,WAAW,SAAC,6BAA6B,cACzC,KAAK;uBAYL,WAAW,SAAC,8BAA8B,cAC1C,KAAK;iCAYL,WAAW,SAAC,2BAA2B,cACvC,KAAK;;;;;;;;IAhON,sCAAsB;;;;;;;;;IAQtB,8CAAyD;;;;;;;;;IAQzD,2CAAuC;;;;;;;;;IAQvC,gDAAuD;;;;;;;;;;;;;IAYvD,kCACgD;;;;;;;;;;;;;IAYhD,uCAA6C;;;;;;;;;;;;IAW7C,qCAA2B;;;;;;;;;;;;IAW3B,oCAA6B;;;;;;;;;;;;IAW7B,wCAAwC;;;;;;;;;;;;;IAYxC,6CAA4E;;;;;;;;;;;;;IAY5E,6CAAsC;;;;;;;;;;;;;IAYtC,wCAAiC;;;;;;;;;;;;;IAYjC,8CACqC;;;;;;;;;;;;IAWrC,yCACuC;;;;;;;IAMvC,sCACuG;;;;;;;;;IAQvG,wCACiC;;;;;;;;;;;;;IAYjC,uCACuB;;;;;;;;;;;;;IAYvB,6CACsC;;;;;;;;;;;;;IAYtC,uCACgC;;;;;;;;;;;;;IAYhC,wCACiC;;;;;;;;;;;;;IAYjC,kDAC2C;;;;;IAI3C,uCAAoC;;;;;;IAIpC,kDAA8C;;;;;;IAI9C,iDAAmD;;;AAqGvD,MAAM,OAAO,+BAA+B,GAAa;IACrD,OAAO,EAAE,aAAa;IACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,4BAA4B,CAAC;IAC3D,KAAK,EAAE,IAAI;CACd;;AASD,MAAM,OAAO,4BAA6B,SAAQ,yBAAyB;;;YAN1E,SAAS,SAAC;gBACP,QAAQ,EAAE;;oCAEsB;gBAChC,SAAS,EAAE,CAAC,+BAA+B,CAAC;aAC/C;;;;;AAWD,MAAM,OAAO,iBAAiB;;;YAL7B,QAAQ,SAAC;gBACN,YAAY,EAAE,CAAC,oBAAoB,EAAE,4BAA4B,CAAC;gBAClE,OAAO,EAAE,CAAC,oBAAoB,EAAE,4BAA4B,CAAC;gBAC7D,OAAO,EAAE,CAAC,eAAe,CAAC;aAC7B","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 } from '../core/utils';\nimport { EditorProvider } from '../core/edit-provider';\n\nexport enum LabelPosition {\n    BEFORE = 'before',\n    AFTER = 'after'\n}\n\nexport interface IChangeCheckboxEventArgs {\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') 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') 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') 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 isDesabled = 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 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) {\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 (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"]}