@libs-ui/components-inputs-range-slider 0.2.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # inputs-range-slider
2
+
3
+ This library was generated with [Nx](https://nx.dev).
@@ -0,0 +1,2 @@
1
+ export * from './inputs-range-slider.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvaW5wdXRzL3JhbmdlLXNsaWRlci9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW5wdXRzLXJhbmdlLXNsaWRlci5jb21wb25lbnQnO1xuIl19
@@ -0,0 +1,125 @@
1
+ import { ChangeDetectionStrategy, Component, computed, effect, input, model, output, signal, viewChild } from '@angular/core';
2
+ import { viewDataNumberByLanguage } from '@libs-ui/utils';
3
+ import { Subject, fromEvent } from 'rxjs';
4
+ import { mergeMap, take, takeUntil, tap, throttleTime } from 'rxjs/operators';
5
+ import * as i0 from "@angular/core";
6
+ export class LibsUiComponentsInputsRangeSliderComponent {
7
+ /* PROPERTY */
8
+ visibilityMin = signal(true);
9
+ visibilityMax = signal(true);
10
+ position = signal(0);
11
+ focus = signal(false);
12
+ maxDisplay = computed(this.maxComputed.bind(this));
13
+ onChange = signal(new Subject());
14
+ onDestroy = signal(new Subject());
15
+ /* INPUT */
16
+ mode = input('slider');
17
+ min = input(1);
18
+ max = input(100);
19
+ value = model(0);
20
+ classInclude = input();
21
+ disable = input(false);
22
+ unit = input();
23
+ step = input(0);
24
+ hideProgressingValue = input();
25
+ formatNumber = input();
26
+ /* OUTPUT */
27
+ outChange = output();
28
+ /* VIEW CHILD */
29
+ containerEl = viewChild('containerEl');
30
+ rangeEl = viewChild('rangeEl');
31
+ valueEl = viewChild('valueEl');
32
+ maxValueEl = viewChild('maxValueEl');
33
+ constructor() {
34
+ let first = true;
35
+ effect(() => {
36
+ this.setVariableCss();
37
+ this.calculatePosition();
38
+ if (first) {
39
+ first = false;
40
+ return;
41
+ }
42
+ this.outChange.emit(this.value());
43
+ }, { allowSignalWrites: true });
44
+ }
45
+ /* FUNCTIONS */
46
+ ngAfterViewInit() {
47
+ const windowMouseUp = this.initEvent(window, 'mouseup').pipe(tap(() => this.focus.set(false)));
48
+ const elementMouseDown = this.initEvent(this.rangeEl()?.nativeElement, 'mousedown').pipe(tap(() => this.focus.set(true)));
49
+ const elementMouseUp = this.initEvent(this.rangeEl()?.nativeElement, 'click').pipe(take(1));
50
+ const elementMouseMove = this.initEvent(this.rangeEl()?.nativeElement, 'mousemove').pipe(takeUntil(windowMouseUp));
51
+ const drag = elementMouseDown.pipe(mergeMap(() => elementMouseMove));
52
+ const click = elementMouseDown.pipe(mergeMap(() => elementMouseUp));
53
+ drag.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));
54
+ click.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));
55
+ this.onChange().pipe(throttleTime(200), takeUntil(this.onDestroy())).subscribe(value => this.outChange.emit(value));
56
+ }
57
+ initEvent(element, name) {
58
+ return fromEvent(element, name).pipe(tap((e) => e.stopPropagation()), takeUntil(this.onDestroy()));
59
+ }
60
+ async handlerChange(event) {
61
+ if (this.disable()) {
62
+ event.preventDefault();
63
+ event.stopPropagation();
64
+ event.target.value = this.value();
65
+ return;
66
+ }
67
+ this.value.set(+event.target.value);
68
+ }
69
+ async calculatePosition() {
70
+ if (!this.containerEl() || !this.valueEl()) {
71
+ return;
72
+ }
73
+ const sliderContainer = this.containerEl()?.nativeElement.getBoundingClientRect();
74
+ const progressing = this.max ? (this.value() / this.max()) : 0;
75
+ if (this.hideProgressingValue()) {
76
+ return;
77
+ }
78
+ const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();
79
+ const rectMax = this.containerEl()?.nativeElement.getBoundingClientRect();
80
+ this.position.set((sliderContainer.width * progressing) - ((rectValue.width) / 2) - (this.value() < 10 ? 5 : 4));
81
+ const grandWidthValue = this.position + rectValue.width - rectMax.width;
82
+ if (grandWidthValue > 0) {
83
+ this.position.update(value => value - grandWidthValue);
84
+ }
85
+ this.setVisibility();
86
+ }
87
+ async setVisibility() {
88
+ const rectMax = this.maxValueEl()?.nativeElement.getBoundingClientRect();
89
+ const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();
90
+ this.visibilityMin.set(true);
91
+ this.visibilityMax.set(true);
92
+ if (!this.value()) {
93
+ this.visibilityMin.set(false);
94
+ return;
95
+ }
96
+ if (rectValue.left + rectValue.width >= rectMax.left) {
97
+ this.visibilityMax.set(false);
98
+ }
99
+ if (this.value() < this.min() + 1) {
100
+ this.visibilityMin.set(false);
101
+ }
102
+ }
103
+ async setVariableCss() {
104
+ const element = this.containerEl()?.nativeElement;
105
+ if (!element) {
106
+ return;
107
+ }
108
+ const colorHover = getComputedStyle(element).getPropertyValue('--libs-ui-color-light-1');
109
+ element.style.setProperty('--libs-ui-slider-border-box-shadow', `${colorHover}30`);
110
+ element.style.setProperty('--libs-ui-slider-value', `${this.value() - 0.5}%`);
111
+ }
112
+ maxComputed() {
113
+ if (this.formatNumber()) {
114
+ return viewDataNumberByLanguage(this.max(), true, 1, false, true);
115
+ }
116
+ return this.max();
117
+ }
118
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsRangeSliderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
119
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsRangeSliderComponent, isStandalone: true, selector: "libs_ui-components-inputs-range_slider", inputs: { mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, unit: { classPropertyName: "unit", publicName: "unit", isSignal: true, isRequired: false, transformFunction: null }, step: { classPropertyName: "step", publicName: "step", isSignal: true, isRequired: false, transformFunction: null }, hideProgressingValue: { classPropertyName: "hideProgressingValue", publicName: "hideProgressingValue", isSignal: true, isRequired: false, transformFunction: null }, formatNumber: { classPropertyName: "formatNumber", publicName: "formatNumber", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange", outChange: "outChange" }, viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["containerEl"], descendants: true, isSignal: true }, { propertyName: "rangeEl", first: true, predicate: ["rangeEl"], descendants: true, isSignal: true }, { propertyName: "valueEl", first: true, predicate: ["valueEl"], descendants: true, isSignal: true }, { propertyName: "maxValueEl", first: true, predicate: ["maxValueEl"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"libs-ui-range-slider-container\"\n [style.height.px]=\"mode() === 'slider' ? 44 : 22\"\n [class.pt-[4px]]=\"mode() === 'slider'\"\n #containerEl>\n <div [class.hidden]=\"!focus()\"\n class=\"libs-ui-range-slider-icon-active\">\n </div>\n <input #rangeEl\n class=\"libs-ui-range-slider\"\n [attr.mode]=\"mode()\"\n [attr.focus]=\"focus()\"\n [attr.disable]=\"disable()\"\n [value]=\"value()\"\n [type]=\"'range'\"\n [min]=\"min()\"\n [max]=\"max()\"\n [step]=\"step()\">\n @if (mode() === 'slider') {\n <div class=\"flex justify-between relative mt-[8px]\">\n <div class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMin()\">\n {{ min() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n <div #valueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] absolute bottom-0 flex\"\n [style.left.px]=\"position()\">\n @if (!hideProgressingValue()) {\n {{ value() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n }\n </div>\n <div #maxValueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMax()\">\n {{ maxComputed() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n </div>\n }\n</div>\n", styles: [".libs-ui-range-slider-container{width:100%;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:linear-gradient(to right,var(--libs-ui-color-default, #226FF5) 0%,var(--libs-ui-color-default, #226FF5) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) 100%);outline:none;border-radius:4px}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:solid 2px var(--libs-ui-color-default);z-index:3;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb{width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 2px #4e4e4e4d;border:solid 2px var(--libs-ui-color-default);z-index:3}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]{background:linear-gradient(to right,#071631 0%,#071631 var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-webkit-slider-thumb{display:none}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-moz-range-thumb{width:0;height:0;border:none}.libs-ui-range-slider-container .libs-ui-range-slider:hover,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true]{background:linear-gradient(to right,var(--libs-ui-color-light-1, #4E8CF7) 0%,var(--libs-ui-color-light-1, #4E8CF7) var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-webkit-slider-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-webkit-slider-thumb{display:block}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-moz-range-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-moz-range-thumb{width:16px;height:16px;border:solid 2px var(--libs-ui-color-default)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true]{pointer-events:none;background:linear-gradient(to right,#CDD0D6 0%,#CDD0D6 var(--libs-ui-slider-value),#E6E7EA var(--libs-ui-slider-value),#E6E7EA 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true].libs-ui-range-slider::-webkit-slider-thumb{border:solid 2px #CDD0D6}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
120
+ }
121
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsRangeSliderComponent, decorators: [{
122
+ type: Component,
123
+ args: [{ selector: 'libs_ui-components-inputs-range_slider', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"libs-ui-range-slider-container\"\n [style.height.px]=\"mode() === 'slider' ? 44 : 22\"\n [class.pt-[4px]]=\"mode() === 'slider'\"\n #containerEl>\n <div [class.hidden]=\"!focus()\"\n class=\"libs-ui-range-slider-icon-active\">\n </div>\n <input #rangeEl\n class=\"libs-ui-range-slider\"\n [attr.mode]=\"mode()\"\n [attr.focus]=\"focus()\"\n [attr.disable]=\"disable()\"\n [value]=\"value()\"\n [type]=\"'range'\"\n [min]=\"min()\"\n [max]=\"max()\"\n [step]=\"step()\">\n @if (mode() === 'slider') {\n <div class=\"flex justify-between relative mt-[8px]\">\n <div class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMin()\">\n {{ min() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n <div #valueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] absolute bottom-0 flex\"\n [style.left.px]=\"position()\">\n @if (!hideProgressingValue()) {\n {{ value() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n }\n </div>\n <div #maxValueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMax()\">\n {{ maxComputed() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n </div>\n }\n</div>\n", styles: [".libs-ui-range-slider-container{width:100%;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:linear-gradient(to right,var(--libs-ui-color-default, #226FF5) 0%,var(--libs-ui-color-default, #226FF5) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) 100%);outline:none;border-radius:4px}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:solid 2px var(--libs-ui-color-default);z-index:3;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb{width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 2px #4e4e4e4d;border:solid 2px var(--libs-ui-color-default);z-index:3}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]{background:linear-gradient(to right,#071631 0%,#071631 var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-webkit-slider-thumb{display:none}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-moz-range-thumb{width:0;height:0;border:none}.libs-ui-range-slider-container .libs-ui-range-slider:hover,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true]{background:linear-gradient(to right,var(--libs-ui-color-light-1, #4E8CF7) 0%,var(--libs-ui-color-light-1, #4E8CF7) var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-webkit-slider-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-webkit-slider-thumb{display:block}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-moz-range-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-moz-range-thumb{width:16px;height:16px;border:solid 2px var(--libs-ui-color-default)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true]{pointer-events:none;background:linear-gradient(to right,#CDD0D6 0%,#CDD0D6 var(--libs-ui-slider-value),#E6E7EA var(--libs-ui-slider-value),#E6E7EA 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true].libs-ui-range-slider::-webkit-slider-thumb{border:solid 2px #CDD0D6}\n"] }]
124
+ }], ctorParameters: () => [] });
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs-range-slider.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/inputs/range-slider/src/inputs-range-slider.component.ts","../../../../../../libs-ui/components/inputs/range-slider/src/inputs-range-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ElementRef, computed, effect, input, model, output, signal, viewChild } from '@angular/core';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { viewDataNumberByLanguage } from '@libs-ui/utils';\nimport { Observable, Subject, fromEvent } from 'rxjs';\nimport { mergeMap, take, takeUntil, tap, throttleTime } from 'rxjs/operators';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-range_slider',\n  templateUrl: 'inputs-range-slider.component.html',\n  styleUrl: 'inputs-range-slider.component.scss',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsInputsRangeSliderComponent implements AfterViewInit {\n\n  /* PROPERTY */\n  protected visibilityMin = signal<boolean>(true);\n  protected visibilityMax = signal<boolean>(true);\n  protected position = signal<number>(0);\n  protected focus = signal<boolean>(false);\n  protected maxDisplay = computed(this.maxComputed.bind(this))\n\n  private onChange = signal<Subject<number>>(new Subject());\n  private onDestroy = signal<Subject<void>>(new Subject());\n\n  /* INPUT */\n  readonly mode = input<'media' | 'slider'>('slider');\n  readonly min = input<number>(1);\n  readonly max = input<number>(100);\n  readonly value = model<number>(0);\n  readonly classInclude = input<string>();\n  readonly disable = input<boolean>(false);\n  readonly unit = input<string>();\n  readonly step = input<number>(0);\n  readonly hideProgressingValue = input<boolean>();\n  readonly formatNumber = input<boolean>();\n\n  /* OUTPUT */\n  readonly outChange = output<number>();\n\n  /* VIEW CHILD */\n  private readonly containerEl = viewChild<ElementRef>('containerEl');\n  private readonly rangeEl = viewChild<ElementRef>('rangeEl');\n  private readonly valueEl = viewChild<ElementRef>('valueEl');\n  private readonly maxValueEl = viewChild<ElementRef>('maxValueEl');\n\n  constructor() {\n    let first = true;\n\n    effect(() => {\n      this.setVariableCss();\n      this.calculatePosition();\n      if (first) {\n        first = false;\n\n        return;\n      }\n      this.outChange.emit(this.value());\n    }, { allowSignalWrites: true })\n  }\n\n  /* FUNCTIONS */\n  ngAfterViewInit(): void {\n    const windowMouseUp = this.initEvent(window as unknown as HTMLElement, 'mouseup').pipe(tap(() => this.focus.set(false)));\n    const elementMouseDown = this.initEvent(this.rangeEl()?.nativeElement, 'mousedown').pipe(tap(() => this.focus.set(true)));\n    const elementMouseUp = this.initEvent(this.rangeEl()?.nativeElement, 'click').pipe(take(1));\n    const elementMouseMove = this.initEvent(this.rangeEl()?.nativeElement, 'mousemove').pipe(takeUntil(windowMouseUp));\n\n    const drag = elementMouseDown.pipe(mergeMap(() => elementMouseMove));\n    const click = elementMouseDown.pipe(mergeMap(() => elementMouseUp));\n\n    drag.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));\n    click.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));\n    this.onChange().pipe(throttleTime(200), takeUntil(this.onDestroy())).subscribe(value => this.outChange.emit(value));\n  }\n\n  private initEvent(element: HTMLElement, name: string): Observable<IEvent> {\n    return fromEvent<IEvent>(element, name).pipe(tap((e: IEvent) => e.stopPropagation()), takeUntil(this.onDestroy()));\n  }\n\n  private async handlerChange(event: IEvent) {\n    if (this.disable()) {\n      event.preventDefault();\n      event.stopPropagation();\n      event.target.value = this.value();\n\n      return;\n    }\n    this.value.set(+event.target.value);\n  }\n\n  private async calculatePosition() {\n    if (!this.containerEl() || !this.valueEl()) {\n      return;\n    }\n    const sliderContainer = this.containerEl()?.nativeElement.getBoundingClientRect();\n    const progressing = this.max ? (this.value() / this.max()) : 0;\n\n    if (this.hideProgressingValue()) {\n      return;\n    }\n    const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();\n    const rectMax = this.containerEl()?.nativeElement.getBoundingClientRect();\n\n    this.position.set((sliderContainer.width * progressing) - ((rectValue.width) / 2) - (this.value() < 10 ? 5 : 4));\n    const grandWidthValue = this.position + rectValue.width - rectMax.width;\n\n    if (grandWidthValue > 0) {\n      this.position.update(value => value - grandWidthValue);\n    }\n    this.setVisibility();\n  }\n\n  private async setVisibility() {\n    const rectMax = this.maxValueEl()?.nativeElement.getBoundingClientRect();\n    const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();\n\n    this.visibilityMin.set(true);\n    this.visibilityMax.set(true);\n    if (!this.value()) {\n      this.visibilityMin.set(false);\n\n      return;\n    }\n    if (rectValue.left + rectValue.width >= rectMax.left) {\n      this.visibilityMax.set(false);\n    }\n    if (this.value() < this.min() + 1) {\n      this.visibilityMin.set(false);\n    }\n  }\n\n  private async setVariableCss() {\n    const element = this.containerEl()?.nativeElement;\n\n    if (!element) {\n      return;\n    }\n    const colorHover = getComputedStyle(element).getPropertyValue('--libs-ui-color-light-1');\n\n    element.style.setProperty('--libs-ui-slider-border-box-shadow', `${colorHover}30`);\n    element.style.setProperty('--libs-ui-slider-value', `${this.value() - 0.5}%`);\n  }\n\n  protected maxComputed() {\n    if (this.formatNumber()) {\n      return viewDataNumberByLanguage(this.max(), true, 1, false, true);\n    }\n\n    return this.max();\n  }\n\n}\n","<div class=\"libs-ui-range-slider-container\"\n  [style.height.px]=\"mode() === 'slider' ? 44 : 22\"\n  [class.pt-[4px]]=\"mode() === 'slider'\"\n  #containerEl>\n  <div [class.hidden]=\"!focus()\"\n    class=\"libs-ui-range-slider-icon-active\">\n  </div>\n  <input #rangeEl\n    class=\"libs-ui-range-slider\"\n    [attr.mode]=\"mode()\"\n    [attr.focus]=\"focus()\"\n    [attr.disable]=\"disable()\"\n    [value]=\"value()\"\n    [type]=\"'range'\"\n    [min]=\"min()\"\n    [max]=\"max()\"\n    [step]=\"step()\">\n  @if (mode() === 'slider') {\n    <div class=\"flex justify-between relative mt-[8px]\">\n      <div class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n        [class.invisible]=\"!visibilityMin()\">\n        {{ min() }}\n        @if (unit()) {\n          <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n        }\n      </div>\n      <div #valueEl\n        class=\"libs-ui-font-h7r text-[#9ca2ad] absolute bottom-0 flex\"\n        [style.left.px]=\"position()\">\n        @if (!hideProgressingValue()) {\n          {{ value() }}\n          @if (unit()) {\n            <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n          }\n        }\n      </div>\n      <div #maxValueEl\n        class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n        [class.invisible]=\"!visibilityMax()\">\n        {{ maxComputed() }}\n        @if (unit()) {\n          <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n        }\n      </div>\n    </div>\n  }\n</div>\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1jb21wb25lbnRzLWlucHV0cy1yYW5nZS1zbGlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvaW5wdXRzL3JhbmdlLXNsaWRlci9zcmMvbGlicy11aS1jb21wb25lbnRzLWlucHV0cy1yYW5nZS1zbGlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,132 @@
1
+ import * as i0 from '@angular/core';
2
+ import { signal, computed, input, model, output, viewChild, effect, Component, ChangeDetectionStrategy } from '@angular/core';
3
+ import { viewDataNumberByLanguage } from '@libs-ui/utils';
4
+ import { Subject, fromEvent } from 'rxjs';
5
+ import { tap, take, takeUntil, mergeMap, throttleTime } from 'rxjs/operators';
6
+
7
+ class LibsUiComponentsInputsRangeSliderComponent {
8
+ /* PROPERTY */
9
+ visibilityMin = signal(true);
10
+ visibilityMax = signal(true);
11
+ position = signal(0);
12
+ focus = signal(false);
13
+ maxDisplay = computed(this.maxComputed.bind(this));
14
+ onChange = signal(new Subject());
15
+ onDestroy = signal(new Subject());
16
+ /* INPUT */
17
+ mode = input('slider');
18
+ min = input(1);
19
+ max = input(100);
20
+ value = model(0);
21
+ classInclude = input();
22
+ disable = input(false);
23
+ unit = input();
24
+ step = input(0);
25
+ hideProgressingValue = input();
26
+ formatNumber = input();
27
+ /* OUTPUT */
28
+ outChange = output();
29
+ /* VIEW CHILD */
30
+ containerEl = viewChild('containerEl');
31
+ rangeEl = viewChild('rangeEl');
32
+ valueEl = viewChild('valueEl');
33
+ maxValueEl = viewChild('maxValueEl');
34
+ constructor() {
35
+ let first = true;
36
+ effect(() => {
37
+ this.setVariableCss();
38
+ this.calculatePosition();
39
+ if (first) {
40
+ first = false;
41
+ return;
42
+ }
43
+ this.outChange.emit(this.value());
44
+ }, { allowSignalWrites: true });
45
+ }
46
+ /* FUNCTIONS */
47
+ ngAfterViewInit() {
48
+ const windowMouseUp = this.initEvent(window, 'mouseup').pipe(tap(() => this.focus.set(false)));
49
+ const elementMouseDown = this.initEvent(this.rangeEl()?.nativeElement, 'mousedown').pipe(tap(() => this.focus.set(true)));
50
+ const elementMouseUp = this.initEvent(this.rangeEl()?.nativeElement, 'click').pipe(take(1));
51
+ const elementMouseMove = this.initEvent(this.rangeEl()?.nativeElement, 'mousemove').pipe(takeUntil(windowMouseUp));
52
+ const drag = elementMouseDown.pipe(mergeMap(() => elementMouseMove));
53
+ const click = elementMouseDown.pipe(mergeMap(() => elementMouseUp));
54
+ drag.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));
55
+ click.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));
56
+ this.onChange().pipe(throttleTime(200), takeUntil(this.onDestroy())).subscribe(value => this.outChange.emit(value));
57
+ }
58
+ initEvent(element, name) {
59
+ return fromEvent(element, name).pipe(tap((e) => e.stopPropagation()), takeUntil(this.onDestroy()));
60
+ }
61
+ async handlerChange(event) {
62
+ if (this.disable()) {
63
+ event.preventDefault();
64
+ event.stopPropagation();
65
+ event.target.value = this.value();
66
+ return;
67
+ }
68
+ this.value.set(+event.target.value);
69
+ }
70
+ async calculatePosition() {
71
+ if (!this.containerEl() || !this.valueEl()) {
72
+ return;
73
+ }
74
+ const sliderContainer = this.containerEl()?.nativeElement.getBoundingClientRect();
75
+ const progressing = this.max ? (this.value() / this.max()) : 0;
76
+ if (this.hideProgressingValue()) {
77
+ return;
78
+ }
79
+ const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();
80
+ const rectMax = this.containerEl()?.nativeElement.getBoundingClientRect();
81
+ this.position.set((sliderContainer.width * progressing) - ((rectValue.width) / 2) - (this.value() < 10 ? 5 : 4));
82
+ const grandWidthValue = this.position + rectValue.width - rectMax.width;
83
+ if (grandWidthValue > 0) {
84
+ this.position.update(value => value - grandWidthValue);
85
+ }
86
+ this.setVisibility();
87
+ }
88
+ async setVisibility() {
89
+ const rectMax = this.maxValueEl()?.nativeElement.getBoundingClientRect();
90
+ const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();
91
+ this.visibilityMin.set(true);
92
+ this.visibilityMax.set(true);
93
+ if (!this.value()) {
94
+ this.visibilityMin.set(false);
95
+ return;
96
+ }
97
+ if (rectValue.left + rectValue.width >= rectMax.left) {
98
+ this.visibilityMax.set(false);
99
+ }
100
+ if (this.value() < this.min() + 1) {
101
+ this.visibilityMin.set(false);
102
+ }
103
+ }
104
+ async setVariableCss() {
105
+ const element = this.containerEl()?.nativeElement;
106
+ if (!element) {
107
+ return;
108
+ }
109
+ const colorHover = getComputedStyle(element).getPropertyValue('--libs-ui-color-light-1');
110
+ element.style.setProperty('--libs-ui-slider-border-box-shadow', `${colorHover}30`);
111
+ element.style.setProperty('--libs-ui-slider-value', `${this.value() - 0.5}%`);
112
+ }
113
+ maxComputed() {
114
+ if (this.formatNumber()) {
115
+ return viewDataNumberByLanguage(this.max(), true, 1, false, true);
116
+ }
117
+ return this.max();
118
+ }
119
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsRangeSliderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
120
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsRangeSliderComponent, isStandalone: true, selector: "libs_ui-components-inputs-range_slider", inputs: { mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, unit: { classPropertyName: "unit", publicName: "unit", isSignal: true, isRequired: false, transformFunction: null }, step: { classPropertyName: "step", publicName: "step", isSignal: true, isRequired: false, transformFunction: null }, hideProgressingValue: { classPropertyName: "hideProgressingValue", publicName: "hideProgressingValue", isSignal: true, isRequired: false, transformFunction: null }, formatNumber: { classPropertyName: "formatNumber", publicName: "formatNumber", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange", outChange: "outChange" }, viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["containerEl"], descendants: true, isSignal: true }, { propertyName: "rangeEl", first: true, predicate: ["rangeEl"], descendants: true, isSignal: true }, { propertyName: "valueEl", first: true, predicate: ["valueEl"], descendants: true, isSignal: true }, { propertyName: "maxValueEl", first: true, predicate: ["maxValueEl"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"libs-ui-range-slider-container\"\n [style.height.px]=\"mode() === 'slider' ? 44 : 22\"\n [class.pt-[4px]]=\"mode() === 'slider'\"\n #containerEl>\n <div [class.hidden]=\"!focus()\"\n class=\"libs-ui-range-slider-icon-active\">\n </div>\n <input #rangeEl\n class=\"libs-ui-range-slider\"\n [attr.mode]=\"mode()\"\n [attr.focus]=\"focus()\"\n [attr.disable]=\"disable()\"\n [value]=\"value()\"\n [type]=\"'range'\"\n [min]=\"min()\"\n [max]=\"max()\"\n [step]=\"step()\">\n @if (mode() === 'slider') {\n <div class=\"flex justify-between relative mt-[8px]\">\n <div class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMin()\">\n {{ min() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n <div #valueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] absolute bottom-0 flex\"\n [style.left.px]=\"position()\">\n @if (!hideProgressingValue()) {\n {{ value() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n }\n </div>\n <div #maxValueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMax()\">\n {{ maxComputed() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n </div>\n }\n</div>\n", styles: [".libs-ui-range-slider-container{width:100%;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:linear-gradient(to right,var(--libs-ui-color-default, #226FF5) 0%,var(--libs-ui-color-default, #226FF5) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) 100%);outline:none;border-radius:4px}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:solid 2px var(--libs-ui-color-default);z-index:3;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb{width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 2px #4e4e4e4d;border:solid 2px var(--libs-ui-color-default);z-index:3}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]{background:linear-gradient(to right,#071631 0%,#071631 var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-webkit-slider-thumb{display:none}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-moz-range-thumb{width:0;height:0;border:none}.libs-ui-range-slider-container .libs-ui-range-slider:hover,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true]{background:linear-gradient(to right,var(--libs-ui-color-light-1, #4E8CF7) 0%,var(--libs-ui-color-light-1, #4E8CF7) var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-webkit-slider-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-webkit-slider-thumb{display:block}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-moz-range-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-moz-range-thumb{width:16px;height:16px;border:solid 2px var(--libs-ui-color-default)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true]{pointer-events:none;background:linear-gradient(to right,#CDD0D6 0%,#CDD0D6 var(--libs-ui-slider-value),#E6E7EA var(--libs-ui-slider-value),#E6E7EA 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true].libs-ui-range-slider::-webkit-slider-thumb{border:solid 2px #CDD0D6}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
121
+ }
122
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsRangeSliderComponent, decorators: [{
123
+ type: Component,
124
+ args: [{ selector: 'libs_ui-components-inputs-range_slider', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"libs-ui-range-slider-container\"\n [style.height.px]=\"mode() === 'slider' ? 44 : 22\"\n [class.pt-[4px]]=\"mode() === 'slider'\"\n #containerEl>\n <div [class.hidden]=\"!focus()\"\n class=\"libs-ui-range-slider-icon-active\">\n </div>\n <input #rangeEl\n class=\"libs-ui-range-slider\"\n [attr.mode]=\"mode()\"\n [attr.focus]=\"focus()\"\n [attr.disable]=\"disable()\"\n [value]=\"value()\"\n [type]=\"'range'\"\n [min]=\"min()\"\n [max]=\"max()\"\n [step]=\"step()\">\n @if (mode() === 'slider') {\n <div class=\"flex justify-between relative mt-[8px]\">\n <div class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMin()\">\n {{ min() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n <div #valueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] absolute bottom-0 flex\"\n [style.left.px]=\"position()\">\n @if (!hideProgressingValue()) {\n {{ value() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n }\n </div>\n <div #maxValueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMax()\">\n {{ maxComputed() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n </div>\n }\n</div>\n", styles: [".libs-ui-range-slider-container{width:100%;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:linear-gradient(to right,var(--libs-ui-color-default, #226FF5) 0%,var(--libs-ui-color-default, #226FF5) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) var(--libs-ui-slider-value),var(--libs-ui-color-light-3, #e9f1fe) 100%);outline:none;border-radius:4px}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:solid 2px var(--libs-ui-color-default);z-index:3;position:relative}.libs-ui-range-slider-container .libs-ui-range-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb{width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 2px #4e4e4e4d;border:solid 2px var(--libs-ui-color-default);z-index:3}.libs-ui-range-slider-container .libs-ui-range-slider::-moz-range-thumb:hover{box-shadow:0 0 0 8px var(--libs-ui-slider-border-box-shadow, rgba(78, 140, 247, .1882352941))}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]{background:linear-gradient(to right,#071631 0%,#071631 var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-webkit-slider-thumb{display:none}.libs-ui-range-slider-container .libs-ui-range-slider[mode=media]::-moz-range-thumb{width:0;height:0;border:none}.libs-ui-range-slider-container .libs-ui-range-slider:hover,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true]{background:linear-gradient(to right,var(--libs-ui-color-light-1, #4E8CF7) 0%,var(--libs-ui-color-light-1, #4E8CF7) var(--libs-ui-slider-value),#CDD0D6 var(--libs-ui-slider-value),#CDD0D6 100%)}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-webkit-slider-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-webkit-slider-thumb{display:block}.libs-ui-range-slider-container .libs-ui-range-slider:hover[mode=media]::-moz-range-thumb,.libs-ui-range-slider-container .libs-ui-range-slider[focus=true][mode=media]::-moz-range-thumb{width:16px;height:16px;border:solid 2px var(--libs-ui-color-default)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true]{pointer-events:none;background:linear-gradient(to right,#CDD0D6 0%,#CDD0D6 var(--libs-ui-slider-value),#E6E7EA var(--libs-ui-slider-value),#E6E7EA 100%)}.libs-ui-range-slider-container .libs-ui-range-slider[disable=true].libs-ui-range-slider::-webkit-slider-thumb{border:solid 2px #CDD0D6}\n"] }]
125
+ }], ctorParameters: () => [] });
126
+
127
+ /**
128
+ * Generated bundle index. Do not edit.
129
+ */
130
+
131
+ export { LibsUiComponentsInputsRangeSliderComponent };
132
+ //# sourceMappingURL=libs-ui-components-inputs-range-slider.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"libs-ui-components-inputs-range-slider.mjs","sources":["../../../../../../libs-ui/components/inputs/range-slider/src/inputs-range-slider.component.ts","../../../../../../libs-ui/components/inputs/range-slider/src/inputs-range-slider.component.html","../../../../../../libs-ui/components/inputs/range-slider/src/libs-ui-components-inputs-range-slider.ts"],"sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ElementRef, computed, effect, input, model, output, signal, viewChild } from '@angular/core';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { viewDataNumberByLanguage } from '@libs-ui/utils';\nimport { Observable, Subject, fromEvent } from 'rxjs';\nimport { mergeMap, take, takeUntil, tap, throttleTime } from 'rxjs/operators';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-inputs-range_slider',\n templateUrl: 'inputs-range-slider.component.html',\n styleUrl: 'inputs-range-slider.component.scss',\n standalone: true,\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsInputsRangeSliderComponent implements AfterViewInit {\n\n /* PROPERTY */\n protected visibilityMin = signal<boolean>(true);\n protected visibilityMax = signal<boolean>(true);\n protected position = signal<number>(0);\n protected focus = signal<boolean>(false);\n protected maxDisplay = computed(this.maxComputed.bind(this))\n\n private onChange = signal<Subject<number>>(new Subject());\n private onDestroy = signal<Subject<void>>(new Subject());\n\n /* INPUT */\n readonly mode = input<'media' | 'slider'>('slider');\n readonly min = input<number>(1);\n readonly max = input<number>(100);\n readonly value = model<number>(0);\n readonly classInclude = input<string>();\n readonly disable = input<boolean>(false);\n readonly unit = input<string>();\n readonly step = input<number>(0);\n readonly hideProgressingValue = input<boolean>();\n readonly formatNumber = input<boolean>();\n\n /* OUTPUT */\n readonly outChange = output<number>();\n\n /* VIEW CHILD */\n private readonly containerEl = viewChild<ElementRef>('containerEl');\n private readonly rangeEl = viewChild<ElementRef>('rangeEl');\n private readonly valueEl = viewChild<ElementRef>('valueEl');\n private readonly maxValueEl = viewChild<ElementRef>('maxValueEl');\n\n constructor() {\n let first = true;\n\n effect(() => {\n this.setVariableCss();\n this.calculatePosition();\n if (first) {\n first = false;\n\n return;\n }\n this.outChange.emit(this.value());\n }, { allowSignalWrites: true })\n }\n\n /* FUNCTIONS */\n ngAfterViewInit(): void {\n const windowMouseUp = this.initEvent(window as unknown as HTMLElement, 'mouseup').pipe(tap(() => this.focus.set(false)));\n const elementMouseDown = this.initEvent(this.rangeEl()?.nativeElement, 'mousedown').pipe(tap(() => this.focus.set(true)));\n const elementMouseUp = this.initEvent(this.rangeEl()?.nativeElement, 'click').pipe(take(1));\n const elementMouseMove = this.initEvent(this.rangeEl()?.nativeElement, 'mousemove').pipe(takeUntil(windowMouseUp));\n\n const drag = elementMouseDown.pipe(mergeMap(() => elementMouseMove));\n const click = elementMouseDown.pipe(mergeMap(() => elementMouseUp));\n\n drag.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));\n click.pipe(takeUntil(this.onDestroy())).subscribe(this.handlerChange.bind(this));\n this.onChange().pipe(throttleTime(200), takeUntil(this.onDestroy())).subscribe(value => this.outChange.emit(value));\n }\n\n private initEvent(element: HTMLElement, name: string): Observable<IEvent> {\n return fromEvent<IEvent>(element, name).pipe(tap((e: IEvent) => e.stopPropagation()), takeUntil(this.onDestroy()));\n }\n\n private async handlerChange(event: IEvent) {\n if (this.disable()) {\n event.preventDefault();\n event.stopPropagation();\n event.target.value = this.value();\n\n return;\n }\n this.value.set(+event.target.value);\n }\n\n private async calculatePosition() {\n if (!this.containerEl() || !this.valueEl()) {\n return;\n }\n const sliderContainer = this.containerEl()?.nativeElement.getBoundingClientRect();\n const progressing = this.max ? (this.value() / this.max()) : 0;\n\n if (this.hideProgressingValue()) {\n return;\n }\n const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();\n const rectMax = this.containerEl()?.nativeElement.getBoundingClientRect();\n\n this.position.set((sliderContainer.width * progressing) - ((rectValue.width) / 2) - (this.value() < 10 ? 5 : 4));\n const grandWidthValue = this.position + rectValue.width - rectMax.width;\n\n if (grandWidthValue > 0) {\n this.position.update(value => value - grandWidthValue);\n }\n this.setVisibility();\n }\n\n private async setVisibility() {\n const rectMax = this.maxValueEl()?.nativeElement.getBoundingClientRect();\n const rectValue = this.valueEl()?.nativeElement.getBoundingClientRect();\n\n this.visibilityMin.set(true);\n this.visibilityMax.set(true);\n if (!this.value()) {\n this.visibilityMin.set(false);\n\n return;\n }\n if (rectValue.left + rectValue.width >= rectMax.left) {\n this.visibilityMax.set(false);\n }\n if (this.value() < this.min() + 1) {\n this.visibilityMin.set(false);\n }\n }\n\n private async setVariableCss() {\n const element = this.containerEl()?.nativeElement;\n\n if (!element) {\n return;\n }\n const colorHover = getComputedStyle(element).getPropertyValue('--libs-ui-color-light-1');\n\n element.style.setProperty('--libs-ui-slider-border-box-shadow', `${colorHover}30`);\n element.style.setProperty('--libs-ui-slider-value', `${this.value() - 0.5}%`);\n }\n\n protected maxComputed() {\n if (this.formatNumber()) {\n return viewDataNumberByLanguage(this.max(), true, 1, false, true);\n }\n\n return this.max();\n }\n\n}\n","<div class=\"libs-ui-range-slider-container\"\n [style.height.px]=\"mode() === 'slider' ? 44 : 22\"\n [class.pt-[4px]]=\"mode() === 'slider'\"\n #containerEl>\n <div [class.hidden]=\"!focus()\"\n class=\"libs-ui-range-slider-icon-active\">\n </div>\n <input #rangeEl\n class=\"libs-ui-range-slider\"\n [attr.mode]=\"mode()\"\n [attr.focus]=\"focus()\"\n [attr.disable]=\"disable()\"\n [value]=\"value()\"\n [type]=\"'range'\"\n [min]=\"min()\"\n [max]=\"max()\"\n [step]=\"step()\">\n @if (mode() === 'slider') {\n <div class=\"flex justify-between relative mt-[8px]\">\n <div class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMin()\">\n {{ min() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n <div #valueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] absolute bottom-0 flex\"\n [style.left.px]=\"position()\">\n @if (!hideProgressingValue()) {\n {{ value() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n }\n </div>\n <div #maxValueEl\n class=\"libs-ui-font-h7r text-[#9ca2ad] flex\"\n [class.invisible]=\"!visibilityMax()\">\n {{ maxComputed() }}\n @if (unit()) {\n <span class=\"libs-ui-font-h7r text-[#9ca2ad]\">{{ unit() }}</span>\n }\n </div>\n </div>\n }\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1 @@
1
+ export * from './inputs-range-slider.component';
@@ -0,0 +1,36 @@
1
+ import { AfterViewInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class LibsUiComponentsInputsRangeSliderComponent implements AfterViewInit {
4
+ protected visibilityMin: import("@angular/core").WritableSignal<boolean>;
5
+ protected visibilityMax: import("@angular/core").WritableSignal<boolean>;
6
+ protected position: import("@angular/core").WritableSignal<number>;
7
+ protected focus: import("@angular/core").WritableSignal<boolean>;
8
+ protected maxDisplay: import("@angular/core").Signal<any>;
9
+ private onChange;
10
+ private onDestroy;
11
+ readonly mode: import("@angular/core").InputSignal<"media" | "slider">;
12
+ readonly min: import("@angular/core").InputSignal<number>;
13
+ readonly max: import("@angular/core").InputSignal<number>;
14
+ readonly value: import("@angular/core").ModelSignal<number>;
15
+ readonly classInclude: import("@angular/core").InputSignal<string | undefined>;
16
+ readonly disable: import("@angular/core").InputSignal<boolean>;
17
+ readonly unit: import("@angular/core").InputSignal<string | undefined>;
18
+ readonly step: import("@angular/core").InputSignal<number>;
19
+ readonly hideProgressingValue: import("@angular/core").InputSignal<boolean | undefined>;
20
+ readonly formatNumber: import("@angular/core").InputSignal<boolean | undefined>;
21
+ readonly outChange: import("@angular/core").OutputEmitterRef<number>;
22
+ private readonly containerEl;
23
+ private readonly rangeEl;
24
+ private readonly valueEl;
25
+ private readonly maxValueEl;
26
+ constructor();
27
+ ngAfterViewInit(): void;
28
+ private initEvent;
29
+ private handlerChange;
30
+ private calculatePosition;
31
+ private setVisibility;
32
+ private setVariableCss;
33
+ protected maxComputed(): any;
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiComponentsInputsRangeSliderComponent, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<LibsUiComponentsInputsRangeSliderComponent, "libs_ui-components-inputs-range_slider", never, { "mode": { "alias": "mode"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "classInclude": { "alias": "classInclude"; "required": false; "isSignal": true; }; "disable": { "alias": "disable"; "required": false; "isSignal": true; }; "unit": { "alias": "unit"; "required": false; "isSignal": true; }; "step": { "alias": "step"; "required": false; "isSignal": true; }; "hideProgressingValue": { "alias": "hideProgressingValue"; "required": false; "isSignal": true; }; "formatNumber": { "alias": "formatNumber"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; "outChange": "outChange"; }, never, never, true, never>;
36
+ }
package/package.json ADDED
@@ -0,0 +1,25 @@
1
+ {
2
+ "name": "@libs-ui/components-inputs-range-slider",
3
+ "version": "0.2.11",
4
+ "peerDependencies": {
5
+ "@angular/common": "^18.2.0",
6
+ "@angular/core": "^18.2.0"
7
+ },
8
+ "sideEffects": false,
9
+ "module": "fesm2022/libs-ui-components-inputs-range-slider.mjs",
10
+ "typings": "index.d.ts",
11
+ "exports": {
12
+ "./package.json": {
13
+ "default": "./package.json"
14
+ },
15
+ ".": {
16
+ "types": "./index.d.ts",
17
+ "esm2022": "./esm2022/libs-ui-components-inputs-range-slider.mjs",
18
+ "esm": "./esm2022/libs-ui-components-inputs-range-slider.mjs",
19
+ "default": "./fesm2022/libs-ui-components-inputs-range-slider.mjs"
20
+ }
21
+ },
22
+ "dependencies": {
23
+ "tslib": "^2.3.0"
24
+ }
25
+ }