UNPKG

@junte/ui

Version:

Quality Angular UI components kit

136 lines 13.3 kB
var SliderComponent_1; import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, Component, forwardRef, HostBinding, HostListener, Input } from '@angular/core'; import { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms'; import { NGXLogger } from 'ngx-logger'; import { map } from 'rxjs/operators'; import { PropertyApi } from '../../core/decorators/api'; import { Size } from '../../core/enums/size'; import { UI } from '../../core/enums/ui'; const DEFAULT_MIN = 0; const DEFAULT_MAX = 100; const DEFAULT_STEP = 1; let SliderComponent = SliderComponent_1 = class SliderComponent { constructor(logger, fb) { this.logger = logger; this.fb = fb; this.ui = UI; this._min = DEFAULT_MIN; this._max = DEFAULT_MAX; this._step = DEFAULT_STEP; this.rangeControl = this.fb.control(null); this.form = this.fb.group({ range: this.rangeControl, }); this.host = 'jnt-slider-host'; this._size = Size.normal; this.disabled = false; this.onChange = () => this.logger.error('value accessor is not registered'); this.onTouched = () => this.logger.error('value accessor is not registered'); this.registerOnChange = fn => this.onChange = fn; this.registerOnTouched = fn => this.onTouched = fn; this.onBlur = () => this.onTouched(); } set min(min) { this._min = min || DEFAULT_MIN; } get min() { return this._min; } set max(max) { this._max = max || DEFAULT_MAX; } get max() { return this._max; } set step(step) { this._step = step || DEFAULT_STEP; } get step() { return this._step; } ngOnInit() { this.rangeControl.valueChanges.pipe(map(value => +value)) .subscribe(value => { if (value > this.max || value < this.min) { value = Math.min(Math.max(value, this.min), this.max); this.rangeControl.setValue(value, { emitEvent: false }); } this.onChange(value); }); } writeValue(value) { this.rangeControl.setValue(value || DEFAULT_MIN, { emitEvent: false }); } setDisabledState(isDisabled) { this.disabled = isDisabled; } }; SliderComponent.ctorParameters = () => [ { type: NGXLogger }, { type: FormBuilder } ]; __decorate([ HostBinding('attr.host'), __metadata("design:type", Object) ], SliderComponent.prototype, "host", void 0); __decorate([ HostBinding('attr.data-size'), __metadata("design:type", String) ], SliderComponent.prototype, "_size", void 0); __decorate([ HostBinding('attr.data-disabled'), __metadata("design:type", Object) ], SliderComponent.prototype, "disabled", void 0); __decorate([ PropertyApi({ description: 'Slider min', type: 'number', default: DEFAULT_MIN }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], SliderComponent.prototype, "min", null); __decorate([ PropertyApi({ description: 'Slider max', type: 'number', default: DEFAULT_MAX }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], SliderComponent.prototype, "max", null); __decorate([ PropertyApi({ description: 'Slider step', type: 'number', default: DEFAULT_STEP }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], SliderComponent.prototype, "step", null); __decorate([ HostListener('blur'), __metadata("design:type", Object) ], SliderComponent.prototype, "onBlur", void 0); SliderComponent = SliderComponent_1 = __decorate([ Component({ selector: 'jnt-slider', template: "<div child-of=\"jnt-slider-host\" data-slided [style.width]=\"(+rangeControl.value | getPercent:min:max) + '%'\"></div>\n<div child-of=\"jnt-slider-host\" data-pointer [style.left]=\"'calc(' + (+rangeControl.value | getPercent:min:max) + '% - 8px)'\"></div>\n\n<form child-of=\"jnt-slider-host\" [formGroup]=\"form\">\n <input child-of=\"jnt-slider-host\" type=\"range\" [min]=\"min\" [max]=\"max\" [step]=\"step\"\n formControlName=\"range\" />\n</form>", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SliderComponent_1), multi: true } ] }), __metadata("design:paramtypes", [NGXLogger, FormBuilder]) ], SliderComponent); export { SliderComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnInit\n} from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NGXLogger } from 'ngx-logger';\nimport { map } from 'rxjs/operators';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Size } from '../../core/enums/size';\nimport { UI } from '../../core/enums/ui';\n\nconst DEFAULT_MIN = 0;\nconst DEFAULT_MAX = 100;\nconst DEFAULT_STEP = 1;\n\n@Component({\n  selector: 'jnt-slider',\n  templateUrl: './slider.encapsulated.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SliderComponent),\n      multi: true\n    }\n  ]\n})\nexport class SliderComponent implements OnInit, ControlValueAccessor {\n\n  ui = UI;\n\n  private _min = DEFAULT_MIN;\n  private _max = DEFAULT_MAX;\n  private _step = DEFAULT_STEP;\n\n  rangeControl = this.fb.control(null);\n  form = this.fb.group({\n    range: this.rangeControl,\n  });\n\n  @HostBinding('attr.host')\n  readonly host = 'jnt-slider-host';\n\n  @HostBinding('attr.data-size')\n  _size: Size = Size.normal;\n\n  @HostBinding('attr.data-disabled')\n  disabled = false;\n\n  @PropertyApi({\n    description: 'Slider min',\n    type: 'number',\n    default: DEFAULT_MIN\n  })\n  @Input() set min(min: number) {\n    this._min = min || DEFAULT_MIN;\n  }\n\n  get min() {\n    return this._min;\n  }\n\n  @PropertyApi({\n    description: 'Slider max',\n    type: 'number',\n    default: DEFAULT_MAX\n  })\n  @Input() set max(max: number) {\n    this._max = max || DEFAULT_MAX;\n  }\n\n  get max() {\n    return this._max;\n  }\n\n  @PropertyApi({\n    description: 'Slider step',\n    type: 'number',\n    default: DEFAULT_STEP\n  })\n  @Input() set step(step: number) {\n    this._step = step || DEFAULT_STEP;\n  }\n\n  get step() {\n    return this._step;\n  }\n\n  onChange: (value: any) => void = () => this.logger.error('value accessor is not registered');\n  onTouched: () => void = () => this.logger.error('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  constructor(private logger: NGXLogger,\n              private fb: FormBuilder) {\n  }\n\n  ngOnInit() {\n    this.rangeControl.valueChanges.pipe(map(value => +value))\n      .subscribe(value => {\n        if (value > this.max || value < this.min) {\n          value = Math.min(Math.max(value, this.min), this.max);\n          this.rangeControl.setValue(value, {emitEvent: false});\n        }\n        this.onChange(value);\n      });\n  }\n\n  writeValue(value: number) {\n    this.rangeControl.setValue(value || DEFAULT_MIN, {emitEvent: false});\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n}\n"]}