@leoborel/ngx-ui-switch
Version:
switch button for angular4
188 lines • 25.2 kB
JavaScript
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"]}