UNPKG

ng-toggle-button

Version:
304 lines 41.4 kB
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>"]}