@acorex/components 18.7.2 → 18.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (24) hide show
  1. package/color-palette/lib/color-palette-picker.component.d.ts +3 -3
  2. package/color-palette/lib/color-palette.module.d.ts +4 -3
  3. package/conversation/lib/conversation-messages/conversation-message-audio/conversation-message-audio.component.d.ts +1 -0
  4. package/conversation/lib/conversation.module.d.ts +2 -2
  5. package/esm2022/color-palette/lib/color-palette-picker.component.mjs +13 -10
  6. package/esm2022/color-palette/lib/color-palette.component.mjs +2 -2
  7. package/esm2022/color-palette/lib/color-palette.module.mjs +5 -2
  8. package/esm2022/conversation/lib/conversation-messages/conversation-message-audio/conversation-message-audio.component.mjs +12 -9
  9. package/esm2022/conversation/lib/conversation.module.mjs +5 -5
  10. package/esm2022/range-slider/index.mjs +3 -1
  11. package/esm2022/range-slider/lib/range-slider.class.mjs +3 -0
  12. package/esm2022/range-slider/lib/range-slider.component.mjs +429 -6
  13. package/esm2022/range-slider/lib/range-slider.module.mjs +3 -2
  14. package/fesm2022/acorex-components-color-palette.mjs +18 -12
  15. package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
  16. package/fesm2022/acorex-components-conversation.mjs +21 -17
  17. package/fesm2022/acorex-components-conversation.mjs.map +1 -1
  18. package/fesm2022/acorex-components-range-slider.mjs +434 -8
  19. package/fesm2022/acorex-components-range-slider.mjs.map +1 -1
  20. package/package.json +36 -36
  21. package/range-slider/index.d.ts +2 -0
  22. package/range-slider/lib/range-slider.class.d.ts +8 -0
  23. package/range-slider/lib/range-slider.component.d.ts +98 -2
  24. package/range-slider/lib/range-slider.module.d.ts +1 -1
@@ -1,15 +1,438 @@
1
- import { Component } from '@angular/core';
1
+ import { AXValuableComponent, MXValueComponent, } from '@acorex/components/common';
2
+ import { ChangeDetectionStrategy, Component, HostBinding, NgZone, ViewEncapsulation, computed, effect, forwardRef, inject, input, model, output, } from '@angular/core';
3
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { classes } from 'polytype';
2
5
  import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
3
7
  /**
4
8
  * @category
5
9
  * Range slider for selecting a range of values.
6
10
  */
7
- export class AXRangeSliderComponent {
11
+ export class AXRangeSliderComponent extends classes((MXValueComponent)) {
12
+ //protected AXTooltip = computed(() => {});
13
+ constructor() {
14
+ super();
15
+ this.zone = inject(NgZone);
16
+ //outputs
17
+ this.onStart = output();
18
+ //inputs
19
+ this.orientation = input('horizontal');
20
+ this.color = input('primary');
21
+ this.values = model(this.value);
22
+ this.mode = input('single');
23
+ this.min = input(0);
24
+ this.max = input(100);
25
+ this.step = input(1);
26
+ this.snap = input(1);
27
+ this.tooltipMode = input('end');
28
+ this.snapMode = input('start');
29
+ this.hasSnap = input(false);
30
+ this.hasLable = input(this.hasSnap());
31
+ this.hasTooltip = input(false);
32
+ //computed
33
+ this.height = 0.25;
34
+ this.range = computed(() => this.max() - this.min());
35
+ this.isHorizontal = computed(() => this.orientation() === 'horizontal');
36
+ this.isDual = computed(() => this.mode() === 'dual');
37
+ this.calculateSnapBar = computed(() => {
38
+ if (this.hasSnap()) {
39
+ let array = [];
40
+ for (let i = this.min(); i < this.max(); i += this.snap()) {
41
+ array.push(i);
42
+ }
43
+ array = [...array, this.max()];
44
+ if (array[0] < 0) {
45
+ array = array.map((i) => i + -array[0]).sort((a, b) => a - b);
46
+ }
47
+ if (array[0] > 0) {
48
+ array = array.map((i) => i - array[0]).sort((a, b) => a - b);
49
+ }
50
+ return array;
51
+ }
52
+ else {
53
+ return undefined;
54
+ }
55
+ });
56
+ this.calculatePos = computed(() => {
57
+ if (this.isDual() && this.values()) {
58
+ return [
59
+ ((this.values()[0] - this.min()) / this.range()) * 100,
60
+ ((this.values()[1] - this.min()) / this.range()) * 100,
61
+ ];
62
+ }
63
+ else {
64
+ return ((this.values() - this.min()) / this.range()) * 100;
65
+ }
66
+ });
67
+ this.choosenHandler = undefined;
68
+ this.sliderElement = null;
69
+ this.AXRangeSliderHighlight = computed(() => this.isHorizontal()
70
+ ? {
71
+ left: this.isDual() ? this.calculatePos()[0] + '%' : this.min() + '%',
72
+ width: this.isDual()
73
+ ? this.calculatePos()[1] - this.calculatePos()[0] + '%'
74
+ : this.calculatePos() + '%',
75
+ }
76
+ : {
77
+ height: this.isDual()
78
+ ? this.calculatePos()[1] - this.calculatePos()[0] + '%'
79
+ : this.calculatePos() + '%',
80
+ top: this.mode() === 'dual' ? this.calculatePos()[0] + '%' : this.min() + '%',
81
+ });
82
+ this.AXRangeSliderHandler1 = computed(() => this.isHorizontal()
83
+ ? {
84
+ left: this.isDual() ? this.calculatePos()[0] + '%' : this.calculatePos() + '%',
85
+ }
86
+ : {
87
+ top: this.isDual() ? this.calculatePos()[0] + '%' : this.calculatePos() + '%',
88
+ });
89
+ this.AXRangeSliderHandler2 = computed(() => this.isHorizontal()
90
+ ? {
91
+ left: this.calculatePos()[1] + '%',
92
+ }
93
+ : {
94
+ top: this.calculatePos()[1] + '%',
95
+ });
96
+ this.AXRangeSliderStep = computed(() => {
97
+ if (this.isHorizontal()) {
98
+ switch (this.snapMode()) {
99
+ case 'both':
100
+ return { top: '0', height: 8 * this.height + 'rem' };
101
+ case 'start':
102
+ return { top: 4 * this.height + 'rem', height: 4 * this.height + 'rem' };
103
+ case 'end':
104
+ return { top: -2 * this.height + 'rem', height: 4 * this.height + 'rem' };
105
+ }
106
+ }
107
+ else {
108
+ switch (this.snapMode()) {
109
+ case 'both':
110
+ return { top: '0', width: 8 * this.height + 'rem' };
111
+ case 'start':
112
+ return { left: 4 * this.height + 'rem', width: 4 * this.height + 'rem' };
113
+ case 'end':
114
+ return { left: -2 * this.height + 'rem', width: 4 * this.height + 'rem' };
115
+ }
116
+ }
117
+ });
118
+ this.AXRangeLabel = computed(() => {
119
+ if (this.isHorizontal()) {
120
+ switch (this.snapMode()) {
121
+ case 'both':
122
+ return { top: 6 * this.height + 'rem' };
123
+ case 'start':
124
+ return { top: 4 * this.height + 'rem' };
125
+ case 'end':
126
+ return { top: -6 * this.height + 'rem' };
127
+ }
128
+ }
129
+ else {
130
+ switch (this.snapMode()) {
131
+ case 'both':
132
+ return { left: 8 * this.height + 'rem' };
133
+ case 'start':
134
+ return { left: 4 * this.height + 'rem' };
135
+ case 'end':
136
+ return { left: -8 * this.height + 'rem' };
137
+ }
138
+ }
139
+ });
140
+ effect(() => {
141
+ this.fixInitializeValues();
142
+ this.fixChangingMode();
143
+ }, { allowSignalWrites: true });
144
+ }
145
+ ngOnInit() {
146
+ super.ngOnInit();
147
+ this.initializeValues();
148
+ }
149
+ handleOnStart(event, circle) {
150
+ this.zone.runOutsideAngular(() => {
151
+ if (this.disabled)
152
+ return;
153
+ event.preventDefault();
154
+ this.sliderElement = event.target.closest('ax-range-slider');
155
+ if (this.sliderElement) {
156
+ this.choosenHandler = circle;
157
+ const moveListener = (moveEvent) => this.onMove(moveEvent, circle);
158
+ const endListener = () => this.onEnd(moveListener, endListener);
159
+ window.addEventListener('mousemove', moveListener);
160
+ window.addEventListener('mouseup', endListener);
161
+ window.addEventListener('touchmove', moveListener, { passive: true });
162
+ window.addEventListener('touchend', endListener);
163
+ }
164
+ });
165
+ }
166
+ onclickBar(event) {
167
+ this.sliderElement = event.target.closest('ax-range-slider');
168
+ this.zone.runOutsideAngular(() => {
169
+ if (!this.sliderElement || this.disabled)
170
+ return;
171
+ const clientX = event instanceof MouseEvent ? event.clientX : event.touches[0].clientX;
172
+ const sliderRect = this.sliderElement.getBoundingClientRect();
173
+ const clickPosition = ((clientX - sliderRect.left) / sliderRect.width) * 100;
174
+ let newValue = Math.round(this.min() + (clickPosition / 100) * (this.max() - this.min()));
175
+ newValue = this.calculateStep(newValue);
176
+ if (this.isDual()) {
177
+ if (clickPosition < this.calculatePos()[0]) {
178
+ this.values.set([newValue, this.values()[1]]);
179
+ this.commitValue(this.values());
180
+ }
181
+ else if (clickPosition > this.calculatePos()[1]) {
182
+ this.values.set([this.values()[0], newValue]);
183
+ this.commitValue(this.values());
184
+ }
185
+ }
186
+ else {
187
+ if (clickPosition > this.calculatePos()) {
188
+ this.values.set(newValue);
189
+ this.commitValue(this.values());
190
+ }
191
+ }
192
+ this.onStart.emit({
193
+ component: this,
194
+ htmlElement: event.target,
195
+ isUserInteraction: event.isTrusted,
196
+ data: this.values(),
197
+ });
198
+ });
199
+ }
200
+ onMove(event, circle) {
201
+ if (!this.sliderElement || this.readonly)
202
+ return;
203
+ const sliderRect = this.sliderElement.getBoundingClientRect();
204
+ let newValue;
205
+ if (this.isHorizontal()) {
206
+ const clientX = event instanceof MouseEvent ? event.clientX : event.touches[0].clientX;
207
+ let newLeft = ((clientX - sliderRect.left) / sliderRect.width) * 100;
208
+ newLeft = Math.max(0, Math.min(newLeft, 100));
209
+ newValue = Math.round(this.min() + (newLeft / 100) * (this.max() - this.min()));
210
+ }
211
+ else {
212
+ const clientY = event instanceof MouseEvent ? event.clientY : event.touches[0].clientY;
213
+ let newLeft = ((clientY - sliderRect.top) / sliderRect.height) * 100;
214
+ newLeft = Math.max(0, Math.min(newLeft, 100));
215
+ newValue = Math.round(this.min() + (newLeft / 100) * (this.max() - this.min()));
216
+ }
217
+ if (!this.readonly) {
218
+ if (this.isDual()) {
219
+ if (circle === 'first') {
220
+ newValue = Math.max(this.min(), Math.min(newValue, this.values()[1] - this.step()));
221
+ if (this.step() !== 1)
222
+ newValue = this.calculateStep(newValue);
223
+ if (this.values()[0] !== newValue) {
224
+ this.values.set([newValue, this.values()[1]]);
225
+ this.commitValue(this.values());
226
+ }
227
+ }
228
+ else {
229
+ newValue = Math.min(this.max(), Math.max(newValue, this.values()[0] + this.step()));
230
+ if (this.step() !== 1)
231
+ newValue = this.calculateStep(newValue);
232
+ if (this.values()[1] !== newValue) {
233
+ this.values.set([this.values()[0], newValue]);
234
+ this.commitValue(this.values());
235
+ }
236
+ }
237
+ }
238
+ else {
239
+ newValue = Math.max(this.min(), newValue);
240
+ if (this.step() !== 1)
241
+ newValue = this.calculateStep(newValue);
242
+ if (this.values() !== newValue) {
243
+ this.values.set(newValue);
244
+ this.commitValue(newValue);
245
+ }
246
+ }
247
+ }
248
+ }
249
+ onWheel(event) {
250
+ this.zone.runOutsideAngular(() => {
251
+ event.preventDefault();
252
+ if ((this.choosenHandler && this.mode() === 'single') || this.readonly)
253
+ return;
254
+ let newValue;
255
+ if (this.isDual()) {
256
+ if (event.deltaY < 0) {
257
+ if (this.choosenHandler === 'first') {
258
+ newValue = this.calculateStep(this.values()[0] + this.step());
259
+ if (this.checkValues(newValue, this.choosenHandler, this.values()[1]) &&
260
+ this.values()[0] !== newValue) {
261
+ this.values.update((old) => [this.calculateStep(old[0] + this.step()), old[1]]);
262
+ }
263
+ }
264
+ else {
265
+ newValue = this.calculateStep(this.values()[1] + this.step());
266
+ if (newValue <= this.max() && this.values()[1] !== newValue) {
267
+ this.values.update((old) => [old[0], this.calculateStep(old[1] + this.step())]);
268
+ }
269
+ }
270
+ }
271
+ else {
272
+ if (this.choosenHandler === 'first') {
273
+ newValue = this.calculateStep(this.values()[0] - this.step());
274
+ if (this.checkValues(newValue, this.choosenHandler, this.values()[1]) &&
275
+ this.values() !== newValue) {
276
+ this.values.update((old) => [this.calculateStep(old[0] - this.step()), old[1]]);
277
+ }
278
+ }
279
+ else {
280
+ newValue = this.calculateStep(this.values()[1] - this.step());
281
+ if (this.checkValues(newValue, this.choosenHandler, this.values()[0]) &&
282
+ this.values()[1] !== newValue) {
283
+ this.values.update((old) => [old[0], this.calculateStep(old[1] - this.step())]);
284
+ }
285
+ }
286
+ }
287
+ }
288
+ else {
289
+ if (event.deltaY < 0) {
290
+ if (this.checkValue(this.calculateStep(this.values() + this.step()))) {
291
+ this.values.update((old) => this.calculateStep(old + this.step()));
292
+ }
293
+ }
294
+ else {
295
+ if (this.checkValue(this.calculateStep(this.values() - this.step()))) {
296
+ this.values.update((old) => this.calculateStep(old - this.step()));
297
+ }
298
+ }
299
+ }
300
+ });
301
+ }
302
+ onEnd(moveListener, endListener) {
303
+ window.removeEventListener('mousemove', moveListener);
304
+ window.removeEventListener('mouseup', endListener);
305
+ window.removeEventListener('touchmove', moveListener);
306
+ window.removeEventListener('touchend', endListener);
307
+ this.sliderElement = null;
308
+ }
309
+ initializeValues() {
310
+ this.fixInitializeUndefined();
311
+ this.fixInitializeValues();
312
+ this.fixInitializeStep();
313
+ }
314
+ fixInitializeUndefined() {
315
+ if (typeof this.values() === 'undefined') {
316
+ if (this.isDual()) {
317
+ this.values.set([this.min(), this.max()]);
318
+ }
319
+ else {
320
+ this.values.set(this.min());
321
+ }
322
+ this.commitValue(this.values());
323
+ }
324
+ }
325
+ fixInitializeValues() {
326
+ //swap value
327
+ if (this.isDual() && this.values()[0] > this.values()[1]) {
328
+ this.values.set([this.values()[1], this.values()[0]]);
329
+ this.commitValue(this.values());
330
+ }
331
+ //not in range
332
+ if (typeof this.values() === 'number' && !this.checkValue(this.values())) {
333
+ this.values.set(this.min());
334
+ this.commitValue(this.values());
335
+ }
336
+ else if (typeof this.values() !== 'number' &&
337
+ !this.checkValues(this.values()[0], 'first', this.values()[1])) {
338
+ this.values.set([this.min(), this.max()]);
339
+ this.commitValue(this.values());
340
+ }
341
+ }
342
+ fixInitializeStep() {
343
+ if (this.step() !== 1) {
344
+ if (this.isDual()) {
345
+ this.values.update((old) => [this.calculateStep(old[0]), this.calculateStep(old[1])]);
346
+ this.commitValue(this.values());
347
+ if (this.values()[0] === this.values()[1]) {
348
+ this.values.update((old) => [this.calculateStep(old[0]), this.calculateStep(old[1]) + this.step()]);
349
+ this.commitValue(this.values());
350
+ }
351
+ }
352
+ else {
353
+ this.values.update((old) => this.calculateStep(old));
354
+ this.commitValue(this.values());
355
+ }
356
+ }
357
+ }
358
+ fixChangingMode() {
359
+ if (typeof this.values() === 'number' && this.isDual()) {
360
+ this.values.set([this.min(), this.max()]);
361
+ this.commitValue(this.values());
362
+ }
363
+ else if (typeof this.values() !== 'number' && !this.isDual()) {
364
+ this.values.set(this.min());
365
+ this.commitValue(this.values());
366
+ }
367
+ }
368
+ calculateStep(x) {
369
+ const roundedValue = Math.round(x / this.step()) * this.step();
370
+ if (roundedValue > this.max())
371
+ return this.max();
372
+ else if (roundedValue < this.min())
373
+ return this.min();
374
+ //else if (x >= this.min() && x < this.min() - (this.min() % this.step())) return this.min();
375
+ else if (x <= this.max() && x > this.max() - (this.max() % this.step()))
376
+ return this.max();
377
+ else
378
+ return roundedValue;
379
+ }
380
+ checkValue(x) {
381
+ if (x >= this.min() && x <= this.max())
382
+ return true;
383
+ else
384
+ return false;
385
+ }
386
+ checkValues(value1, y, value2) {
387
+ if (value1 >= this.min() && value1 <= this.max()) {
388
+ if (y === 'first') {
389
+ if (value1 < value2 && value2 <= this.max())
390
+ return true;
391
+ else
392
+ return false;
393
+ }
394
+ else {
395
+ if (value1 > value2 && value2 >= this.min())
396
+ return true;
397
+ else
398
+ return false;
399
+ }
400
+ }
401
+ else
402
+ return false;
403
+ }
404
+ getPercantage(value) {
405
+ return (value / this.range()) * 100;
406
+ }
407
+ get __hostClass() {
408
+ return [
409
+ `ax-${this.color()}-solid`,
410
+ `${this.disabled ? 'ax-state-disabled' : ''}`,
411
+ `${this.readonly ? 'ax-state-readonly' : ''}`,
412
+ ];
413
+ }
8
414
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXRangeSliderComponent, selector: "ax-range-slider", ngImport: i0, template: "<p>test</p>", styles: [""] }); }
415
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXRangeSliderComponent, selector: "ax-range-slider", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: false, isRequired: false, transformFunction: null }, orientation: { classPropertyName: "orientation", publicName: "orientation", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, values: { classPropertyName: "values", publicName: "values", isSignal: true, isRequired: false, transformFunction: null }, 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 }, step: { classPropertyName: "step", publicName: "step", isSignal: true, isRequired: false, transformFunction: null }, snap: { classPropertyName: "snap", publicName: "snap", isSignal: true, isRequired: false, transformFunction: null }, tooltipMode: { classPropertyName: "tooltipMode", publicName: "tooltipMode", isSignal: true, isRequired: false, transformFunction: null }, snapMode: { classPropertyName: "snapMode", publicName: "snapMode", isSignal: true, isRequired: false, transformFunction: null }, hasSnap: { classPropertyName: "hasSnap", publicName: "hasSnap", isSignal: true, isRequired: false, transformFunction: null }, hasLable: { classPropertyName: "hasLable", publicName: "hasLable", isSignal: true, isRequired: false, transformFunction: null }, hasTooltip: { classPropertyName: "hasTooltip", publicName: "hasTooltip", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onStart: "onStart", values: "valuesChange" }, host: { properties: { "class": "this.__hostClass" } }, providers: [
416
+ { provide: AXValuableComponent, useExisting: AXRangeSliderComponent },
417
+ {
418
+ provide: NG_VALUE_ACCESSOR,
419
+ useExisting: forwardRef(() => AXRangeSliderComponent),
420
+ multi: true,
421
+ },
422
+ ], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-range-slider\" (wheel)=\"onWheel($event)\" [class]=\"'ax-orientation-' + orientation()\">\n <div class=\"ax-range-slider-bar\" (mousedown)=\"onclickBar($event)\" (touchstart)=\"onclickBar($event)\"></div>\n <div class=\"ax-range-slider-highlight\" [ngStyle]=\"AXRangeSliderHighlight()\"></div>\n\n <div\n class=\"ax-range-slider-handler\"\n [ngStyle]=\"AXRangeSliderHandler1()\"\n (mousedown)=\"handleOnStart($event, 'first')\"\n (touchstart)=\"handleOnStart($event, 'first')\"\n >\n @if (hasTooltip()) {\n <div class=\"ax-range-slider-tooltip\">{{ isDual() ? values()[0] : values() }}</div>\n }\n </div>\n\n @if (isDual()) {\n <div\n class=\"ax-range-slider-handler\"\n [ngStyle]=\"AXRangeSliderHandler2()\"\n (mousedown)=\"handleOnStart($event, 'second')\"\n (touchstart)=\"handleOnStart($event, 'second')\"\n >\n @if (hasTooltip()) {\n <div class=\"ax-range-slider-tooltip\">{{ values()[1] }}</div>\n }\n </div>\n }\n @if (hasSnap()) {\n <div class=\"ax-range-slider-step\" [ngStyle]=\"AXRangeSliderStep()\">\n @for (item of calculateSnapBar(); track $index) {\n <div\n class=\"ax-range-slider-steps\"\n [ngStyle]=\"\n isHorizontal() ? { left: getPercantage(item) + '%' } : { top: getPercantage(item) + '%' }\n \"\n >\n @if (hasLable()) {\n <div class=\"ax-range-slider-label\" [ngStyle]=\"AXRangeLabel()\">\n {{ item + min() }}\n </div>\n }\n </div>\n }\n </div>\n }\n</div>\n", styles: [":root{--ax-range-slider-base-thickness: .25rem}ax-range-slider{display:flex;align-items:center;justify-content:center;font-size:small}ax-range-slider .ax-range-slider.ax-orientation-horizontal{position:relative;width:100%;height:calc(var(--ax-range-slider-base-thickness) * 4)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-bar{position:absolute;top:50%;left:0;width:100.1%;height:var(--ax-range-slider-base-thickness);transform:translateY(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-bg));cursor:pointer}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-highlight{position:absolute;top:50%;height:calc(var(--ax-range-slider-base-thickness) * 3 / 2);transform:translateY(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-fg))}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-handler{position:absolute;top:50%;width:calc(var(--ax-range-slider-base-thickness) * 6);height:calc(var(--ax-range-slider-base-thickness) * 6);z-index:20;background-color:rgb(var(--ax-range-slider-fg));border-radius:50%;cursor:pointer;transform:translate(-50%,-50%);transition:box-shadow .1s linear}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-handler:hover{box-shadow:var(--tw-ring-inset) 0 0 0 calc(.6rem + var(--tw-ring-offset-width)) rgba(var(--ax-range-slider-fg),.25)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-handler:active{box-shadow:var(--tw-ring-inset) 0 0 0 calc(.6rem + var(--tw-ring-offset-width)) rgba(var(--ax-range-slider-fg),.25)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-tooltip{position:absolute;left:calc(var(--ax-range-slider-base-thickness) * 2.8);top:calc(var(--ax-range-slider-base-thickness) * -2);background-color:rgb(var(--ax-range-slider-fg));color:rgb(var(--ax-range-tooltip-text));padding:5px 10px;border-radius:3px;white-space:nowrap;transform:translate(-50%,-125%)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-tooltip:after{content:\"\";position:absolute;top:calc(var(--ax-range-slider-base-thickness) * 7);left:50%;transform:translate(-50%);border-width:.5rem;border-style:solid;border-color:rgb(var(--ax-range-slider-fg)) transparent transparent transparent}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-step{position:absolute;display:flex;flex-direction:row;width:100%;z-index:10}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-step .ax-range-slider-steps{position:absolute;border-left:calc(var(--ax-range-slider-base-thickness) / 2) solid rgb(var(--ax-color-border-default));height:50%}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-step .ax-range-slider-steps .ax-range-slider-label{position:relative;text-align:center;top:calc(var(--ax-range-slider-base-thickness) * 2);left:-50%}ax-range-slider .ax-range-slider.ax-orientation-vertical{position:relative;width:calc(var(--ax-range-slider-base-thickness) * 4);height:100%}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-bar{position:absolute;top:0;left:50%;width:var(--ax-range-slider-base-thickness);height:100.1%;transform:translate(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-bg));cursor:pointer}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-highlight{position:absolute;left:50%;width:calc(var(--ax-range-slider-base-thickness) * 3 / 2);transform:translate(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-fg))}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-handler{position:absolute;left:50%;width:calc(var(--ax-range-slider-base-thickness) * 6);height:calc(var(--ax-range-slider-base-thickness) * 6);z-index:20;background-color:rgb(var(--ax-range-slider-fg));border-radius:50%;cursor:pointer;transform:translate(-50%,-50%);transition:background-color .2s ease}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-handler:active{border:1px solid transparent;box-shadow:var(--tw-ring-inset) 0 0 0 calc(.5rem + var(--tw-ring-offset-width)) rgba(var(--ax-range-slider-fg),.25)}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-tooltip{position:absolute;top:calc(var(--ax-range-slider-base-thickness) * 8.5);left:calc(var(--ax-range-slider-base-thickness) * -8);background-color:rgb(var(--ax-range-slider-fg));color:rgb(var(--ax-range-tooltip-text));padding:5px 10px;border-radius:3px;white-space:nowrap;transform:translate(-50%,-125%)}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-tooltip:after{content:\"\";position:absolute;top:50%;left:97%;transform:translateY(-50%);border-width:.5rem;border-style:solid;border-color:transparent transparent transparent rgb(var(--ax-range-slider-fg))}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-step{position:absolute;display:flex;flex-direction:column;height:100%;z-index:10}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-step .ax-range-slider-steps{position:absolute;width:50%;border-top:calc(var(--ax-range-slider-base-thickness) / 2) solid rgb(var(--ax-color-border-default))}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-step .ax-range-slider-steps .ax-range-slider-label{position:absolute;left:150%;top:calc(var(--ax-range-slider-base-thickness) * -3)}ax-range-slider.ax-primary-solid{--ax-range-slider-bg: var(--ax-color-primary-200);--ax-range-slider-fg: var(--ax-color-primary-500);--ax-range-tooltip-text: var(--ax-color-primary-fore)}ax-range-slider.ax-secondary-solid{--ax-range-slider-bg: var(--ax-color-secondary-200);--ax-range-slider-fg: var(--ax-color-secondary-500);--ax-range-tooltip-text: var(--ax-color-secondary-fore)}ax-range-slider.ax-success-solid{--ax-range-slider-bg: var(--ax-color-success-200);--ax-range-slider-fg: var(--ax-color-success-500);--ax-range-tooltip-text: var(--ax-color-success-fore)}ax-range-slider.ax-warning-solid{--ax-range-slider-bg: var(--ax-color-warning-200);--ax-range-slider-fg: var(--ax-color-warning-500);--ax-range-tooltip-text: var(--ax-color-warning-fore)}ax-range-slider.ax-danger-solid{--ax-range-slider-bg: var(--ax-color-danger-200);--ax-range-slider-fg: var(--ax-color-danger-500);--ax-range-tooltip-text: var(--ax-color-danger-fore)}ax-range-slider.ax-info-solid{--ax-range-slider-bg: var(--ax-color-info-200);--ax-range-slider-fg: var(--ax-color-info-500);--ax-range-tooltip-text: var(--ax-color-info-fore)}ax-range-slider.ax-state-disabled{opacity:.5;cursor:not-allowed}ax-range-slider.ax-state-readonly{opacity:.75}.ax-dark ax-range-slider.ax-primary-solid{--ax-range-slider-bg: var(--ax-color-primary-700);--ax-range-slider-fg: var(--ax-color-primary-200);--ax-range-tooltip-text: var(--ax-color-primary-fore-tint)}.ax-dark ax-range-slider.ax-secondary-solid{--ax-range-slider-bg: var(--ax-color-secondary-700);--ax-range-slider-fg: var(--ax-color-secondary-200);--ax-range-tooltip-text: var(--ax-color-secondary-fore-tint)}.ax-dark ax-range-slider.ax-success-solid{--ax-range-slider-bg: var(--ax-color-success-700);--ax-range-slider-fg: var(--ax-color-success-200);--ax-range-tooltip-text: var(--ax-color-success-fore-tint)}.ax-dark ax-range-slider.ax-warning-solid{--ax-range-slider-bg: var(--ax-color-warning-700);--ax-range-slider-fg: var(--ax-color-warning-200);--ax-range-tooltip-text: var(--ax-color-warning-fore-tint)}.ax-dark ax-range-slider.ax-danger-solid{--ax-range-slider-bg: var(--ax-color-danger-700);--ax-range-slider-fg: var(--ax-color-danger-200);--ax-range-tooltip-text: var(--ax-color-danger-fore-tint)}.ax-dark ax-range-slider.ax-info-solid{--ax-range-slider-bg: var(--ax-color-info-700);--ax-range-slider-fg: var(--ax-color-info-200);--ax-range-tooltip-text: var(--ax-color-info-fore-tint)}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
10
423
  }
11
424
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderComponent, decorators: [{
12
425
  type: Component,
13
- args: [{ selector: 'ax-range-slider', template: "<p>test</p>" }]
14
- }] });
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2Utc2xpZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9yYW5nZS1zbGlkZXIvc3JjL2xpYi9yYW5nZS1zbGlkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3JhbmdlLXNsaWRlci9zcmMvbGliL3JhbmdlLXNsaWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUxQzs7O0dBR0c7QUFNSCxNQUFNLE9BQU8sc0JBQXNCOzhHQUF0QixzQkFBc0I7a0dBQXRCLHNCQUFzQix1RENYbkMsYUFBVzs7MkZEV0Usc0JBQXNCO2tCQUxsQyxTQUFTOytCQUNFLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBjYXRlZ29yeVxuICogUmFuZ2Ugc2xpZGVyIGZvciBzZWxlY3RpbmcgYSByYW5nZSBvZiB2YWx1ZXMuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F4LXJhbmdlLXNsaWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9yYW5nZS1zbGlkZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9yYW5nZS1zbGlkZXIuY29tcG9uZW50LnNhc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQVhSYW5nZVNsaWRlckNvbXBvbmVudCB7fVxuIiwiPHA+dGVzdDwvcD4iXX0=
426
+ args: [{ selector: 'ax-range-slider', inputs: ['disabled', 'readonly'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
427
+ { provide: AXValuableComponent, useExisting: AXRangeSliderComponent },
428
+ {
429
+ provide: NG_VALUE_ACCESSOR,
430
+ useExisting: forwardRef(() => AXRangeSliderComponent),
431
+ multi: true,
432
+ },
433
+ ], template: "<div class=\"ax-range-slider\" (wheel)=\"onWheel($event)\" [class]=\"'ax-orientation-' + orientation()\">\n <div class=\"ax-range-slider-bar\" (mousedown)=\"onclickBar($event)\" (touchstart)=\"onclickBar($event)\"></div>\n <div class=\"ax-range-slider-highlight\" [ngStyle]=\"AXRangeSliderHighlight()\"></div>\n\n <div\n class=\"ax-range-slider-handler\"\n [ngStyle]=\"AXRangeSliderHandler1()\"\n (mousedown)=\"handleOnStart($event, 'first')\"\n (touchstart)=\"handleOnStart($event, 'first')\"\n >\n @if (hasTooltip()) {\n <div class=\"ax-range-slider-tooltip\">{{ isDual() ? values()[0] : values() }}</div>\n }\n </div>\n\n @if (isDual()) {\n <div\n class=\"ax-range-slider-handler\"\n [ngStyle]=\"AXRangeSliderHandler2()\"\n (mousedown)=\"handleOnStart($event, 'second')\"\n (touchstart)=\"handleOnStart($event, 'second')\"\n >\n @if (hasTooltip()) {\n <div class=\"ax-range-slider-tooltip\">{{ values()[1] }}</div>\n }\n </div>\n }\n @if (hasSnap()) {\n <div class=\"ax-range-slider-step\" [ngStyle]=\"AXRangeSliderStep()\">\n @for (item of calculateSnapBar(); track $index) {\n <div\n class=\"ax-range-slider-steps\"\n [ngStyle]=\"\n isHorizontal() ? { left: getPercantage(item) + '%' } : { top: getPercantage(item) + '%' }\n \"\n >\n @if (hasLable()) {\n <div class=\"ax-range-slider-label\" [ngStyle]=\"AXRangeLabel()\">\n {{ item + min() }}\n </div>\n }\n </div>\n }\n </div>\n }\n</div>\n", styles: [":root{--ax-range-slider-base-thickness: .25rem}ax-range-slider{display:flex;align-items:center;justify-content:center;font-size:small}ax-range-slider .ax-range-slider.ax-orientation-horizontal{position:relative;width:100%;height:calc(var(--ax-range-slider-base-thickness) * 4)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-bar{position:absolute;top:50%;left:0;width:100.1%;height:var(--ax-range-slider-base-thickness);transform:translateY(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-bg));cursor:pointer}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-highlight{position:absolute;top:50%;height:calc(var(--ax-range-slider-base-thickness) * 3 / 2);transform:translateY(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-fg))}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-handler{position:absolute;top:50%;width:calc(var(--ax-range-slider-base-thickness) * 6);height:calc(var(--ax-range-slider-base-thickness) * 6);z-index:20;background-color:rgb(var(--ax-range-slider-fg));border-radius:50%;cursor:pointer;transform:translate(-50%,-50%);transition:box-shadow .1s linear}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-handler:hover{box-shadow:var(--tw-ring-inset) 0 0 0 calc(.6rem + var(--tw-ring-offset-width)) rgba(var(--ax-range-slider-fg),.25)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-handler:active{box-shadow:var(--tw-ring-inset) 0 0 0 calc(.6rem + var(--tw-ring-offset-width)) rgba(var(--ax-range-slider-fg),.25)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-tooltip{position:absolute;left:calc(var(--ax-range-slider-base-thickness) * 2.8);top:calc(var(--ax-range-slider-base-thickness) * -2);background-color:rgb(var(--ax-range-slider-fg));color:rgb(var(--ax-range-tooltip-text));padding:5px 10px;border-radius:3px;white-space:nowrap;transform:translate(-50%,-125%)}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-tooltip:after{content:\"\";position:absolute;top:calc(var(--ax-range-slider-base-thickness) * 7);left:50%;transform:translate(-50%);border-width:.5rem;border-style:solid;border-color:rgb(var(--ax-range-slider-fg)) transparent transparent transparent}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-step{position:absolute;display:flex;flex-direction:row;width:100%;z-index:10}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-step .ax-range-slider-steps{position:absolute;border-left:calc(var(--ax-range-slider-base-thickness) / 2) solid rgb(var(--ax-color-border-default));height:50%}ax-range-slider .ax-range-slider.ax-orientation-horizontal .ax-range-slider-step .ax-range-slider-steps .ax-range-slider-label{position:relative;text-align:center;top:calc(var(--ax-range-slider-base-thickness) * 2);left:-50%}ax-range-slider .ax-range-slider.ax-orientation-vertical{position:relative;width:calc(var(--ax-range-slider-base-thickness) * 4);height:100%}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-bar{position:absolute;top:0;left:50%;width:var(--ax-range-slider-base-thickness);height:100.1%;transform:translate(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-bg));cursor:pointer}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-highlight{position:absolute;left:50%;width:calc(var(--ax-range-slider-base-thickness) * 3 / 2);transform:translate(-50%);z-index:20;border-radius:9999rem;background-color:rgb(var(--ax-range-slider-fg))}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-handler{position:absolute;left:50%;width:calc(var(--ax-range-slider-base-thickness) * 6);height:calc(var(--ax-range-slider-base-thickness) * 6);z-index:20;background-color:rgb(var(--ax-range-slider-fg));border-radius:50%;cursor:pointer;transform:translate(-50%,-50%);transition:background-color .2s ease}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-handler:active{border:1px solid transparent;box-shadow:var(--tw-ring-inset) 0 0 0 calc(.5rem + var(--tw-ring-offset-width)) rgba(var(--ax-range-slider-fg),.25)}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-tooltip{position:absolute;top:calc(var(--ax-range-slider-base-thickness) * 8.5);left:calc(var(--ax-range-slider-base-thickness) * -8);background-color:rgb(var(--ax-range-slider-fg));color:rgb(var(--ax-range-tooltip-text));padding:5px 10px;border-radius:3px;white-space:nowrap;transform:translate(-50%,-125%)}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-tooltip:after{content:\"\";position:absolute;top:50%;left:97%;transform:translateY(-50%);border-width:.5rem;border-style:solid;border-color:transparent transparent transparent rgb(var(--ax-range-slider-fg))}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-step{position:absolute;display:flex;flex-direction:column;height:100%;z-index:10}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-step .ax-range-slider-steps{position:absolute;width:50%;border-top:calc(var(--ax-range-slider-base-thickness) / 2) solid rgb(var(--ax-color-border-default))}ax-range-slider .ax-range-slider.ax-orientation-vertical .ax-range-slider-step .ax-range-slider-steps .ax-range-slider-label{position:absolute;left:150%;top:calc(var(--ax-range-slider-base-thickness) * -3)}ax-range-slider.ax-primary-solid{--ax-range-slider-bg: var(--ax-color-primary-200);--ax-range-slider-fg: var(--ax-color-primary-500);--ax-range-tooltip-text: var(--ax-color-primary-fore)}ax-range-slider.ax-secondary-solid{--ax-range-slider-bg: var(--ax-color-secondary-200);--ax-range-slider-fg: var(--ax-color-secondary-500);--ax-range-tooltip-text: var(--ax-color-secondary-fore)}ax-range-slider.ax-success-solid{--ax-range-slider-bg: var(--ax-color-success-200);--ax-range-slider-fg: var(--ax-color-success-500);--ax-range-tooltip-text: var(--ax-color-success-fore)}ax-range-slider.ax-warning-solid{--ax-range-slider-bg: var(--ax-color-warning-200);--ax-range-slider-fg: var(--ax-color-warning-500);--ax-range-tooltip-text: var(--ax-color-warning-fore)}ax-range-slider.ax-danger-solid{--ax-range-slider-bg: var(--ax-color-danger-200);--ax-range-slider-fg: var(--ax-color-danger-500);--ax-range-tooltip-text: var(--ax-color-danger-fore)}ax-range-slider.ax-info-solid{--ax-range-slider-bg: var(--ax-color-info-200);--ax-range-slider-fg: var(--ax-color-info-500);--ax-range-tooltip-text: var(--ax-color-info-fore)}ax-range-slider.ax-state-disabled{opacity:.5;cursor:not-allowed}ax-range-slider.ax-state-readonly{opacity:.75}.ax-dark ax-range-slider.ax-primary-solid{--ax-range-slider-bg: var(--ax-color-primary-700);--ax-range-slider-fg: var(--ax-color-primary-200);--ax-range-tooltip-text: var(--ax-color-primary-fore-tint)}.ax-dark ax-range-slider.ax-secondary-solid{--ax-range-slider-bg: var(--ax-color-secondary-700);--ax-range-slider-fg: var(--ax-color-secondary-200);--ax-range-tooltip-text: var(--ax-color-secondary-fore-tint)}.ax-dark ax-range-slider.ax-success-solid{--ax-range-slider-bg: var(--ax-color-success-700);--ax-range-slider-fg: var(--ax-color-success-200);--ax-range-tooltip-text: var(--ax-color-success-fore-tint)}.ax-dark ax-range-slider.ax-warning-solid{--ax-range-slider-bg: var(--ax-color-warning-700);--ax-range-slider-fg: var(--ax-color-warning-200);--ax-range-tooltip-text: var(--ax-color-warning-fore-tint)}.ax-dark ax-range-slider.ax-danger-solid{--ax-range-slider-bg: var(--ax-color-danger-700);--ax-range-slider-fg: var(--ax-color-danger-200);--ax-range-tooltip-text: var(--ax-color-danger-fore-tint)}.ax-dark ax-range-slider.ax-info-solid{--ax-range-slider-bg: var(--ax-color-info-700);--ax-range-slider-fg: var(--ax-color-info-200);--ax-range-tooltip-text: var(--ax-color-info-fore-tint)}\n"] }]
434
+ }], ctorParameters: () => [], propDecorators: { __hostClass: [{
435
+ type: HostBinding,
436
+ args: ['class']
437
+ }] } });
438
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-slider.component.js","sourceRoot":"","sources":["../../../../../../libs/components/range-slider/src/lib/range-slider.component.ts","../../../../../../libs/components/range-slider/src/lib/range-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AXOrientation,\n  AXStyleColorType,\n  AXValuableComponent,\n  MXValueComponent,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  NgZone,\n  ViewEncapsulation,\n  computed,\n  effect,\n  forwardRef,\n  inject,\n  input,\n  model,\n  output,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { classes } from 'polytype';\nimport {\n  AXRangeSliderMode,\n  AXRangeSliderSnapMode,\n  AXRangeSliderTooltipMode,\n  AXRangeSliderValue,\n  AXRangeStartEvent,\n} from './range-slider.class';\n\n/**\n * @category\n * Range slider for selecting a range of values.\n */\n@Component({\n  selector: 'ax-range-slider',\n  templateUrl: './range-slider.component.html',\n  styleUrls: ['./range-slider.component.scss'],\n  inputs: ['disabled', 'readonly'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: AXValuableComponent, useExisting: AXRangeSliderComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXRangeSliderComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXRangeSliderComponent extends classes(MXValueComponent<AXRangeSliderValue>) {\n  private zone = inject(NgZone);\n  //outputs\n  onStart = output<AXRangeStartEvent>();\n  //inputs\n  orientation = input<AXOrientation>('horizontal');\n  color = input<AXStyleColorType>('primary');\n  values = model<AXRangeSliderValue>(this.value);\n  mode = input<AXRangeSliderMode>('single');\n  min = input<number>(0);\n  max = input<number>(100);\n  step = input<number>(1);\n  snap = input<number>(1);\n  tooltipMode = input<AXRangeSliderTooltipMode>('end');\n  snapMode = input<AXRangeSliderSnapMode>('start');\n  hasSnap = input(false);\n  hasLable = input(this.hasSnap());\n  hasTooltip = input(false);\n  //computed\n  height = 0.25;\n  range = computed(() => this.max() - this.min());\n  isHorizontal = computed(() => this.orientation() === 'horizontal');\n  isDual = computed(() => this.mode() === 'dual');\n\n  calculateSnapBar = computed(() => {\n    if (this.hasSnap()) {\n      let array = [];\n      for (let i = this.min(); i < this.max(); i += this.snap()) {\n        array.push(i);\n      }\n      array = [...array, this.max()];\n      if (array[0] < 0) {\n        array = array.map((i) => i + -array[0]).sort((a, b) => a - b);\n      }\n      if (array[0] > 0) {\n        array = array.map((i) => i - array[0]).sort((a, b) => a - b);\n      }\n      return array;\n    } else {\n      return undefined;\n    }\n  });\n  calculatePos = computed<AXRangeSliderValue>(() => {\n    if (this.isDual() && this.values()) {\n      return [\n        ((this.values()[0] - this.min()) / this.range()) * 100,\n        ((this.values()[1] - this.min()) / this.range()) * 100,\n      ];\n    } else {\n      return (((this.values() as number) - this.min()) / this.range()) * 100;\n    }\n  });\n\n  private choosenHandler: 'first' | 'second' | undefined = undefined;\n\n  private sliderElement: HTMLElement | null = null;\n\n  protected AXRangeSliderHighlight = computed(() =>\n    this.isHorizontal()\n      ? {\n          left: this.isDual() ? this.calculatePos()[0] + '%' : this.min() + '%',\n          width: this.isDual()\n            ? this.calculatePos()[1] - this.calculatePos()[0] + '%'\n            : this.calculatePos() + '%',\n        }\n      : {\n          height: this.isDual()\n            ? this.calculatePos()[1] - this.calculatePos()[0] + '%'\n            : this.calculatePos() + '%',\n          top: this.mode() === 'dual' ? this.calculatePos()[0] + '%' : this.min() + '%',\n        },\n  );\n  protected AXRangeSliderHandler1 = computed(() =>\n    this.isHorizontal()\n      ? {\n          left: this.isDual() ? this.calculatePos()[0] + '%' : this.calculatePos() + '%',\n        }\n      : {\n          top: this.isDual() ? this.calculatePos()[0] + '%' : this.calculatePos() + '%',\n        },\n  );\n  protected AXRangeSliderHandler2 = computed(() =>\n    this.isHorizontal()\n      ? {\n          left: this.calculatePos()[1] + '%',\n        }\n      : {\n          top: this.calculatePos()[1] + '%',\n        },\n  );\n  protected AXRangeSliderStep = computed(() => {\n    if (this.isHorizontal()) {\n      switch (this.snapMode()) {\n        case 'both':\n          return { top: '0', height: 8 * this.height + 'rem' };\n        case 'start':\n          return { top: 4 * this.height + 'rem', height: 4 * this.height + 'rem' };\n        case 'end':\n          return { top: -2 * this.height + 'rem', height: 4 * this.height + 'rem' };\n      }\n    } else {\n      switch (this.snapMode()) {\n        case 'both':\n          return { top: '0', width: 8 * this.height + 'rem' };\n        case 'start':\n          return { left: 4 * this.height + 'rem', width: 4 * this.height + 'rem' };\n        case 'end':\n          return { left: -2 * this.height + 'rem', width: 4 * this.height + 'rem' };\n      }\n    }\n  });\n  protected AXRangeLabel = computed(() => {\n    if (this.isHorizontal()) {\n      switch (this.snapMode()) {\n        case 'both':\n          return { top: 6 * this.height + 'rem' };\n        case 'start':\n          return { top: 4 * this.height + 'rem' };\n        case 'end':\n          return { top: -6 * this.height + 'rem' };\n      }\n    } else {\n      switch (this.snapMode()) {\n        case 'both':\n          return { left: 8 * this.height + 'rem' };\n        case 'start':\n          return { left: 4 * this.height + 'rem' };\n        case 'end':\n          return { left: -8 * this.height + 'rem' };\n      }\n    }\n  });\n  //protected AXTooltip = computed(() => {});\n  constructor() {\n    super();\n    effect(\n      () => {\n        this.fixInitializeValues();\n        this.fixChangingMode();\n      },\n      { allowSignalWrites: true },\n    );\n  }\n\n  protected override ngOnInit(): void {\n    super.ngOnInit();\n    this.initializeValues();\n  }\n\n  handleOnStart(event: MouseEvent | TouchEvent, circle: 'first' | 'second'): void {\n    this.zone.runOutsideAngular(() => {\n      if (this.disabled) return;\n      event.preventDefault();\n      this.sliderElement = (event.target as HTMLElement).closest('ax-range-slider') as HTMLElement;\n      if (this.sliderElement) {\n        this.choosenHandler = circle;\n        const moveListener = (moveEvent: MouseEvent | TouchEvent) => this.onMove(moveEvent, circle);\n        const endListener = () => this.onEnd(moveListener, endListener);\n        window.addEventListener('mousemove', moveListener);\n        window.addEventListener('mouseup', endListener);\n        window.addEventListener('touchmove', moveListener, { passive: true });\n        window.addEventListener('touchend', endListener);\n      }\n    });\n  }\n  onclickBar(event: MouseEvent | TouchEvent) {\n    this.sliderElement = (event.target as HTMLElement).closest('ax-range-slider') as HTMLElement;\n    this.zone.runOutsideAngular(() => {\n      if (!this.sliderElement || this.disabled) return;\n      const clientX = event instanceof MouseEvent ? event.clientX : (event as TouchEvent).touches[0].clientX;\n      const sliderRect = this.sliderElement.getBoundingClientRect();\n      const clickPosition = ((clientX - sliderRect.left) / sliderRect.width) * 100;\n      let newValue = Math.round(this.min() + (clickPosition / 100) * (this.max() - this.min()));\n      newValue = this.calculateStep(newValue);\n      if (this.isDual()) {\n        if (clickPosition < this.calculatePos()[0]) {\n          this.values.set([newValue, this.values()[1]]);\n          this.commitValue(this.values());\n        } else if (clickPosition > this.calculatePos()[1]) {\n          this.values.set([this.values()[0], newValue]);\n          this.commitValue(this.values());\n        }\n      } else {\n        if (clickPosition > (this.calculatePos() as number)) {\n          this.values.set(newValue);\n          this.commitValue(this.values());\n        }\n      }\n      this.onStart.emit({\n        component: this,\n        htmlElement: event.target as HTMLElement,\n        isUserInteraction: event.isTrusted,\n        data: this.values(),\n      });\n    });\n  }\n  onMove(event: MouseEvent | TouchEvent, circle: 'first' | 'second'): void {\n    if (!this.sliderElement || this.readonly) return;\n    const sliderRect = this.sliderElement.getBoundingClientRect();\n    let newValue: number;\n    if (this.isHorizontal()) {\n      const clientX = event instanceof MouseEvent ? event.clientX : (event as TouchEvent).touches[0].clientX;\n      let newLeft = ((clientX - sliderRect.left) / sliderRect.width) * 100;\n      newLeft = Math.max(0, Math.min(newLeft, 100));\n      newValue = Math.round(this.min() + (newLeft / 100) * (this.max() - this.min()));\n    } else {\n      const clientY = event instanceof MouseEvent ? event.clientY : (event as TouchEvent).touches[0].clientY;\n      let newLeft = ((clientY - sliderRect.top) / sliderRect.height) * 100;\n      newLeft = Math.max(0, Math.min(newLeft, 100));\n      newValue = Math.round(this.min() + (newLeft / 100) * (this.max() - this.min()));\n    }\n    if (!this.readonly) {\n      if (this.isDual()) {\n        if (circle === 'first') {\n          newValue = Math.max(this.min(), Math.min(newValue, this.values()[1] - this.step()));\n          if (this.step() !== 1) newValue = this.calculateStep(newValue);\n          if (this.values()[0] !== newValue) {\n            this.values.set([newValue, this.values()[1]]);\n            this.commitValue(this.values());\n          }\n        } else {\n          newValue = Math.min(this.max(), Math.max(newValue, this.values()[0] + this.step()));\n          if (this.step() !== 1) newValue = this.calculateStep(newValue);\n          if (this.values()[1] !== newValue) {\n            this.values.set([this.values()[0], newValue]);\n            this.commitValue(this.values());\n          }\n        }\n      } else {\n        newValue = Math.max(this.min(), newValue);\n        if (this.step() !== 1) newValue = this.calculateStep(newValue);\n        if (this.values() !== newValue) {\n          this.values.set(newValue);\n          this.commitValue(newValue);\n        }\n      }\n    }\n  }\n  onWheel(event: WheelEvent) {\n    this.zone.runOutsideAngular(() => {\n      event.preventDefault();\n      if ((this.choosenHandler && this.mode() === 'single') || this.readonly) return;\n      let newValue;\n      if (this.isDual()) {\n        if (event.deltaY < 0) {\n          if (this.choosenHandler === 'first') {\n            newValue = this.calculateStep((this.values()[0] as number) + this.step());\n            if (\n              this.checkValues(newValue, this.choosenHandler, this.values()[1]) &&\n              this.values()[0] !== newValue\n            ) {\n              this.values.update((old) => [this.calculateStep((old[0] as number) + this.step()), old[1]]);\n            }\n          } else {\n            newValue = this.calculateStep((this.values()[1] as number) + this.step());\n            if (newValue <= this.max() && this.values()[1] !== newValue) {\n              this.values.update((old) => [old[0], this.calculateStep((old[1] as number) + this.step())]);\n            }\n          }\n        } else {\n          if (this.choosenHandler === 'first') {\n            newValue = this.calculateStep((this.values()[0] as number) - this.step());\n            if (\n              this.checkValues(newValue, this.choosenHandler, this.values()[1]) &&\n              this.values() !== newValue\n            ) {\n              this.values.update((old) => [this.calculateStep((old[0] as number) - this.step()), old[1]]);\n            }\n          } else {\n            newValue = this.calculateStep((this.values()[1] as number) - this.step());\n            if (\n              this.checkValues(newValue, this.choosenHandler, this.values()[0]) &&\n              this.values()[1] !== newValue\n            ) {\n              this.values.update((old) => [old[0], this.calculateStep((old[1] as number) - this.step())]);\n            }\n          }\n        }\n      } else {\n        if (event.deltaY < 0) {\n          if (this.checkValue(this.calculateStep((this.values() as number) + this.step()))) {\n            this.values.update((old) => this.calculateStep((old as number) + this.step()));\n          }\n        } else {\n          if (this.checkValue(this.calculateStep((this.values() as number) - this.step()))) {\n            this.values.update((old) => this.calculateStep((old as number) - this.step()));\n          }\n        }\n      }\n    });\n  }\n  onEnd(moveListener: (event: MouseEvent | TouchEvent) => void, endListener: () => void): void {\n    window.removeEventListener('mousemove', moveListener);\n    window.removeEventListener('mouseup', endListener);\n    window.removeEventListener('touchmove', moveListener);\n    window.removeEventListener('touchend', endListener);\n    this.sliderElement = null;\n  }\n\n  initializeValues() {\n    this.fixInitializeUndefined();\n    this.fixInitializeValues();\n    this.fixInitializeStep();\n  }\n  fixInitializeUndefined() {\n    if (typeof this.values() === 'undefined') {\n      if (this.isDual()) {\n        this.values.set([this.min(), this.max()]);\n      } else {\n        this.values.set(this.min());\n      }\n      this.commitValue(this.values());\n    }\n  }\n  fixInitializeValues() {\n    //swap value\n    if (this.isDual() && this.values()[0] > this.values()[1]) {\n      this.values.set([this.values()[1], this.values()[0]]);\n      this.commitValue(this.values());\n    }\n    //not in range\n    if (typeof this.values() === 'number' && !this.checkValue(this.values() as number)) {\n      this.values.set(this.min());\n      this.commitValue(this.values());\n    } else if (\n      typeof this.values() !== 'number' &&\n      !this.checkValues(this.values()[0], 'first', this.values()[1])\n    ) {\n      this.values.set([this.min(), this.max()]);\n      this.commitValue(this.values());\n    }\n  }\n  fixInitializeStep() {\n    if (this.step() !== 1) {\n      if (this.isDual()) {\n        this.values.update((old) => [this.calculateStep(old[0]), this.calculateStep(old[1])]);\n        this.commitValue(this.values());\n        if (this.values()[0] === this.values()[1]) {\n          this.values.update((old) => [this.calculateStep(old[0]), this.calculateStep(old[1]) + this.step()]);\n          this.commitValue(this.values());\n        }\n      } else {\n        this.values.update((old) => this.calculateStep(old as number));\n        this.commitValue(this.values());\n      }\n    }\n  }\n  fixChangingMode() {\n    if (typeof this.values() === 'number' && this.isDual()) {\n      this.values.set([this.min(), this.max()]);\n      this.commitValue(this.values());\n    } else if (typeof this.values() !== 'number' && !this.isDual()) {\n      this.values.set(this.min());\n      this.commitValue(this.values());\n    }\n  }\n  calculateStep(x: number): number {\n    const roundedValue = Math.round(x / this.step()) * this.step();\n    if (roundedValue > this.max()) return this.max();\n    else if (roundedValue < this.min()) return this.min();\n    //else if (x >= this.min() && x < this.min() - (this.min() % this.step())) return this.min();\n    else if (x <= this.max() && x > this.max() - (this.max() % this.step())) return this.max();\n    else return roundedValue;\n  }\n  checkValue(x: number): boolean {\n    if (x >= this.min() && x <= this.max()) return true;\n    else return false;\n  }\n  checkValues(value1: number, y: 'first' | 'second', value2: number): boolean {\n    if (value1 >= this.min() && value1 <= this.max()) {\n      if (y === 'first') {\n        if (value1 < value2 && value2 <= this.max()) return true;\n        else return false;\n      } else {\n        if (value1 > value2 && value2 >= this.min()) return true;\n        else return false;\n      }\n    } else return false;\n  }\n  getPercantage(value: number): number {\n    return (value / this.range()) * 100;\n  }\n\n  @HostBinding('class')\n  private get __hostClass(): string[] {\n    return [\n      `ax-${this.color()}-solid`,\n      `${this.disabled ? 'ax-state-disabled' : ''}`,\n      `${this.readonly ? 'ax-state-readonly' : ''}`,\n    ];\n  }\n}\n","<div class=\"ax-range-slider\" (wheel)=\"onWheel($event)\" [class]=\"'ax-orientation-' + orientation()\">\n  <div class=\"ax-range-slider-bar\" (mousedown)=\"onclickBar($event)\" (touchstart)=\"onclickBar($event)\"></div>\n  <div class=\"ax-range-slider-highlight\" [ngStyle]=\"AXRangeSliderHighlight()\"></div>\n\n  <div\n    class=\"ax-range-slider-handler\"\n    [ngStyle]=\"AXRangeSliderHandler1()\"\n    (mousedown)=\"handleOnStart($event, 'first')\"\n    (touchstart)=\"handleOnStart($event, 'first')\"\n  >\n    @if (hasTooltip()) {\n      <div class=\"ax-range-slider-tooltip\">{{ isDual() ? values()[0] : values() }}</div>\n    }\n  </div>\n\n  @if (isDual()) {\n    <div\n      class=\"ax-range-slider-handler\"\n      [ngStyle]=\"AXRangeSliderHandler2()\"\n      (mousedown)=\"handleOnStart($event, 'second')\"\n      (touchstart)=\"handleOnStart($event, 'second')\"\n    >\n      @if (hasTooltip()) {\n        <div class=\"ax-range-slider-tooltip\">{{ values()[1] }}</div>\n      }\n    </div>\n  }\n  @if (hasSnap()) {\n    <div class=\"ax-range-slider-step\" [ngStyle]=\"AXRangeSliderStep()\">\n      @for (item of calculateSnapBar(); track $index) {\n        <div\n          class=\"ax-range-slider-steps\"\n          [ngStyle]=\"\n            isHorizontal() ? { left: getPercantage(item) + '%' } : { top: getPercantage(item) + '%' }\n          \"\n        >\n          @if (hasLable()) {\n            <div class=\"ax-range-slider-label\" [ngStyle]=\"AXRangeLabel()\">\n              {{ item + min() }}\n            </div>\n          }\n        </div>\n      }\n    </div>\n  }\n</div>\n"]}
@@ -4,7 +4,7 @@ import { AXRangeSliderComponent } from './range-slider.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export class AXRangeSliderModule {
6
6
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderModule, declarations: [AXRangeSliderComponent], imports: [CommonModule] }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderModule, declarations: [AXRangeSliderComponent], imports: [CommonModule], exports: [AXRangeSliderComponent] }); }
8
8
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderModule, imports: [CommonModule] }); }
9
9
  }
10
10
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRangeSliderModule, decorators: [{
@@ -12,6 +12,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
12
12
  args: [{
13
13
  declarations: [AXRangeSliderComponent],
14
14
  imports: [CommonModule],
15
+ exports: [AXRangeSliderComponent],
15
16
  }]
16
17
  }] });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2Utc2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9yYW5nZS1zbGlkZXIvc3JjL2xpYi9yYW5nZS1zbGlkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQU1sRSxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixpQkFIZixzQkFBc0IsYUFDM0IsWUFBWTsrR0FFWCxtQkFBbUIsWUFGcEIsWUFBWTs7MkZBRVgsbUJBQW1CO2tCQUovQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUN0QyxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7aUJBQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWFJhbmdlU2xpZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9yYW5nZS1zbGlkZXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbQVhSYW5nZVNsaWRlckNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBBWFJhbmdlU2xpZGVyTW9kdWxlIHt9XG4iXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2Utc2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9yYW5nZS1zbGlkZXIvc3JjL2xpYi9yYW5nZS1zbGlkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQU9sRSxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixpQkFKZixzQkFBc0IsYUFDM0IsWUFBWSxhQUNaLHNCQUFzQjsrR0FFckIsbUJBQW1CLFlBSHBCLFlBQVk7OzJGQUdYLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYUmFuZ2VTbGlkZXJDb21wb25lbnQgfSBmcm9tICcuL3JhbmdlLXNsaWRlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtBWFJhbmdlU2xpZGVyQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtBWFJhbmdlU2xpZGVyQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgQVhSYW5nZVNsaWRlck1vZHVsZSB7fVxuIl19