ng-toggle-button
Version:
Angular toggle button switch
304 lines • 41.4 kB
JavaScript
import { Component, Input, forwardRef, Output, EventEmitter } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { CommonModule } from '@angular/common';
import * as i0 from "@angular/core";
import * as i1 from "./ng-toggle.config";
import * as i2 from "@angular/common";
const DEFAULT_COLOR_CHECKED = '#0099CC';
const DEFAULT_COLOR_UNCHECKED = '#e0e0e0';
const DEFAULT_LABEL_CHECKED = '';
const DEFAULT_LABEL_UNCHECKED = '';
const DEFAULT_SWITCH_COLOR = '#fff';
const DISABLED_COLOR = '#dbdbdb';
const DISABLED_BUTTON_COLOR = 'silver';
let nextUniqueId = 0;
export class NgToggleComponent {
constructor(config, _elementRef) {
this.config = config;
this._elementRef = _elementRef;
this.value = this.config.value || true;
this.name = this.config.name || '';
this.disabled = this.config.disabled || false;
this.height = this.config.height || 25;
this.width = this.config.width || 45;
this.margin = this.config.margin || 2;
this.fontSize = this.config.fontSize || undefined;
this.speed = this.config.speed || 300;
this.color = this.config.color;
this.switchColor = this.config.switchColor;
this.labels = this.config.labels || true;
this.fontColor = this.config.fontColor || undefined;
this.values = this.config.values || { checked: true, unchecked: false };
this.textAlign = this.config.textAlign || {
checked: 'left',
unchecked: 'right',
};
this.id = '';
this.ariaLabel = null;
this.ariaLabelledby = null;
this.cssColors = false;
this.change = new EventEmitter();
this.valueChange = new EventEmitter();
this.onChange = (_) => { };
this.onTouch = () => { };
this._uniqueId = 'ng-toggle-' + (++nextUniqueId);
this.id = this.id || this._uniqueId;
this.ariaLabel = this.ariaLabel || this.name || this.id;
}
ngOnInit() {
this.setToogle();
}
onInput(value) {
this.value = value;
this.onTouch();
this.onChange(this.value);
}
writeValue(value) {
this.value = value;
this.setToogle();
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouch = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
setToogle() {
const value = this.value;
let index = Object.values(this.values).findIndex(el => el == value);
if (index > -1)
this.toggled = Object.keys(this.values)[index] == 'checked' ? true : false;
}
ngOnChanges(changes) {
for (const propName in changes) {
const chng = changes[propName];
if (propName == 'value')
this.writeValue(chng.currentValue);
}
}
get coreStyle() {
return {
width: px(this.width),
height: px(this.height),
transition: `all ${this.speed}ms`,
backgroundColor: this.cssColors
? null
: (this.disabled ? this.colorDisabled : this.colorCurrent),
borderRadius: px(Math.round(this.height / 2))
};
}
get buttonRadius() {
const radius = this.height - this.margin * 2;
return radius > 0 ? radius : 0;
}
get distance() {
return px(this.width - this.height + this.margin);
}
get buttonStyle() {
const transition = `all ${this.speed}ms`;
const margin = px(this.margin);
const transform = this.toggled
? translate(this.distance, margin)
: translate(margin, margin);
let background = this.switchColor
? this.switchColorCurrent
: null;
background = this.disabled ? this.switchColorDisabled : background;
return {
width: px(this.buttonRadius),
height: px(this.buttonRadius),
transition,
transform,
background,
};
}
get labelStyle() {
return {
lineHeight: px(this.height),
fontSize: this.fontSize ? px(this.fontSize) : null,
color: this.fontColor ? this.fontColorCurrent : null,
width: px(this.width - this.buttonRadius - this.margin),
};
}
get labelLeftStyle() {
return {
...this.labelStyle,
textAlign: this.textAlign.checked || this.textAlign
};
}
get labelRightStyle() {
return {
...this.labelStyle,
textAlign: this.textAlign.unchecked || this.textAlign
};
}
get colorChecked() {
let { color } = this;
if (!isObject(color)) {
return color || DEFAULT_COLOR_CHECKED;
}
return get(color, 'checked', DEFAULT_COLOR_CHECKED);
}
get colorUnchecked() {
return get(this.color, 'unchecked', DEFAULT_COLOR_UNCHECKED);
}
get colorDisabled() {
return get(this.color, 'disabled', DISABLED_COLOR);
}
get colorCurrent() {
return this.toggled
? this.colorChecked
: this.colorUnchecked;
}
get labelChecked() {
return get(this.labels, 'checked', DEFAULT_LABEL_CHECKED);
}
get labelUnchecked() {
return get(this.labels, 'unchecked', DEFAULT_LABEL_UNCHECKED);
}
get switchColorChecked() {
return get(this.switchColor, 'checked', DEFAULT_SWITCH_COLOR);
}
get switchColorUnchecked() {
return get(this.switchColor, 'unchecked', DEFAULT_SWITCH_COLOR);
}
get switchColorDisabled() {
return get(this.switchColor, 'disabled', DISABLED_BUTTON_COLOR);
}
get switchColorCurrent() {
if (!isObject(this.switchColor)) {
return this.switchColor || DEFAULT_SWITCH_COLOR;
}
return this.toggled
? this.switchColorChecked
: this.switchColorUnchecked;
}
get fontColorChecked() {
return get(this.fontColor, 'checked', DEFAULT_SWITCH_COLOR);
}
get fontColorUnchecked() {
return get(this.fontColor, 'unchecked', DEFAULT_SWITCH_COLOR);
}
get fontColorDisabled() {
return get(this.fontColor, 'disabled', DEFAULT_SWITCH_COLOR);
}
get fontColorCurrent() {
if (!isObject(this.fontColor)) {
return this.fontColor || DEFAULT_SWITCH_COLOR;
}
if (this.disabled) {
return this.fontColorDisabled;
}
return this.toggled
? this.fontColorChecked
: this.fontColorUnchecked;
}
get label() {
if (this.ariaLabelledby) {
return this.ariaLabelledby;
}
return this.ariaLabel ? null : `${this._uniqueId}-label`;
}
toggle(event) {
const toggled = !this.toggled;
this.toggled = toggled;
this.value = this.getValue(toggled);
this.onTouch();
this.onChange(this.value);
this.valueChange.emit(this.value);
}
getValue(key) {
return key === true ? this.values['checked'] : this.values['unchecked'];
}
onFocus(event) {
if (!this.focused && event.relatedTarget) {
this.focused = true;
}
}
onFocusout(event) {
if (!this._elementRef.nativeElement.contains(event.relatedTarget)) {
this.focused = false;
this.onTouch();
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgToggleComponent, deps: [{ token: i1.NgToggleConfig }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NgToggleComponent, isStandalone: true, selector: "ng-toggle", inputs: { value: "value", name: "name", disabled: "disabled", height: "height", width: "width", margin: "margin", fontSize: "fontSize", speed: "speed", color: "color", switchColor: "switchColor", labels: "labels", fontColor: "fontColor", values: "values", textAlign: "textAlign", id: "id", ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"], ariaDescribedby: ["aria-describedby", "ariaDescribedby"] }, outputs: { change: "change", valueChange: "valueChange" }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => NgToggleComponent),
multi: true
}
], usesOnChanges: true, ngImport: i0, template: "<label class=\"ng-toggle-switch\" [for]=\"id\" [attr.id]=\"label\">\n <input\n type=\"checkbox\"\n class=\"ng-toggle-switch-input\"\n [checked]=\"value\"\n [disabled]=\"disabled\"\n (change)=\"toggle($event)\"\n (focusin)=\"onFocus($event)\"\n (focusout)=\"onFocusout($event)\"\n [attr.id]=\"id\"\n [attr.name]=\"name\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"label\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n [attr.aria-checked]=\"toggled\"\n role=\"checkbox\"\n >\n <div\n class=\"ng-toggle-switch-core\"\n [ngClass]=\"{'ng-toggle-focused': focused}\"\n [ngStyle]=\"coreStyle\"\n >\n <div\n class=\"ng-toggle-switch-button\"\n [ngStyle]=\"buttonStyle\">\n </div>\n </div>\n <ng-container *ngIf=\"labels\">\n <span\n class=\"ng-toggle-switch-label ng-toggle-left\"\n [ngStyle]=\"labelLeftStyle\"\n *ngIf=\"toggled\"\n >\n {{labelChecked}}\n </span>\n <span\n class=\"ng-toggle-switch-label ng-toggle-right\"\n [ngStyle]=\"labelRightStyle\"\n *ngIf=\"!toggled\"\n >\n {{labelUnchecked}}\n </span>\n </ng-container>\n</label>", styles: ["label{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}.ng-toggle-switch{display:inline-block;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none;font-size:10px;cursor:pointer}.ng-toggle-switch .ng-toggle-switch-input{opacity:0;position:absolute;width:1px;height:1px}.ng-toggle-switch .ng-toggle-switch-label{position:absolute;top:0;font-weight:600;color:#fff;z-index:1;padding:0 10px;box-sizing:border-box}.ng-toggle-switch .ng-toggle-switch-label.ng-toggle-left{left:0}.ng-toggle-switch .ng-toggle-switch-label.ng-toggle-right{right:0}.ng-toggle-switch .ng-toggle-switch-core{display:block;position:relative;box-sizing:border-box;outline:0;margin:0;transition:border-color .3s,background-color .3s;-webkit-user-select:none;user-select:none}.ng-toggle-switch .ng-toggle-switch-core .ng-toggle-switch-button{display:block;position:absolute;overflow:hidden;top:0;left:0;border-radius:100%;background-color:#fff;z-index:2}.ng-toggle-switch.disabled{pointer-events:none;opacity:.6}.ng-toggle-focused{box-shadow:0 0 4px 3px #999}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NgToggleComponent, decorators: [{
type: Component,
args: [{ selector: 'ng-toggle', standalone: true, imports: [CommonModule], providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => NgToggleComponent),
multi: true
}
], template: "<label class=\"ng-toggle-switch\" [for]=\"id\" [attr.id]=\"label\">\n <input\n type=\"checkbox\"\n class=\"ng-toggle-switch-input\"\n [checked]=\"value\"\n [disabled]=\"disabled\"\n (change)=\"toggle($event)\"\n (focusin)=\"onFocus($event)\"\n (focusout)=\"onFocusout($event)\"\n [attr.id]=\"id\"\n [attr.name]=\"name\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"label\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n [attr.aria-checked]=\"toggled\"\n role=\"checkbox\"\n >\n <div\n class=\"ng-toggle-switch-core\"\n [ngClass]=\"{'ng-toggle-focused': focused}\"\n [ngStyle]=\"coreStyle\"\n >\n <div\n class=\"ng-toggle-switch-button\"\n [ngStyle]=\"buttonStyle\">\n </div>\n </div>\n <ng-container *ngIf=\"labels\">\n <span\n class=\"ng-toggle-switch-label ng-toggle-left\"\n [ngStyle]=\"labelLeftStyle\"\n *ngIf=\"toggled\"\n >\n {{labelChecked}}\n </span>\n <span\n class=\"ng-toggle-switch-label ng-toggle-right\"\n [ngStyle]=\"labelRightStyle\"\n *ngIf=\"!toggled\"\n >\n {{labelUnchecked}}\n </span>\n </ng-container>\n</label>", styles: ["label{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}.ng-toggle-switch{display:inline-block;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none;font-size:10px;cursor:pointer}.ng-toggle-switch .ng-toggle-switch-input{opacity:0;position:absolute;width:1px;height:1px}.ng-toggle-switch .ng-toggle-switch-label{position:absolute;top:0;font-weight:600;color:#fff;z-index:1;padding:0 10px;box-sizing:border-box}.ng-toggle-switch .ng-toggle-switch-label.ng-toggle-left{left:0}.ng-toggle-switch .ng-toggle-switch-label.ng-toggle-right{right:0}.ng-toggle-switch .ng-toggle-switch-core{display:block;position:relative;box-sizing:border-box;outline:0;margin:0;transition:border-color .3s,background-color .3s;-webkit-user-select:none;user-select:none}.ng-toggle-switch .ng-toggle-switch-core .ng-toggle-switch-button{display:block;position:absolute;overflow:hidden;top:0;left:0;border-radius:100%;background-color:#fff;z-index:2}.ng-toggle-switch.disabled{pointer-events:none;opacity:.6}.ng-toggle-focused{box-shadow:0 0 4px 3px #999}\n"] }]
}], ctorParameters: () => [{ type: i1.NgToggleConfig }, { type: i0.ElementRef }], propDecorators: { value: [{
type: Input
}], name: [{
type: Input
}], disabled: [{
type: Input
}], height: [{
type: Input
}], width: [{
type: Input
}], margin: [{
type: Input
}], fontSize: [{
type: Input
}], speed: [{
type: Input
}], color: [{
type: Input
}], switchColor: [{
type: Input
}], labels: [{
type: Input
}], fontColor: [{
type: Input
}], values: [{
type: Input
}], textAlign: [{
type: Input
}], id: [{
type: Input
}], ariaLabel: [{
type: Input,
args: ['aria-label']
}], ariaLabelledby: [{
type: Input,
args: ['aria-labelledby']
}], ariaDescribedby: [{
type: Input,
args: ['aria-describedby']
}], change: [{
type: Output
}], valueChange: [{
type: Output
}] } });
export const isObject = (value) => {
return typeof value === 'object';
};
export const has = (object, key) => {
return isObject(object) && object.hasOwnProperty(key);
};
export const get = (object, key, defaultValue) => {
return has(object, key) ? object[key] : defaultValue;
};
export const px = value => {
return `${value}px`;
};
export const translate = (x, y) => {
return `translate(${x}, ${y})`;
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-toggle.component.js","sourceRoot":"","sources":["../../../../projects/ng-toggle/src/lib/ng-toggle.component.ts","../../../../projects/ng-toggle/src/lib/ng-toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, Output, EventEmitter, OnChanges, SimpleChanges, ElementRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgToggleConfig } from './ng-toggle.config';\nimport { CommonModule } from '@angular/common';\n\nconst DEFAULT_COLOR_CHECKED = '#0099CC'\nconst DEFAULT_COLOR_UNCHECKED = '#e0e0e0'\nconst DEFAULT_LABEL_CHECKED = ''\nconst DEFAULT_LABEL_UNCHECKED = ''\nconst DEFAULT_SWITCH_COLOR = '#fff'\nconst DISABLED_COLOR = '#dbdbdb'\nconst DISABLED_BUTTON_COLOR = 'silver'\nlet nextUniqueId = 0;\n\n@Component({\n  selector: 'ng-toggle',\n  standalone: true,\n  imports: [CommonModule],\n  templateUrl: './ng-toggle.component.html',\n  styleUrls: ['./ng-toggle.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NgToggleComponent),\n      multi: true\n    }\n  ]\n})\nexport class NgToggleComponent implements OnInit, ControlValueAccessor, OnChanges {\n\n  @Input() value: any = this.config.value || true\n  @Input() name: string = this.config.name || ''\n  @Input() disabled: boolean = this.config.disabled || false\n\n  @Input() height: number = this.config.height || 25\n  @Input() width: number = this.config.width || 45\n  @Input() margin: number = this.config.margin || 2\n  @Input() fontSize: number = this.config.fontSize || undefined\n  @Input() speed: number = this.config.speed || 300\n  @Input() color: string | toggleConfig = this.config.color\n  @Input() switchColor: string | toggleConfig = this.config.switchColor\n  @Input() labels: boolean | toggleConfig = this.config.labels || true\n  @Input() fontColor: string | toggleConfig = this.config.fontColor || undefined\n  @Input() values: valueConfig = this.config.values || {checked: true, unchecked: false}\n  @Input() textAlign: string | toggleConfig = this.config.textAlign || {\n    checked: 'left',\n    unchecked: 'right',\n  }\n  @Input() id: string = ''\n  @Input('aria-label') ariaLabel: string | null = null;\n  @Input('aria-labelledby') ariaLabelledby: string | null = null;\n  @Input('aria-describedby') ariaDescribedby: string;\n  cssColors: boolean = false\n\n  @Output() change = new EventEmitter()\n  @Output() valueChange = new EventEmitter()\n  toggled: boolean\n  focused: boolean;\n  private _uniqueId: string;\n\n  constructor(\n    private config: NgToggleConfig,\n    private _elementRef: ElementRef<HTMLElement>,\n  ) {\n    this._uniqueId = 'ng-toggle-'+(++nextUniqueId);\n    this.id = this.id || this._uniqueId\n    this.ariaLabel = this.ariaLabel || this.name || this.id\n  }\n\n  ngOnInit() {\n    this.setToogle()\n  }\n\n  onChange = (_:any) => { }\n  onTouch = () => { }\n\n  onInput(value: boolean) {\n    this.value = value;\n    this.onTouch();\n    this.onChange(this.value);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.setToogle();\n  }\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  setToogle() {\n    const value = this.value\n    let index = Object.values(this.values).findIndex(el => el == value)\n    if(index > -1)\n      this.toggled = Object.keys(this.values)[index] == 'checked' ? true : false\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    for (const propName in changes) {\n      const chng = changes[propName];\n      if(propName == 'value')\n        this.writeValue(chng.currentValue)\n    }\n  }\n\n  get coreStyle () {\n    return {\n      width: px(this.width),\n      height: px(this.height),\n      transition: `all ${this.speed}ms`,\n      backgroundColor: this.cssColors\n        ? null\n        : (this.disabled ? this.colorDisabled : this.colorCurrent),\n      borderRadius: px(Math.round(this.height / 2))\n    }\n  }\n  get buttonRadius () {\n    const radius = this.height - this.margin * 2;\n    return radius > 0 ? radius : 0;\n  }\n  get distance () {\n    return px(this.width - this.height + this.margin)\n  }\n  get buttonStyle () {\n    const transition = `all ${this.speed}ms`\n    const margin = px(this.margin)\n    const transform = this.toggled\n      ? translate(this.distance, margin)\n      : translate(margin, margin)\n    let background = this.switchColor\n      ? this.switchColorCurrent\n      : null\n    background = this.disabled ? this.switchColorDisabled : background\n    return {\n      width: px(this.buttonRadius),\n      height: px(this.buttonRadius),\n      transition,\n      transform,\n      background,\n    }\n  }\n  get labelStyle () {\n    return {\n      lineHeight: px(this.height),\n      fontSize: this.fontSize ? px(this.fontSize) : null,\n      color: this.fontColor ? this.fontColorCurrent : null,\n      width: px(this.width - this.buttonRadius - this.margin),\n    }\n  }\n  get labelLeftStyle () {\n    return {\n      ...this.labelStyle,\n      textAlign: (this.textAlign as toggleConfig).checked || this.textAlign\n    }\n  }\n  get labelRightStyle () {\n    return {\n      ...this.labelStyle,\n      textAlign: (this.textAlign as toggleConfig).unchecked || this.textAlign\n    }\n  }\n\n  get colorChecked () {\n    let { color } = this\n    if (!isObject(color)) {\n      return color || DEFAULT_COLOR_CHECKED\n    }\n    return get(color, 'checked', DEFAULT_COLOR_CHECKED)\n  }\n  get colorUnchecked () {\n    return get(this.color, 'unchecked', DEFAULT_COLOR_UNCHECKED)\n  }\n  get colorDisabled () {\n    return get(this.color, 'disabled', DISABLED_COLOR)\n  }\n  get colorCurrent () {\n    return this.toggled\n      ? this.colorChecked\n      : this.colorUnchecked\n  }\n  get labelChecked () {\n    return get(this.labels, 'checked', DEFAULT_LABEL_CHECKED)\n  }\n  get labelUnchecked () {\n    return get(this.labels, 'unchecked', DEFAULT_LABEL_UNCHECKED)\n  }\n  get switchColorChecked () {\n    return get(this.switchColor, 'checked', DEFAULT_SWITCH_COLOR)\n  }\n  get switchColorUnchecked () {\n    return get(this.switchColor, 'unchecked', DEFAULT_SWITCH_COLOR)\n  }\n  get switchColorDisabled(){\n    return get(this.switchColor, 'disabled', DISABLED_BUTTON_COLOR)\n  }\n\n  get switchColorCurrent () {\n    if (!isObject(this.switchColor)) {\n      return this.switchColor || DEFAULT_SWITCH_COLOR\n    }\n    return this.toggled\n      ? this.switchColorChecked\n      : this.switchColorUnchecked\n  }\n\n  get fontColorChecked () {\n    return get(this.fontColor, 'checked', DEFAULT_SWITCH_COLOR)\n  }\n  get fontColorUnchecked () {\n    return get(this.fontColor, 'unchecked', DEFAULT_SWITCH_COLOR)\n  }\n\n  get fontColorDisabled(){\n    return get(this.fontColor, 'disabled', DEFAULT_SWITCH_COLOR)\n  }\n  get fontColorCurrent () {\n    if (!isObject(this.fontColor)) {\n      return this.fontColor || DEFAULT_SWITCH_COLOR\n    }\n    if(this.disabled){\n      return this.fontColorDisabled\n    }\n    return this.toggled\n      ? this.fontColorChecked\n      : this.fontColorUnchecked\n  }\n\n  get label() {\n    if (this.ariaLabelledby) {\n      return this.ariaLabelledby;\n    }\n    return this.ariaLabel ? null : `${this._uniqueId}-label`;\n  }\n\n  toggle(event) {\n    const toggled = !this.toggled;\n    this.toggled = toggled;\n\n    this.value = this.getValue(toggled)\n    this.onTouch();\n    this.onChange(this.value);\n    this.valueChange.emit(this.value)\n  }\n\n  getValue(key: boolean) {\n    return key === true ? this.values['checked'] : this.values['unchecked']\n  }\n\n  onFocus(event: FocusEvent) {\n    if (!this.focused && event.relatedTarget) {\n      this.focused = true;\n    }\n  }\n\n  onFocusout(event: FocusEvent) {\n    if (!this._elementRef.nativeElement.contains(event.relatedTarget as Element)) {\n      this.focused = false;\n      this.onTouch();\n    }\n  }\n}\n\nexport const isObject = (value) => {\n  return typeof value === 'object'\n}\n\nexport const has = (object, key) => {\n  return isObject(object) && object.hasOwnProperty(key)\n}\n\nexport const get = (object, key, defaultValue) => {\n  return has(object, key) ? object[key] : defaultValue\n}\n\nexport const px = value => {\n  return `${value}px`\n}\n\nexport const translate = (x, y) => {\n  return `translate(${x}, ${y})`\n}\n\nexport type toggleConfig = {\n  checked: string;\n  unchecked: string;\n  disabled?: string;\n};\n\nexport type valueConfig = {\n  checked: any;\n  unchecked: any;\n};\n","<label class=\"ng-toggle-switch\" [for]=\"id\" [attr.id]=\"label\">\n  <input\n    type=\"checkbox\"\n    class=\"ng-toggle-switch-input\"\n    [checked]=\"value\"\n    [disabled]=\"disabled\"\n    (change)=\"toggle($event)\"\n    (focusin)=\"onFocus($event)\"\n    (focusout)=\"onFocusout($event)\"\n    [attr.id]=\"id\"\n    [attr.name]=\"name\"\n    [attr.aria-label]=\"ariaLabel\"\n    [attr.aria-labelledby]=\"label\"\n    [attr.aria-describedby]=\"ariaDescribedby\"\n    [attr.aria-checked]=\"toggled\"\n    role=\"checkbox\"\n  >\n  <div\n    class=\"ng-toggle-switch-core\"\n    [ngClass]=\"{'ng-toggle-focused': focused}\"\n    [ngStyle]=\"coreStyle\"\n  >\n    <div\n      class=\"ng-toggle-switch-button\"\n      [ngStyle]=\"buttonStyle\">\n    </div>\n  </div>\n  <ng-container *ngIf=\"labels\">\n    <span\n      class=\"ng-toggle-switch-label ng-toggle-left\"\n      [ngStyle]=\"labelLeftStyle\"\n      *ngIf=\"toggled\"\n    >\n      {{labelChecked}}\n    </span>\n    <span\n      class=\"ng-toggle-switch-label ng-toggle-right\"\n      [ngStyle]=\"labelRightStyle\"\n      *ngIf=\"!toggled\"\n    >\n      {{labelUnchecked}}\n    </span>\n  </ng-container>\n</label>"]}