@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
398 lines • 34.9 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 SwitchLabelPosition;
(function (SwitchLabelPosition) {
SwitchLabelPosition["BEFORE"] = "before";
SwitchLabelPosition["AFTER"] = "after";
})(SwitchLabelPosition || (SwitchLabelPosition = {}));
var noop = function () { };
var ɵ0 = noop;
var nextId = 0;
/**
* **Ignite UI for Angular Switch** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/switch.html)
*
* The Ignite UI Switch lets the user toggle between on/off or true/false states.
*
* Example:
* ```html
* <igx-switch [checked]="true">
* Simple switch
* </igx-switch>
* ```
*/
var IgxSwitchComponent = /** @class */ (function () {
function IgxSwitchComponent() {
/**
* Sets/gets the `id` of the switch component.
* If not set, the `id` of the first switch component will be `"igx-switch-0"`.
* ```html
* <igx-switch id="my-first-switch"></igx-switch>
* ```
* ```typescript
* let switchId = this.switch.id;
* ```
* @memberof IgxSwitchComponent
*/
this.id = "igx-switch-" + nextId++;
/**
* Sets/gets the id of the `label` element in the switch component.
* If not set, the label of the first switch component will have value `"igx-switch-0-label"`.
* ```html
* <igx-switch labelId="Label1"></igx-switch>
* ```
* ```typescript
* let labelId = this.switch.labelId;
* ```
* @memberof IgxSwitchComponent
*/
this.labelId = this.id + "-label";
/**
* Sets/gets the value of the `tabindex` attribute.
* ```html
* <igx-switch [tabindex]="1"></igx-switch>
* ```
* ```typescript
* let tabIndex = this.switch.tabindex;
* ```
* @memberof IgxSwitchComponent
*/
this.tabindex = null;
/**
* Sets/gets the position of the `label` in the switch component.
* If not set, `labelPosition` will have value `"after"`.
* ```html
* <igx-switch labelPosition="before"></igx-switch>
* ```
* ```typescript
* let labelPosition = this.switch.labelPosition;
* ```
* @memberof IgxSwitchComponent
*/
this.labelPosition = 'after';
/**
* Enables/Disables the ripple effect
* If not set, `disableRipple` will have value `false`.
* ```html
* <igx-switch [disableRipple]="true"></igx-switch>
* ```
* ```typescript
* let isRippleDisabled = this.switch.disableRipple;
* ```
* @memberof IgxSwitchComponent
*/
this.disableRipple = false;
/**
* Sets/gets whether switch is required.
* If not set, `required` will have value `false`.
* ```html
* <igx-switch [required]="true"></igx-switch>
* ```
* ```typescript
* let isRequired = this.switch.required;
* ```
* @memberof IgxSwitchComponent
*/
this.required = false;
/**
* Sets/gets the `aria-labelledBy` attribute.
* If not set, the value of `aria-labelledBy` will be equal to the value of `labelId` attribute.
* ```html
* <igx-switch aria-labelledby = "Label1"></igx-switch>
* ```
* ```typescript
* let ariaLabelledBy = this.switch.ariaLabelledBy;
* ```
* @memberof IgxSwitchComponent
*/
this.ariaLabelledBy = this.labelId;
/**
* Sets/gets the value of the `aria-label` attribute.
* ```html
* <igx-switch aria-label="Label1"></igx-switch>
* ```
* ```typescript
* let ariaLabel = this.switch.ariaLabel;
* ```
* @memberof IgxSwitchComponent
*/
this.ariaLabel = null;
/**
* An event that is emitted after the switch state is changed.
* Provides references to the `IgxSwitchComponent` and the `checked` property as event arguments.
* @memberof IgxSwitchComponent
*/
this.change = new EventEmitter();
/**
*@hidden
* @memberof IgxSwitchComponent
*/
this._onTouchedCallback = noop;
/**
*@hidden
* @memberof IgxSwitchComponent
*/
this._onChangeCallback = noop;
/**
* Returns the class of the switch component.
* ```typescript
* let switchClass = this.switch.cssClass;
* ```
* @memberof IgxSwitchComponent
*/
this.cssClass = 'igx-switch';
/**
* Sets/gets whether the switch is on or off.
* Default value is 'false'.
* ```html
* <igx-switch [checked] = "true"></igx-switch>
* ```
* ```typescript
* let isChecked = this.switch.checked;
* ```
* @memberof IgxSwitchComponent
*/
this.checked = false;
/**
* Sets/gets the `disabled` attribute.
* Default value is `false`.
* ```html
* <igx-switch [disabled] = "true"><igx-switch>
* ```
* ```typescript
* let isDisabled = this.switch.disabled;
* ```
* @memberof IgxSwitchComponent
*/
this.disabled = false;
/**
* Sets/gets whether the switch component is on focus.
* Default value is `false`.
* ```typescript
* this.switch.focused = true;
* ```
* ```typescript
* let isFocused = this.switch.focused;
* ```
* @memberof IgxSwitchComponent
*/
this.focused = false;
/**
*@hidden
*/
this.inputId = this.id + "-input";
}
IgxSwitchComponent_1 = IgxSwitchComponent;
/**
* Toggles the checked state of the switch.
* ```typescript
* this.switch.toggle();
* ```
* @memberof IgxSwitchComponent
*/
IgxSwitchComponent.prototype.toggle = function () {
if (this.disabled) {
return;
}
this.checked = !this.checked;
this.focused = false;
this.change.emit({ checked: this.checked, switch: this });
this._onChangeCallback(this.checked);
};
/**
*@hidden
*/
IgxSwitchComponent.prototype._onSwitchChange = function (event) {
event.stopPropagation();
};
/**
*@hidden
*/
IgxSwitchComponent.prototype._onSwitchClick = function (event) {
event.stopPropagation();
this.toggle();
if (isIE()) {
this.nativeCheckbox.nativeElement.blur();
}
};
/**
*@hidden
*/
IgxSwitchComponent.prototype._onLabelClick = function (event) {
this.toggle();
};
/**
*@hidden
*/
IgxSwitchComponent.prototype.onFocus = function (event) {
this.focused = true;
};
/**
*@hidden
*/
IgxSwitchComponent.prototype.onBlur = function (event) {
this.focused = false;
this._onTouchedCallback();
};
/**
*@hidden
*/
IgxSwitchComponent.prototype.writeValue = function (value) {
this._value = value;
this.checked = !!this._value;
};
/** @hidden */
IgxSwitchComponent.prototype.getEditElement = function () {
return this.nativeCheckbox.nativeElement;
};
Object.defineProperty(IgxSwitchComponent.prototype, "labelClass", {
/**
*@hidden
*/
get: function () {
switch (this.labelPosition) {
case SwitchLabelPosition.BEFORE:
return this.cssClass + "__label--before";
case SwitchLabelPosition.AFTER:
default:
return this.cssClass + "__label";
}
},
enumerable: true,
configurable: true
});
/**
*@hidden
*/
IgxSwitchComponent.prototype.registerOnChange = function (fn) { this._onChangeCallback = fn; };
/**
*@hidden
*/
IgxSwitchComponent.prototype.registerOnTouched = function (fn) { this._onTouchedCallback = fn; };
var IgxSwitchComponent_1;
__decorate([
ViewChild('checkbox', { static: true }),
__metadata("design:type", ElementRef)
], IgxSwitchComponent.prototype, "nativeCheckbox", void 0);
__decorate([
ViewChild('label', { static: true }),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "nativeLabel", void 0);
__decorate([
ViewChild('placeholderLabel', { static: true }),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "placeholderLabel", void 0);
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "id", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "labelId", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "value", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxSwitchComponent.prototype, "name", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxSwitchComponent.prototype, "tabindex", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxSwitchComponent.prototype, "labelPosition", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "disableRipple", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "required", void 0);
__decorate([
Input('aria-labelledby'),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "ariaLabelledBy", void 0);
__decorate([
Input('aria-label'),
__metadata("design:type", String)
], IgxSwitchComponent.prototype, "ariaLabel", void 0);
__decorate([
Output(),
__metadata("design:type", EventEmitter)
], IgxSwitchComponent.prototype, "change", void 0);
__decorate([
HostBinding('class.igx-switch'),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "cssClass", void 0);
__decorate([
HostBinding('class.igx-switch--checked'),
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "checked", void 0);
__decorate([
HostBinding('class.igx-switch--disabled'),
Input(),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "disabled", void 0);
__decorate([
HostBinding('class.igx-switch--focused'),
__metadata("design:type", Object)
], IgxSwitchComponent.prototype, "focused", void 0);
IgxSwitchComponent = IgxSwitchComponent_1 = __decorate([
Component({
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxSwitchComponent_1, multi: true }],
selector: 'igx-switch',
template: "<input #checkbox class=\"igx-switch__input\" type=\"checkbox\"\n [id]=\"inputId\"\n [name]=\"name\"\n [value]=\"value\"\n [tabindex]=\"tabindex\"\n [disabled]=\"disabled\"\n [checked]=\"checked\"\n [required]=\"required\"\n [attr.aria-checked]=\"checked\"\n [attr.aria-labelledby]=\"ariaLabelledBy\"\n [attr.aria-label]=\"ariaLabel\"\n (change)=\"_onSwitchChange($event)\"\n (click)=\"_onSwitchClick($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\" />\n\n<label #label class =\"igx-switch__composite\" [for]=\"inputId\"\n igxRipple\n igxRippleTarget=\".igx-switch__ripple\"\n [igxRippleDisabled]=\"disableRipple\"\n [igxRippleCentered]=\"true\"\n [igxRippleDuration]=\"300\">\n <div class=\"igx-switch__composite-thumb\">\n <div class=\"igx-switch__ripple\"></div>\n </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"
})
], IgxSwitchComponent);
return IgxSwitchComponent;
}());
export { IgxSwitchComponent };
export var IGX_SWITCH_REQUIRED_VALIDATOR = {
provide: NG_VALIDATORS,
useExisting: forwardRef(function () { return IgxSwitchRequiredDirective; }),
multi: true
};
/* tslint:disable directive-selector */
var IgxSwitchRequiredDirective = /** @class */ (function (_super) {
__extends(IgxSwitchRequiredDirective, _super);
function IgxSwitchRequiredDirective() {
return _super !== null && _super.apply(this, arguments) || this;
}
IgxSwitchRequiredDirective = __decorate([
Directive({
selector: "igx-switch[required][formControlName],\n igx-switch[required][formControl],\n igx-switch[required][ngModel]",
providers: [IGX_SWITCH_REQUIRED_VALIDATOR]
})
], IgxSwitchRequiredDirective);
return IgxSwitchRequiredDirective;
}(CheckboxRequiredValidator));
export { IgxSwitchRequiredDirective };
/**
* @hidden
*/
var IgxSwitchModule = /** @class */ (function () {
function IgxSwitchModule() {
}
IgxSwitchModule = __decorate([
NgModule({
declarations: [IgxSwitchComponent, IgxSwitchRequiredDirective],
exports: [IgxSwitchComponent, IgxSwitchRequiredDirective],
imports: [IgxRippleModule]
})
], IgxSwitchModule);
return IgxSwitchModule;
}());
export { IgxSwitchModule };
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switch.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/switch/switch.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 SwitchLabelPosition {\n    BEFORE = 'before',\n    AFTER = 'after'\n}\n\nexport interface IChangeSwitchEventArgs extends IBaseEventArgs {\n    checked: boolean;\n    switch: IgxSwitchComponent;\n}\n\nconst noop = () => { };\nlet nextId = 0;\n/**\n * **Ignite UI for Angular Switch** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/switch.html)\n *\n * The Ignite UI Switch lets the user toggle between on/off or true/false states.\n *\n * Example:\n * ```html\n * <igx-switch [checked]=\"true\">\n *   Simple switch\n * </igx-switch>\n * ```\n */\n@Component({\n    providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxSwitchComponent, multi: true }],\n    selector: 'igx-switch',\n    templateUrl: 'switch.component.html'\n})\nexport class IgxSwitchComponent 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.switch.nativeCheckbox;\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.switch.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.switch.placeholderLabel;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @ViewChild('placeholderLabel', { static: true }) public placeholderLabel;\n\n    /**\n     * Sets/gets the `id` of the switch component.\n     * If not set, the `id` of the first switch component will be `\"igx-switch-0\"`.\n     * ```html\n     * <igx-switch id=\"my-first-switch\"></igx-switch>\n     * ```\n     * ```typescript\n     * let switchId =  this.switch.id;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @HostBinding('attr.id')\n    @Input() public id = `igx-switch-${nextId++}`;\n    /**\n     * Sets/gets the id of the `label` element in the switch component.\n     * If not set, the label of the first switch component will have value `\"igx-switch-0-label\"`.\n     * ```html\n     * <igx-switch labelId=\"Label1\"></igx-switch>\n     * ```\n     * ```typescript\n     * let labelId =  this.switch.labelId;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public labelId = `${this.id}-label`;\n    /**\n     * Sets/gets the `value` attribute of the switch component.\n     * ```html\n     * <igx-switch [value] = \"switchValue\"></igx-switch>\n     * ```\n     * ```typescript\n     * let value =  this.switch.value;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public value: any;\n    /**\n     * Sets/gets the `name` attribute of the switch component.\n     * ```html\n     * <igx-switch name = \"Switch1\"></igx-switch>\n     * ```\n     * ```typescript\n     * let name =  this.switch.name;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public name: string;\n    /**\n     * Sets/gets the value of the `tabindex` attribute.\n     * ```html\n     * <igx-switch [tabindex]=\"1\"></igx-switch>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.switch.tabindex;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public tabindex: number = null;\n    /**\n     * Sets/gets the position of the `label` in the switch component.\n     * If not set, `labelPosition` will have value `\"after\"`.\n     * ```html\n     * <igx-switch labelPosition=\"before\"></igx-switch>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.switch.labelPosition;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public labelPosition: SwitchLabelPosition | string = 'after';\n    /**\n     * Enables/Disables the ripple effect\n     * If not set, `disableRipple` will have value `false`.\n     * ```html\n     * <igx-switch [disableRipple]=\"true\"></igx-switch>\n     * ```\n     * ```typescript\n     * let isRippleDisabled = this.switch.disableRipple;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public disableRipple = false;\n    /**\n     * Sets/gets whether switch is required.\n     * If not set, `required` will have value `false`.\n     * ```html\n     * <igx-switch [required]=\"true\"></igx-switch>\n     * ```\n     * ```typescript\n     * let isRequired = this.switch.required;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input() public required = false;\n    /**\n     * Sets/gets the `aria-labelledBy` attribute.\n     * If not set, the  value of `aria-labelledBy` will be equal to the value of `labelId` attribute.\n     * ```html\n     * <igx-switch aria-labelledby = \"Label1\"></igx-switch>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.switch.ariaLabelledBy;\n     * ```\n     * @memberof IgxSwitchComponent\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-switch aria-label=\"Label1\"></igx-switch>\n     * ```\n     * ```typescript\n     * let ariaLabel =  this.switch.ariaLabel;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n    /**\n     * An event that is emitted after the switch state is changed.\n     * Provides references to the `IgxSwitchComponent` and the `checked` property as event arguments.\n     * @memberof IgxSwitchComponent\n     */\n    @Output()\n    readonly change: EventEmitter<IChangeSwitchEventArgs> = new EventEmitter<IChangeSwitchEventArgs>();\n    /**\n     *@hidden\n     * @memberof IgxSwitchComponent\n     */\n    private _onTouchedCallback: () => void = noop;\n    /**\n     *@hidden\n     * @memberof IgxSwitchComponent\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n    /**\n     * Returns the class of the switch component.\n     * ```typescript\n     * let switchClass = this.switch.cssClass;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @HostBinding('class.igx-switch')\n    public cssClass = 'igx-switch';\n    /**\n     * Sets/gets whether the switch is on or off.\n     * Default value is 'false'.\n     * ```html\n     *  <igx-switch [checked] = \"true\"></igx-switch>\n     * ```\n     * ```typescript\n     * let isChecked =  this.switch.checked;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @HostBinding('class.igx-switch--checked')\n    @Input() public checked = false;\n    /**\n     * Sets/gets the `disabled` attribute.\n     * Default value is `false`.\n     * ```html\n     * <igx-switch [disabled] = \"true\"><igx-switch>\n     * ```\n     * ```typescript\n     * let isDisabled =  this.switch.disabled;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @HostBinding('class.igx-switch--disabled')\n    @Input() public disabled = false;\n    /**\n     * Sets/gets whether the switch component is on focus.\n     * Default value is `false`.\n     * ```typescript\n     * this.switch.focused = true;\n     * ```\n     * ```typescript\n     * let isFocused =  this.switch.focused;\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    @HostBinding('class.igx-switch--focused')\n    public focused = false;\n    /**\n     *@hidden\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     * Toggles the checked state of the switch.\n     * ```typescript\n     * this.switch.toggle();\n     * ```\n     * @memberof IgxSwitchComponent\n     */\n    public toggle() {\n        if (this.disabled) {\n            return;\n        }\n\n        this.checked = !this.checked;\n        this.focused = false;\n        this.change.emit({ checked: this.checked, switch: this });\n        this._onChangeCallback(this.checked);\n    }\n    /**\n     *@hidden\n     */\n    public _onSwitchChange(event) {\n        event.stopPropagation();\n    }\n    /**\n     *@hidden\n     */\n    public _onSwitchClick(event) {\n        event.stopPropagation();\n        this.toggle();\n\n        if (isIE()) {\n            this.nativeCheckbox.nativeElement.blur();\n        }\n    }\n    /**\n     *@hidden\n     */\n    public _onLabelClick(event) {\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    /** @hidden */\n    getEditElement() {\n        return this.nativeCheckbox.nativeElement;\n    }\n\n    /**\n     *@hidden\n     */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case SwitchLabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case SwitchLabelPosition.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\nexport const IGX_SWITCH_REQUIRED_VALIDATOR: Provider = {\n    provide: NG_VALIDATORS,\n    useExisting: forwardRef(() => IgxSwitchRequiredDirective),\n    multi: true\n};\n\n/* tslint:disable directive-selector */\n@Directive({\n    selector: `igx-switch[required][formControlName],\n    igx-switch[required][formControl],\n    igx-switch[required][ngModel]`,\n    providers: [IGX_SWITCH_REQUIRED_VALIDATOR]\n})\nexport class IgxSwitchRequiredDirective extends CheckboxRequiredValidator { }\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxSwitchComponent, IgxSwitchRequiredDirective],\n    exports: [IgxSwitchComponent, IgxSwitchRequiredDirective],\n    imports: [IgxRippleModule]\n})\nexport class IgxSwitchModule { }\n"]}