UNPKG

@leoborel/ngx-ui-switch

Version:
188 lines 25.2 kB
import { Component, Input, Output, EventEmitter, HostListener, forwardRef, Inject, Optional, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { UI_SWITCH_OPTIONS } from './ui-switch.token'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; const UI_SWITCH_CONTROL_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => UiSwitchComponent), multi: true, }; export class UiSwitchComponent { constructor(config = {}, cdr) { this.cdr = cdr; /** * Emits changed value */ // eslint-disable-next-line @angular-eslint/no-output-native this.change = new EventEmitter(); /** * Emits DOM event */ this.changeEvent = new EventEmitter(); /** * Emits changed value */ this.valueChange = new EventEmitter(); this.onTouchedCallback = (v) => { }; this.onChangeCallback = (v) => { }; this.size = (config && config.size) || 'medium'; this.color = config && config.color; this.switchOffColor = config && config.switchOffColor; this.switchColor = config && config.switchColor; this.defaultBgColor = config && config.defaultBgColor; this.defaultBoColor = config && config.defaultBoColor; this.checkedLabel = config && config.checkedLabel; this.uncheckedLabel = config && config.uncheckedLabel; this.checkedTextColor = config && config.checkedTextColor; this.uncheckedTextColor = config && config.uncheckedTextColor; } set checked(v) { this._checked = v !== false; } get checked() { return this._checked; } set disabled(v) { this._disabled = v !== false; } get disabled() { return this._disabled; } set reverse(v) { this._reverse = v !== false; } get reverse() { return this._reverse; } set loading(v) { this._loading = v !== false; } get loading() { return this._loading; } getColor(flag = '') { if (flag === 'borderColor') { return this.defaultBoColor; } if (flag === 'switchColor') { if (this.reverse) { return !this.checked ? this.switchColor : this.switchOffColor || this.switchColor; } return this.checked ? this.switchColor : this.switchOffColor || this.switchColor; } if (flag === 'checkedTextColor') { return this.reverse ? this.uncheckedTextColor : this.checkedTextColor; } if (flag === 'uncheckedTextColor') { return this.reverse ? this.checkedTextColor : this.uncheckedTextColor; } if (this.reverse) { return !this.checked ? this.color : this.defaultBgColor; } return this.checked ? this.color : this.defaultBgColor; } onClick(event) { if (this.disabled) { return; } this.checked = !this.checked; // Component events this.change.emit(this.checked); this.valueChange.emit(this.checked); this.changeEvent.emit(event); // value accessor callbacks this.onChangeCallback(this.checked); this.onTouchedCallback(this.checked); this.cdr.markForCheck(); } onToggle(event) { if (this.disabled) { return; } if (this.beforeChange) { this._beforeChange = this.beforeChange.subscribe((confirm) => { if (confirm) { this.onClick(event); } }); } else { this.onClick(event); } } writeValue(obj) { if (obj !== this.checked) { this.checked = !!obj; } this.onChangeCallback(this.checked); if (this.cdr) { this.cdr.markForCheck(); } } registerOnChange(fn) { this.onChangeCallback = fn; } registerOnTouched(fn) { this.onTouchedCallback = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } ngOnDestroy() { if (this._beforeChange) { this._beforeChange.unsubscribe(); } } } UiSwitchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: UiSwitchComponent, deps: [{ token: UI_SWITCH_OPTIONS, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); UiSwitchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: UiSwitchComponent, selector: "ui-switch", inputs: { size: "size", color: "color", switchOffColor: "switchOffColor", switchColor: "switchColor", defaultBgColor: "defaultBgColor", defaultBoColor: "defaultBoColor", checkedLabel: "checkedLabel", uncheckedLabel: "uncheckedLabel", checkedTextColor: "checkedTextColor", uncheckedTextColor: "uncheckedTextColor", beforeChange: "beforeChange", checked: "checked", disabled: "disabled", reverse: "reverse", loading: "loading" }, outputs: { change: "change", changeEvent: "changeEvent", valueChange: "valueChange" }, host: { listeners: { "click": "onToggle($event)" } }, providers: [UI_SWITCH_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: "<button\r\n type=\"button\"\r\n class=\"switch\"\r\n role=\"switch\"\r\n [attr.aria-checked]=\"checked\"\r\n [class.checked]=\"checked\"\r\n [class.disabled]=\"disabled\"\r\n [class.loading]=\"loading\"\r\n [class.switch-large]=\"size === 'large'\"\r\n [class.switch-medium]=\"size === 'medium'\"\r\n [class.switch-small]=\"size === 'small'\"\r\n [style.background-color]=\"getColor()\"\r\n [style.border-color]=\"getColor('borderColor')\"\r\n>\r\n <label class=\"switch-pane\" *ngIf=\"checkedLabel || uncheckedLabel\">\r\n <span\r\n [attr.aria-label]=\"this.checkedLabel\"\r\n class=\"switch-label-checked\"\r\n [style.color]=\"getColor('checkedTextColor')\"\r\n >{{ this.checkedLabel }}</span\r\n >\r\n <span\r\n [attr.aria-label]=\"this.uncheckedLabel\"\r\n class=\"switch-label-unchecked\"\r\n [style.color]=\"getColor('uncheckedTextColor')\"\r\n >{{ this.uncheckedLabel }}</span\r\n >\r\n </label>\r\n <small [style.background]=\"getColor('switchColor')\">\r\n <ng-content></ng-content>\r\n </small>\r\n</button>\r\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: UiSwitchComponent, decorators: [{ type: Component, args: [{ selector: 'ui-switch', providers: [UI_SWITCH_CONTROL_VALUE_ACCESSOR], template: "<button\r\n type=\"button\"\r\n class=\"switch\"\r\n role=\"switch\"\r\n [attr.aria-checked]=\"checked\"\r\n [class.checked]=\"checked\"\r\n [class.disabled]=\"disabled\"\r\n [class.loading]=\"loading\"\r\n [class.switch-large]=\"size === 'large'\"\r\n [class.switch-medium]=\"size === 'medium'\"\r\n [class.switch-small]=\"size === 'small'\"\r\n [style.background-color]=\"getColor()\"\r\n [style.border-color]=\"getColor('borderColor')\"\r\n>\r\n <label class=\"switch-pane\" *ngIf=\"checkedLabel || uncheckedLabel\">\r\n <span\r\n [attr.aria-label]=\"this.checkedLabel\"\r\n class=\"switch-label-checked\"\r\n [style.color]=\"getColor('checkedTextColor')\"\r\n >{{ this.checkedLabel }}</span\r\n >\r\n <span\r\n [attr.aria-label]=\"this.uncheckedLabel\"\r\n class=\"switch-label-unchecked\"\r\n [style.color]=\"getColor('uncheckedTextColor')\"\r\n >{{ this.uncheckedLabel }}</span\r\n >\r\n </label>\r\n <small [style.background]=\"getColor('switchColor')\">\r\n <ng-content></ng-content>\r\n </small>\r\n</button>\r\n" }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [UI_SWITCH_OPTIONS] }, { type: Optional }] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { size: [{ type: Input }], color: [{ type: Input }], switchOffColor: [{ type: Input }], switchColor: [{ type: Input }], defaultBgColor: [{ type: Input }], defaultBoColor: [{ type: Input }], checkedLabel: [{ type: Input }], uncheckedLabel: [{ type: Input }], checkedTextColor: [{ type: Input }], uncheckedTextColor: [{ type: Input }], beforeChange: [{ type: Input }], checked: [{ type: Input }], disabled: [{ type: Input }], reverse: [{ type: Input }], loading: [{ type: Input }], change: [{ type: Output }], changeEvent: [{ type: Output }], valueChange: [{ type: Output }], onToggle: [{ type: HostListener, args: ['click', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-switch.component.js","sourceRoot":"","sources":["../../../../src/lib/ui-switch/ui-switch.component.ts","../../../../src/lib/ui-switch/ui-switch.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  HostListener,\r\n  forwardRef,\r\n  Inject,\r\n  Optional,\r\n  OnDestroy,\r\n} from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\nimport { UI_SWITCH_OPTIONS } from './ui-switch.token';\r\nimport { UiSwitchModuleConfig } from './ui-switch.config';\r\nimport { Observable, Subscription } from 'rxjs';\r\n\r\nconst UI_SWITCH_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => UiSwitchComponent),\r\n  multi: true,\r\n};\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'ui-switch',\r\n  templateUrl: 'ui-switch.component.html',\r\n  providers: [UI_SWITCH_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class UiSwitchComponent implements ControlValueAccessor, OnDestroy {\r\n  private _checked: boolean;\r\n  private _disabled: boolean;\r\n  private _reverse: boolean;\r\n  private _loading: boolean;\r\n  private _beforeChange: Subscription;\r\n\r\n  @Input() size;\r\n  @Input() color;\r\n  @Input() switchOffColor;\r\n  @Input() switchColor;\r\n  @Input() defaultBgColor;\r\n  @Input() defaultBoColor;\r\n  @Input() checkedLabel;\r\n  @Input() uncheckedLabel;\r\n  @Input() checkedTextColor;\r\n  @Input() uncheckedTextColor;\r\n  @Input() beforeChange: Observable<boolean>;\r\n\r\n  @Input()\r\n  set checked(v: boolean) {\r\n    this._checked = v !== false;\r\n  }\r\n\r\n  get checked() {\r\n    return this._checked;\r\n  }\r\n\r\n  @Input()\r\n  set disabled(v: boolean) {\r\n    this._disabled = v !== false;\r\n  }\r\n\r\n  get disabled() {\r\n    return this._disabled;\r\n  }\r\n\r\n  @Input()\r\n  set reverse(v: boolean) {\r\n    this._reverse = v !== false;\r\n  }\r\n\r\n  get reverse() {\r\n    return this._reverse;\r\n  }\r\n\r\n  @Input()\r\n  set loading(v: boolean) {\r\n    this._loading = v !== false;\r\n  }\r\n\r\n  get loading() {\r\n    return this._loading;\r\n  }\r\n\r\n  /**\r\n   * Emits changed value\r\n   */\r\n  // eslint-disable-next-line @angular-eslint/no-output-native\r\n  @Output() change = new EventEmitter<boolean>();\r\n\r\n  /**\r\n   * Emits DOM event\r\n   */\r\n  @Output() changeEvent = new EventEmitter<MouseEvent>();\r\n\r\n  /**\r\n   * Emits changed value\r\n   */\r\n  @Output() valueChange = new EventEmitter<boolean>();\r\n\r\n  constructor(\r\n    @Inject(UI_SWITCH_OPTIONS) @Optional() config: UiSwitchModuleConfig = {},\r\n    private cdr: ChangeDetectorRef\r\n  ) {\r\n    this.size = (config && config.size) || 'medium';\r\n    this.color = config && config.color;\r\n    this.switchOffColor = config && config.switchOffColor;\r\n    this.switchColor = config && config.switchColor;\r\n    this.defaultBgColor = config && config.defaultBgColor;\r\n    this.defaultBoColor = config && config.defaultBoColor;\r\n    this.checkedLabel = config && config.checkedLabel;\r\n    this.uncheckedLabel = config && config.uncheckedLabel;\r\n    this.checkedTextColor = config && config.checkedTextColor;\r\n    this.uncheckedTextColor = config && config.uncheckedTextColor;\r\n  }\r\n\r\n  getColor(flag = '') {\r\n    if (flag === 'borderColor') {\r\n      return this.defaultBoColor;\r\n    }\r\n    if (flag === 'switchColor') {\r\n      if (this.reverse) {\r\n        return !this.checked ? this.switchColor : this.switchOffColor || this.switchColor;\r\n      }\r\n      return this.checked ? this.switchColor : this.switchOffColor || this.switchColor;\r\n    }\r\n    if (flag === 'checkedTextColor') {\r\n      return this.reverse ? this.uncheckedTextColor : this.checkedTextColor;\r\n    }\r\n    if (flag === 'uncheckedTextColor') {\r\n      return this.reverse ? this.checkedTextColor : this.uncheckedTextColor;\r\n    }\r\n    if (this.reverse) {\r\n      return !this.checked ? this.color : this.defaultBgColor;\r\n    }\r\n    return this.checked ? this.color : this.defaultBgColor;\r\n  }\r\n\r\n  onClick(event: MouseEvent) {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n    this.checked = !this.checked;\r\n\r\n    // Component events\r\n    this.change.emit(this.checked);\r\n    this.valueChange.emit(this.checked);\r\n    this.changeEvent.emit(event);\r\n\r\n    // value accessor callbacks\r\n    this.onChangeCallback(this.checked);\r\n    this.onTouchedCallback(this.checked);\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  onToggle(event: MouseEvent) {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n    if (this.beforeChange) {\r\n      this._beforeChange = this.beforeChange.subscribe((confirm: boolean) => {\r\n        if (confirm) {\r\n          this.onClick(event);\r\n        }\r\n      });\r\n    } else {\r\n      this.onClick(event);\r\n    }\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    if (obj !== this.checked) {\r\n      this.checked = !!obj;\r\n    }\r\n\r\n    this.onChangeCallback(this.checked);\r\n    if (this.cdr) {\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any) {\r\n    this.onChangeCallback = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  private onTouchedCallback = (v: any) => {};\r\n  private onChangeCallback = (v: any) => {};\r\n\r\n  ngOnDestroy() {\r\n    if (this._beforeChange) {\r\n      this._beforeChange.unsubscribe();\r\n    }\r\n  }\r\n}\r\n","<button\r\n  type=\"button\"\r\n  class=\"switch\"\r\n  role=\"switch\"\r\n  [attr.aria-checked]=\"checked\"\r\n  [class.checked]=\"checked\"\r\n  [class.disabled]=\"disabled\"\r\n  [class.loading]=\"loading\"\r\n  [class.switch-large]=\"size === 'large'\"\r\n  [class.switch-medium]=\"size === 'medium'\"\r\n  [class.switch-small]=\"size === 'small'\"\r\n  [style.background-color]=\"getColor()\"\r\n  [style.border-color]=\"getColor('borderColor')\"\r\n>\r\n  <label class=\"switch-pane\" *ngIf=\"checkedLabel || uncheckedLabel\">\r\n    <span\r\n      [attr.aria-label]=\"this.checkedLabel\"\r\n      class=\"switch-label-checked\"\r\n      [style.color]=\"getColor('checkedTextColor')\"\r\n      >{{ this.checkedLabel }}</span\r\n    >\r\n    <span\r\n      [attr.aria-label]=\"this.uncheckedLabel\"\r\n      class=\"switch-label-unchecked\"\r\n      [style.color]=\"getColor('uncheckedTextColor')\"\r\n      >{{ this.uncheckedLabel }}</span\r\n    >\r\n  </label>\r\n  <small [style.background]=\"getColor('switchColor')\">\r\n    <ng-content></ng-content>\r\n  </small>\r\n</button>\r\n"]}