@junte/ui
Version:
Quality Angular UI components kit
136 lines • 13.3 kB
JavaScript
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"]}