@seniorsistemas/angular-components 17.16.4 → 17.16.6

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.
@@ -1,17 +1,19 @@
1
1
  var SliderComponent_1;
2
2
  import { __decorate } from "tslib";
3
- import { Component, EventEmitter, forwardRef, HostListener, Input, Output, ViewChild, } from "@angular/core";
3
+ import { Component, EventEmitter, forwardRef, HostListener, Input, Output, ViewChild } from "@angular/core";
4
4
  import { NG_VALUE_ACCESSOR } from "@angular/forms";
5
5
  let SliderComponent = SliderComponent_1 = class SliderComponent {
6
6
  constructor() {
7
+ this.MAX_RANGE_VALUE = 100;
8
+ this.MIN_RANGE_VALUE = 0;
7
9
  this.multiple = false;
8
10
  this.value = 0;
9
11
  this.valueChange = new EventEmitter();
10
12
  this.step = 1;
11
13
  this.hiddenThumb = false;
12
14
  this.disabled = false;
13
- this.min = 0;
14
- this.max = 100;
15
+ this.min = this.MIN_RANGE_VALUE;
16
+ this.max = this.MAX_RANGE_VALUE;
15
17
  this.tabindex = 0;
16
18
  this.startValue = 0;
17
19
  this.endValue = 0;
@@ -30,13 +32,11 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
30
32
  * @example
31
33
  * with min = -10 and max = 10 will have this map.
32
34
  * {
33
- * -10: { left: 0, right: 10 },
34
- * -9: { left: 11, right: 19 },
35
+ * -10: { 0 },
36
+ * -9: { 10 },
35
37
  * ...
36
- * 10: { left: 90, right: 100 }
38
+ * 10: { 10 }
37
39
  * }
38
- * the left value represent value for startValue, the right value represent value for endValue
39
- * left and right values ​​are used when applying percentages in the slider
40
40
  */
41
41
  this.mapRangeValuesForSlider = new Map();
42
42
  this.activeMouseDown = false;
@@ -49,16 +49,16 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
49
49
  (this.multiple && this.draggingThumb === "end" && newPosition < this.startValue)) {
50
50
  return;
51
51
  }
52
- const positionInUserRange = this.getUserValueFromSliderValueByMap(newPosition);
52
+ const positionInUserRange = this.getValueFromMapByValue(newPosition);
53
53
  if (this.multiple) {
54
54
  if (this.draggingThumb === "start") {
55
55
  this.startValue = this.needParseValues
56
- ? this.mapRangeValuesForSlider.get(positionInUserRange).left
56
+ ? this.mapRangeValuesForSlider.get(positionInUserRange)
57
57
  : newPosition;
58
58
  }
59
59
  else if (this.draggingThumb === "end") {
60
60
  this.endValue = this.needParseValues
61
- ? this.mapRangeValuesForSlider.get(positionInUserRange).right
61
+ ? this.mapRangeValuesForSlider.get(positionInUserRange)
62
62
  : newPosition;
63
63
  }
64
64
  this.setValue([this.startValue, this.endValue]);
@@ -71,18 +71,15 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
71
71
  }
72
72
  }
73
73
  else {
74
- const pickLeftValue = newPosition <= 50;
75
- const pickRightValue = newPosition > 50;
76
- if (pickLeftValue) {
77
- this.endValue = this.needParseValues
78
- ? this.mapRangeValuesForSlider.get(positionInUserRange).left
79
- : newPosition;
80
- }
81
- else if (pickRightValue) {
82
- this.endValue = this.needParseValues
83
- ? this.mapRangeValuesForSlider.get(positionInUserRange).right
84
- : newPosition;
74
+ const currentValue = this.value;
75
+ const _value = this.needParseValues ? positionInUserRange : newPosition;
76
+ const isAtSameValue = this.needParseValues ? positionInUserRange === this.value : false;
77
+ const hasStep = this.step !== 0;
78
+ const newValueIsValidByStep = hasStep ? currentValue + this.step === _value || currentValue - this.step === _value : false;
79
+ if (isAtSameValue && !newValueIsValidByStep) {
80
+ return;
85
81
  }
82
+ this.endValue = this.needParseValues ? this.mapRangeValuesForSlider.get(positionInUserRange) : newPosition;
86
83
  this.startValue = this.endValue;
87
84
  this.setValue(this.endValue);
88
85
  }
@@ -103,20 +100,20 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
103
100
  const startValueBeforeEvent = this.startValueBeforeProgressBarEvent;
104
101
  const range = this.rangeBetweenElementsBeforeProgressBarEvent;
105
102
  let { newStart, newEnd } = calculateNewRange(startValueBeforeEvent, startValueBeforeEvent + range, startPositionBeforeEvent, newCenter);
106
- if (newStart < 0 || newEnd > 100) {
103
+ if (newStart < this.MIN_RANGE_VALUE || newEnd > this.MAX_RANGE_VALUE) {
107
104
  return;
108
105
  }
109
106
  if (this.needParseValues) {
110
- const startValueBeforeEventUserRange = this.getUserValueFromSliderValueByMap(startValueBeforeEvent);
111
- const startPositionBeforeEventUserRange = this.getUserValueFromSliderValueByMap(startPositionBeforeEvent);
112
- const centerUserRange = this.getUserValueFromSliderValueByMap(newCenter);
107
+ const startValueBeforeEventUserRange = this.getValueFromMapByValue(startValueBeforeEvent);
108
+ const startPositionBeforeEventUserRange = this.getValueFromMapByValue(startPositionBeforeEvent);
109
+ const centerUserRange = this.getValueFromMapByValue(newCenter);
113
110
  const valueRange = this.totalRangeBeforeProgressBarEvent;
114
111
  let { newStart, newEnd } = calculateNewRange(startValueBeforeEventUserRange, startValueBeforeEventUserRange + valueRange, startPositionBeforeEventUserRange, centerUserRange);
115
112
  if (newStart < this.min || newEnd > this.max) {
116
113
  return;
117
114
  }
118
- this.startValue = this.mapRangeValuesForSlider.get(newStart).left;
119
- this.endValue = this.mapRangeValuesForSlider.get(newEnd).right;
115
+ this.startValue = this.mapRangeValuesForSlider.get(newStart);
116
+ this.endValue = this.mapRangeValuesForSlider.get(newEnd);
120
117
  }
121
118
  else {
122
119
  this.startValue = newStart;
@@ -138,8 +135,15 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
138
135
  };
139
136
  }
140
137
  ngOnInit() {
141
- if (this.needParseValues) {
138
+ this.setUserRangeMapValues();
139
+ }
140
+ ngOnChanges(changes) {
141
+ const hasChangesOnMin = changes.min && !changes.min.firstChange;
142
+ const hasChangesOnMax = changes.max && !changes.max.firstChange;
143
+ const hasChanges = hasChangesOnMin || hasChangesOnMax;
144
+ if (hasChanges) {
142
145
  this.setUserRangeMapValues();
146
+ this.setRangeValues();
143
147
  }
144
148
  }
145
149
  ngAfterViewInit() {
@@ -160,10 +164,12 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
160
164
  }
161
165
  }
162
166
  get tooltipStartText() {
163
- return (this.needParseValues ? this.getUserValueFromSliderValueByMap(this.startValue) : this.startValue).toString();
167
+ var _a, _b;
168
+ return Array.isArray(this.value) ? (_a = this.value[0]) === null || _a === void 0 ? void 0 : _a.toString() : (_b = this.value) === null || _b === void 0 ? void 0 : _b.toString();
164
169
  }
165
170
  get tooltipEndText() {
166
- return (this.needParseValues ? this.getUserValueFromSliderValueByMap(this.endValue) : this.endValue).toString();
171
+ var _a, _b;
172
+ return Array.isArray(this.value) ? (_a = this.value[1]) === null || _a === void 0 ? void 0 : _a.toString() : (_b = this.value) === null || _b === void 0 ? void 0 : _b.toString();
167
173
  }
168
174
  writeValue(obj) {
169
175
  this.value = obj;
@@ -188,11 +194,11 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
188
194
  return;
189
195
  }
190
196
  const trackClickPercentage = this.getPercentageByEvent(evt);
191
- const trackClickToUserRange = this.getUserValueFromSliderValueByMap(trackClickPercentage);
197
+ const trackClickToUserRange = this.getValueFromMapByValue(trackClickPercentage);
192
198
  const _trackClickValid = this.needParseValues ? trackClickToUserRange : trackClickPercentage;
193
199
  const _setEndValue = () => {
194
- const _endValueUserValue = this.getUserValueFromSliderValueByMap(this.endValue);
195
- const _endValue = this.needParseValues ? this.mapRangeValuesForSlider.get(trackClickToUserRange).right : trackClickPercentage;
200
+ const _endValueUserValue = this.getValueFromMapByValue(this.endValue);
201
+ const _endValue = this.needParseValues ? this.mapRangeValuesForSlider.get(trackClickToUserRange) : trackClickPercentage;
196
202
  if (this.needParseValues && _endValueUserValue !== trackClickToUserRange) {
197
203
  this.endValue = _endValue;
198
204
  }
@@ -201,10 +207,10 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
201
207
  }
202
208
  };
203
209
  const _setStartValue = () => {
204
- const _startValueUserValue = this.getUserValueFromSliderValueByMap(this.startValue);
210
+ const _startValueUserValue = this.getValueFromMapByValue(this.startValue);
205
211
  if (this.needParseValues && _startValueUserValue !== trackClickToUserRange) {
206
212
  const _startValue = this.needParseValues
207
- ? this.mapRangeValuesForSlider.get(trackClickToUserRange).left
213
+ ? this.mapRangeValuesForSlider.get(trackClickToUserRange)
208
214
  : trackClickPercentage;
209
215
  this.startValue = _startValue;
210
216
  }
@@ -214,8 +220,8 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
214
220
  };
215
221
  if (this.multiple) {
216
222
  const [start, end] = this.value;
217
- const validStart = this.needParseValues ? this.mapRangeValuesForSlider.get(start).left : start;
218
- const validEnd = this.needParseValues ? this.mapRangeValuesForSlider.get(end).right : end;
223
+ const validStart = this.needParseValues ? this.mapRangeValuesForSlider.get(start) : start;
224
+ const validEnd = this.needParseValues ? this.mapRangeValuesForSlider.get(end) : end;
219
225
  const _updateStart = () => {
220
226
  _setStartValue();
221
227
  this.setValue([trackClickPercentage, validEnd]);
@@ -278,11 +284,14 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
278
284
  document.addEventListener("mouseup", this.onMouseUp);
279
285
  }
280
286
  setRangeValues() {
287
+ const _setStartAndEndValue = (startValue, endValue) => {
288
+ this.startValue = this.getClosestValueFromMapSlider(startValue);
289
+ this.endValue = this.getClosestValueFromMapSlider(endValue);
290
+ };
281
291
  if (Array.isArray(this.value) && !this.multiple) {
282
292
  throw new Error('You must use "multiple" with value as array');
283
293
  }
284
- const hasRangeValues = !!(this.startValue && this.endValue);
285
- if (this.multiple && Array.isArray(this.value) && !hasRangeValues) {
294
+ if (this.multiple && Array.isArray(this.value)) {
286
295
  this.startValue = this.value[0];
287
296
  this.endValue = this.value[1];
288
297
  }
@@ -294,13 +303,40 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
294
303
  this.endValue = this.value;
295
304
  }
296
305
  if (this.needParseValues) {
297
- const isEqualAndMultiple = this.multiple && this.startValue === this.endValue;
298
- this.startValue = this.mapRangeValuesForSlider.get(this.startValue).left;
299
- if (isEqualAndMultiple) {
300
- this.endValue = this.startValue;
306
+ _setStartAndEndValue(this.startValue, this.endValue);
307
+ if (this.multiple) {
308
+ let [_startValue, _endValue] = this.value;
309
+ const difference = getDifference(_endValue, _startValue);
310
+ const endValueIsGreatherThanMax = _endValue > this.max;
311
+ const startValueIsLessThanMin = _startValue < this.min;
312
+ const needUpdateValues = endValueIsGreatherThanMax || startValueIsLessThanMin;
313
+ if (endValueIsGreatherThanMax) {
314
+ _endValue = this.max;
315
+ _startValue = _endValue - difference;
316
+ }
317
+ else if (startValueIsLessThanMin) {
318
+ _startValue = this.min;
319
+ _endValue = _startValue + difference;
320
+ }
321
+ if (needUpdateValues) {
322
+ _setStartAndEndValue(_startValue, _endValue);
323
+ this.setValue([this.startValue, this.endValue]);
324
+ }
301
325
  }
302
326
  else {
303
- this.endValue = this.mapRangeValuesForSlider.get(this.endValue).right;
327
+ let _value = this.value;
328
+ const valueGreatherThanMax = _value > this.max;
329
+ const valueLessThanMin = _value < this.min;
330
+ const needUpdateValue = valueGreatherThanMax || valueLessThanMin;
331
+ if (valueGreatherThanMax) {
332
+ _value = this.max;
333
+ }
334
+ else if (valueLessThanMin) {
335
+ _value = this.min;
336
+ }
337
+ if (needUpdateValue) {
338
+ this.setValue(_value);
339
+ }
304
340
  }
305
341
  }
306
342
  this.setProgress();
@@ -322,21 +358,20 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
322
358
  */
323
359
  getPercentageByEvent(mouseEvent) {
324
360
  const trackRect = this.track.nativeElement.getBoundingClientRect();
325
- let newLeft = ((mouseEvent.clientX - trackRect.left) / trackRect.width) * 100;
326
- newLeft = Math.round(newLeft / this.step) * this.step;
327
- newLeft = Math.max(0, Math.min(newLeft, 100));
361
+ let newLeft = Math.round(((mouseEvent.clientX - trackRect.left) / trackRect.width) * this.MAX_RANGE_VALUE);
362
+ newLeft = Math.max(0, Math.min(newLeft, this.MAX_RANGE_VALUE));
328
363
  return newLeft;
329
364
  }
330
- setValue(value) {
365
+ setValue(value, parse = true) {
331
366
  if (this.disabled) {
332
367
  return;
333
368
  }
334
- if (this.needParseValues) {
369
+ if (this.needParseValues && parse) {
335
370
  if (Array.isArray(value)) {
336
- value = value.map((x) => this.getUserValueFromSliderValueByMap(x));
371
+ value = value.map((x) => this.getValueFromMapByValue(x));
337
372
  }
338
373
  else {
339
- value = this.getUserValueFromSliderValueByMap(value);
374
+ value = this.getValueFromMapByValue(value);
340
375
  }
341
376
  }
342
377
  this.value = value;
@@ -348,54 +383,78 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
348
383
  setUserRangeMapValues() {
349
384
  const start = this.min;
350
385
  const end = this.max;
351
- let forStart = 0;
352
- let forEnd = 100;
353
- this.mapRangeValuesForSlider.clear();
354
- const mappedValues = [];
355
- for (let i = start; i <= end; i++) {
356
- const valuesWithMap = [];
357
- for (let j = forStart; j <= forEnd; j++) {
358
- const sliderToUserRangeValue = this.mapSliderToUserRange(j);
359
- if (sliderToUserRangeValue !== i) {
360
- forStart = j;
361
- break;
362
- }
363
- else {
364
- valuesWithMap.push(j);
365
- }
366
- }
367
- const left = valuesWithMap[0];
368
- const right = valuesWithMap[valuesWithMap.length - 1];
369
- mappedValues.push({ value: i, left, right });
386
+ if (start > end) {
387
+ throw new Error('Max value must be greater than min value');
370
388
  }
371
- adjustLastItem(mappedValues);
372
- mappedValues.forEach((mappedValue) => {
373
- this.mapRangeValuesForSlider.set(mappedValue.value, Object.assign({}, mappedValue));
389
+ this.mapRangeValuesForSlider.clear();
390
+ const range = end - start;
391
+ const decimalPlaces = 2;
392
+ const stepCount = Math.floor(range / this.step);
393
+ const values = [];
394
+ for (let value = start; value <= end; value += this.step) {
395
+ values.push(value);
396
+ }
397
+ if (values[values.length - 1] !== end) {
398
+ values.push(end);
399
+ }
400
+ const mappedValues = values.map((value) => {
401
+ let mapped = ((value - start) / range) * this.MAX_RANGE_VALUE;
402
+ return parseFloat(mapped.toFixed(decimalPlaces));
403
+ });
404
+ mappedValues[0] = 0;
405
+ mappedValues[mappedValues.length - 1] = this.MAX_RANGE_VALUE;
406
+ const error = this.MAX_RANGE_VALUE - mappedValues[mappedValues.length - 1];
407
+ const errorPerStep = error / stepCount;
408
+ for (let i = 1; i < mappedValues.length - 1; i++) {
409
+ mappedValues[i] += errorPerStep;
410
+ mappedValues[i] = parseFloat(mappedValues[i].toFixed(decimalPlaces));
411
+ }
412
+ values.forEach((value, index) => {
413
+ this.mapRangeValuesForSlider.set(value, mappedValues[index]);
374
414
  });
375
415
  }
376
416
  /**
377
- * Maps a slider value to a user value in the range [min, max].
417
+ * Returns the user value from the given slider value by using the map of range values.
378
418
  * @example
379
- * If min = 0 and max = 10, mapSliderToUserRange(25) returns 2.5
419
+ * If the map is 0: { 0 }, 1: { 10 }, 2: { 30 }, 3: { 40 }, 4: { 50 }
420
+ * and the sliderValue is 37, the function returns 3
421
+ * or the slider value is 40, the function returns 4
422
+ * @param sliderValue the value of the slider (values only between range MIN and MAX)
423
+ * @returns the user value from the given slider value
380
424
  */
381
- mapSliderToUserRange(sliderValue) {
382
- return Math.floor(this.min + (sliderValue / 100) * (this.max - this.min));
425
+ getValueFromMapByValue(sliderValue) {
426
+ const mapToArray = Array.from(this.mapRangeValuesForSlider).map(([value, mapped]) => ({ value, mapped }));
427
+ const exactValue = mapToArray.find((x) => x.mapped == sliderValue);
428
+ const closest = mapToArray.reduce((prev, curr) => Math.abs(curr.mapped - sliderValue) < Math.abs(prev.mapped - sliderValue) ? curr : prev);
429
+ return exactValue ? exactValue.value : closest.value;
383
430
  }
384
431
  /**
385
- * Returns the user value from the given slider value by using the map of range values.
386
- * @example
387
- * If the map is [{value: 0, left: 0, right: 25}, {value: 1, left: 25, right: 50}, {value: 2, left: 50, right: 75}, {value: 3, left: 75, right: 100}]
388
- * and the sliderValue is 37, the function returns 1
389
- * @param sliderValue the value of the slider
390
- * @returns the user value from the given slider value
432
+ * Retrieves the key from the map that is closest to the given slider value.
433
+ * @param userValue - The value to find the closest key for. (values only between 0 - 100)
434
+ * @returns The key that corresponds to the closest mapped value.
391
435
  */
392
- getUserValueFromSliderValueByMap(sliderValue) {
393
- var _a;
394
- const mapToArray = Array.from(this.mapRangeValuesForSlider).map((x) => {
395
- return Object.assign({ value: x[0] }, x[1]);
396
- });
397
- const mappedValue = mapToArray.find((x) => isInRange(sliderValue, x.left, x.right));
398
- return (_a = mappedValue === null || mappedValue === void 0 ? void 0 : mappedValue.value) !== null && _a !== void 0 ? _a : sliderValue;
436
+ getClosestValueFromMapSlider(userValue) {
437
+ const mapToArray = Array.from(this.mapRangeValuesForSlider).map(([value, mapped]) => ({ value, mapped }));
438
+ if (userValue >= this.max) {
439
+ return mapToArray[mapToArray.length - 1].mapped;
440
+ }
441
+ else if (userValue <= this.min) {
442
+ return mapToArray[0].mapped;
443
+ }
444
+ const exactValue = mapToArray.find((x) => x.value == userValue);
445
+ const closestValue = mapToArray.reduce((prev, curr) => Math.abs(curr.value - userValue) < Math.abs(prev.value - userValue) ? curr : prev);
446
+ const item = exactValue || closestValue;
447
+ const isFirstItem = mapToArray[0] === item;
448
+ const isLastItem = mapToArray[mapToArray.length - 1] === item;
449
+ if (isFirstItem && userValue > this.min) {
450
+ return getMidpoint(item.mapped, mapToArray[1].mapped);
451
+ }
452
+ else if (isLastItem && userValue < this.max) {
453
+ return getMidpoint(item.mapped, mapToArray[mapToArray.length - 2].mapped);
454
+ }
455
+ else {
456
+ return item.mapped;
457
+ }
399
458
  }
400
459
  handleArrowKeyLeft() {
401
460
  if (this.multiple) {
@@ -417,6 +476,7 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
417
476
  }
418
477
  _incrementOrDecrementStartAndEndValue(increment) {
419
478
  let [start, end] = this.value;
479
+ const difference = getDifference(end, start);
420
480
  if (increment) {
421
481
  start += this.step;
422
482
  end += this.step;
@@ -425,31 +485,28 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
425
485
  start -= this.step;
426
486
  end -= this.step;
427
487
  }
428
- if (this.needParseValues) {
429
- if (!this.mapRangeValuesForSlider.has(start) || !this.mapRangeValuesForSlider.has(end)) {
430
- return;
488
+ const startLessThanMin = start < this.min;
489
+ const endGreaterThanMax = end > this.max;
490
+ if (startLessThanMin || endGreaterThanMax) {
491
+ if (startLessThanMin) {
492
+ start = this.min;
493
+ end = start + difference;
431
494
  }
432
- const isEqual = start === end;
433
- if (isEqual && end === this.max) {
434
- start = this.mapRangeValuesForSlider.get(this.max).right;
435
- end = start;
436
- }
437
- else {
438
- start = this.mapRangeValuesForSlider.get(start).left;
439
- if (isEqual) {
440
- end = start;
441
- }
442
- else {
443
- end = this.mapRangeValuesForSlider.get(end).right;
444
- }
495
+ else if (endGreaterThanMax) {
496
+ end = this.max;
497
+ start = end - difference;
445
498
  }
446
499
  }
447
- if (start < 0 || end > 100) {
500
+ if (start < this.min || end > this.max) {
448
501
  return;
449
502
  }
503
+ this.setValue([start, end], false);
504
+ if (this.needParseValues) {
505
+ start = this.getClosestValueFromMapSlider(start);
506
+ end = this.getClosestValueFromMapSlider(end);
507
+ }
450
508
  this.startValue = start;
451
509
  this.endValue = end;
452
- this.setValue([start, end]);
453
510
  }
454
511
  _incrementOrDecrementEndValue(increment) {
455
512
  let value = this.value;
@@ -461,27 +518,17 @@ let SliderComponent = SliderComponent_1 = class SliderComponent {
461
518
  }
462
519
  let _newEndValue = value;
463
520
  if (this.needParseValues) {
464
- const valueParsedInSlider = this.mapRangeValuesForSlider.get(value);
465
- if (!valueParsedInSlider) {
466
- return;
467
- }
468
- const pickLeft = valueParsedInSlider.right <= 50;
469
- if (pickLeft) {
470
- _newEndValue = this.mapRangeValuesForSlider.get(value).left;
471
- }
472
- else {
473
- _newEndValue = this.mapRangeValuesForSlider.get(value).right;
474
- }
521
+ _newEndValue = this.getClosestValueFromMapSlider(_newEndValue);
475
522
  }
476
- if (_newEndValue < 0 || _newEndValue > 100) {
523
+ if (_newEndValue < this.MIN_RANGE_VALUE || _newEndValue > this.MAX_RANGE_VALUE) {
477
524
  return;
478
525
  }
479
526
  this.endValue = _newEndValue;
480
527
  this.startValue = this.endValue;
481
- this.setValue(this.endValue);
528
+ this.setValue(_newEndValue);
482
529
  }
483
530
  get needParseValues() {
484
- return this.max !== 100 || this.min !== 0;
531
+ return this.max !== this.MAX_RANGE_VALUE || this.min !== this.MIN_RANGE_VALUE;
485
532
  }
486
533
  };
487
534
  __decorate([
@@ -559,68 +606,14 @@ const isInRange = (value, rangeStart, rangeEnd) => {
559
606
  return value >= min && value <= max;
560
607
  };
561
608
  const ɵ1 = isInRange;
562
- /**
563
- * Adjust the last item of a mapped range to fill the gap between it and the penultimate item.
564
- * The gap is calculated by subtracting the difference between the last item's right and left
565
- * from the average difference between all the previous items.
566
- *
567
- * @param mappedValues - The mapped range to be adjusted.
568
- *
569
- * The function works by finding the gap between the last item and the penultimate item and
570
- * then distributing this gap among the previous items. The distribution is done by finding
571
- * the items that need to be fixed and then fixing them by shifting their left and right
572
- * positions.
573
- *
574
- * The function returns nothing, but it modifies the mappedValues array in place.
575
- */
576
- const adjustLastItem = (mappedValues) => {
577
- const lastItem = mappedValues[mappedValues.length - 1];
578
- const lastDifference = lastItem.right - lastItem.left;
579
- const withoutLastItem = mappedValues.slice(0, mappedValues.length - 1);
580
- const differences = withoutLastItem.map(({ left, right }) => right - left);
581
- const averageDifference = Math.floor(differences.reduce((sum, diff) => sum + diff, 0) / differences.length);
582
- const _getRandomIndexFromArray = (array, storedChanges) => {
583
- if (storedChanges.length === array.length) {
584
- storedChanges = [];
585
- }
586
- let randomIndex = Math.floor(Math.random() * array.length);
587
- let randomIndexAlreadyStored = storedChanges.includes(randomIndex);
588
- while (randomIndexAlreadyStored) {
589
- randomIndex = Math.floor(Math.random() * withoutLastItem.length);
590
- randomIndexAlreadyStored = storedChanges.includes(randomIndex);
591
- }
592
- storedChanges.push(randomIndex);
593
- return { randomIndex, storedChanges };
594
- };
595
- const needFixLastItem = lastDifference < averageDifference;
596
- let arr = [];
597
- if (needFixLastItem) {
598
- const captureItensCount = averageDifference - lastDifference;
599
- let randomIndexStored = [];
600
- for (let i = 0; i <= captureItensCount; i++) {
601
- const { randomIndex, storedChanges } = _getRandomIndexFromArray(withoutLastItem, randomIndexStored);
602
- randomIndexStored = storedChanges;
603
- arr.push(randomIndex);
604
- const randomItem = withoutLastItem[randomIndex];
605
- --lastItem.left;
606
- --randomItem.right;
607
- }
608
- mappedValues.forEach((mappedValue, index) => {
609
- const _next = mappedValues[index + 1];
610
- if (!_next) {
611
- return;
612
- }
613
- const nextLeft = _next.left;
614
- const currentRight = mappedValue.right;
615
- if (currentRight !== currentRight + 1) {
616
- const _nextDiff = _next.right - nextLeft;
617
- const _nextLeft = currentRight + 1;
618
- _next.left = _nextLeft;
619
- _next.right = _nextLeft + _nextDiff;
620
- }
621
- });
622
- }
609
+ const getMidpoint = (start, end) => {
610
+ const midpoint = (start + end) / 2;
611
+ return parseFloat(midpoint.toFixed(2));
612
+ };
613
+ const ɵ2 = getMidpoint;
614
+ const getDifference = (end, start) => {
615
+ return Math.abs(end - start);
623
616
  };
624
- const ɵ2 = adjustLastItem;
625
- export { ɵ0, ɵ1, ɵ2 };
626
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    Input,\n    OnInit,\n    Output,\n    ViewChild,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\n@Component({\n    selector: \"s-slider\",\n    templateUrl: \"./slider.component.html\",\n    styleUrls: [\"./slider.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SliderComponent),\n            multi: true,\n        },\n    ],\n})\nexport class SliderComponent implements OnInit, AfterViewInit, ControlValueAccessor {\n    @ViewChild(\"track\")\n    public track!: ElementRef;\n\n    @Input()\n    public multiple = false;\n\n    @Input()\n    public value: number | [number, number] = 0;\n\n    @Output()\n    public valueChange = new EventEmitter<number | [number, number]>();\n\n    @Input()\n    public step = 1;\n\n    @Input()\n    public hiddenThumb = false;\n\n    @Input()\n    public disabled = false;\n\n    @Input()\n    public min = 0;\n\n    @Input()\n    public max = 100;\n\n    @Input()\n    public minValueLabel: string;\n\n    @Input()\n    public maxValueLabel: string;\n\n    @Input()\n    public tabindex = 0;\n\n    public startValue = 0;\n    public endValue = 0;\n    public movingProgressBar = false;\n    public progressLeft = 0;\n    public progressWidth = \"\";\n\n    public onChange: (value: number | [number, number]) => void = () => {};\n    public onTouched: (value: number | [number, number]) => void = () => {};\n\n    private draggingThumb: \"start\" | \"end\" | null = null;\n    private progressBarEventPositionStart = -1;\n    private startValueBeforeProgressBarEvent = -1;\n    private rangeBetweenElementsBeforeProgressBarEvent = -1;\n    private totalRangeBeforeProgressBarEvent = -1;\n    /**\n     * Map of valid values for values in range.\n     * @example\n     * with min = -10 and max = 10 will have this map.\n     * {\n     *     -10: { left: 0, right: 10 },\n     *     -9: { left: 11, right: 19 },\n     *      ...\n     *     10: { left: 90, right: 100 }\n     * }\n     * the left value represent value for startValue, the right value represent value for endValue\n     * left and right values ​​are used when applying percentages in the slider\n     */\n    private mapRangeValuesForSlider: Map<number, { left: number; right: number }> = new Map();\n    private activeMouseDown = false;\n    private focusActive = false;\n\n    public ngOnInit(): void {\n        if (this.needParseValues) {\n            this.setUserRangeMapValues();\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        setTimeout(() => {\n            this.setRangeValues();\n        });\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydown($event: KeyboardEvent) {\n        if (this.focusActive && !this.disabled) {\n            const isArrowKeyLeft = $event.key === \"ArrowLeft\";\n            const isArrowKeyRight = $event.key === \"ArrowRight\";\n            if (isArrowKeyLeft) {\n                this.handleArrowKeyLeft();\n            } else if (isArrowKeyRight) {\n                this.handleArrowKeyRight();\n            }\n        }\n    }\n\n    public get tooltipStartText() {\n        return (this.needParseValues ? this.getUserValueFromSliderValueByMap(this.startValue) : this.startValue).toString();\n    }\n\n    public get tooltipEndText() {\n        return (this.needParseValues ? this.getUserValueFromSliderValueByMap(this.endValue) : this.endValue).toString();\n    }    \n\n    public writeValue(obj: number | [number, number]): void {\n        this.value = obj;\n    }\n\n    public registerOnChange(fn: (value: number | [number, number]) => void): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    public setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    public onFocusIn() {\n        this.focusActive = true;\n    }\n\n    public onBlur() {\n        this.focusActive = false;\n    }\n\n    public onTrackClick(evt: PointerEvent) {\n        if (this.disabled || this.movingProgressBar || this.activeMouseDown) {\n            return;\n        }\n        const trackClickPercentage = this.getPercentageByEvent(evt);\n        const trackClickToUserRange = this.getUserValueFromSliderValueByMap(trackClickPercentage);\n        const _trackClickValid = this.needParseValues ? trackClickToUserRange : trackClickPercentage;\n        const _setEndValue = () => {\n            const _endValueUserValue = this.getUserValueFromSliderValueByMap(this.endValue);\n            const _endValue = this.needParseValues ? this.mapRangeValuesForSlider.get(trackClickToUserRange).right : trackClickPercentage;\n            if (this.needParseValues && _endValueUserValue !== trackClickToUserRange) {\n                this.endValue = _endValue;\n            } else if (!this.needParseValues) {\n                this.endValue = trackClickPercentage;\n            }\n        };\n\n        const _setStartValue = () => {\n            const _startValueUserValue = this.getUserValueFromSliderValueByMap(this.startValue);\n            if (this.needParseValues && _startValueUserValue !== trackClickToUserRange) {\n                const _startValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(trackClickToUserRange).left\n                    : trackClickPercentage;\n                this.startValue = _startValue;\n            } else if (!this.needParseValues) {\n                this.startValue = trackClickPercentage;\n            }\n        };\n        if (this.multiple) {\n            const [start, end] = this.value as [number, number];\n            const validStart = this.needParseValues ? this.mapRangeValuesForSlider.get(start).left : start;\n            const validEnd = this.needParseValues ? this.mapRangeValuesForSlider.get(end).right : end;\n            const _updateStart = () => {\n                _setStartValue();\n                this.setValue([trackClickPercentage, validEnd]);\n            };\n\n            const _updateEnd = () => {\n                _setEndValue();\n                this.setValue([validStart, trackClickPercentage]);\n            };\n            const clickPercentageBetweenRange = isInRange(_trackClickValid, start, end);\n            if (_trackClickValid < start) {\n                _updateStart();\n            } else if (_trackClickValid > end) {\n                _updateEnd();\n            } else if (clickPercentageBetweenRange) {\n                const middle = (start + end) / 2;\n                const trackClickPercentageIsExactiddle = _trackClickValid === middle;\n                if (trackClickPercentageIsExactiddle) {\n                    _updateStart();\n                } else {\n                    const setStart = _trackClickValid < middle;\n                    const setEnd = _trackClickValid > middle;\n                    if (setStart) {\n                        _updateStart();\n                    } else if (setEnd) {\n                        _updateEnd();\n                    }\n                }\n            }\n        } else {\n            this.setValue(trackClickPercentage);\n            _setEndValue();\n        }\n\n        this.setProgress();\n    }\n\n    public onProgressMouseDown(evt: PointerEvent) {\n        if (!this.multiple || this.disabled) {\n            return;\n        }\n        this.progressBarEventPositionStart = this.getPercentageByEvent(evt);\n        this.startValueBeforeProgressBarEvent = this.startValue;\n        this.rangeBetweenElementsBeforeProgressBarEvent = this.endValue - this.startValue;\n        if (this.multiple) {\n            const [start, end] = this.value as [number, number];\n            this.totalRangeBeforeProgressBarEvent = end - start;\n        }\n        document.addEventListener(\"mousemove\", this.handleProgressBarMove);\n        document.addEventListener(\"mouseup\", this.handleProgressBarMoveEnd);\n    }\n\n    public onMouseDown(_: MouseEvent, thumb: \"start\" | \"end\"): void {\n        if (this.disabled) return;\n\n        this.draggingThumb = thumb;\n        this.activeMouseDown = true;\n        document.addEventListener(\"mousemove\", this.onThumbMove);\n        document.addEventListener(\"mouseup\", this.onMouseUp);\n    }\n\n    private setRangeValues(): void {\n        if (Array.isArray(this.value) && !this.multiple) {\n            throw new Error('You must use \"multiple\" with value as array');\n        }\n        const hasRangeValues = !!(this.startValue && this.endValue);\n        if (this.multiple && Array.isArray(this.value) && !hasRangeValues) {\n            this.startValue = this.value[0];\n            this.endValue = this.value[1];\n        } else if (this.multiple && !Array.isArray(this.value)) {\n            this.value = [this.startValue, this.endValue];\n        } else if (!this.multiple) {\n            this.startValue = this.value as number;\n            this.endValue = this.value as number;\n        }\n\n        if (this.needParseValues) {\n            const isEqualAndMultiple = this.multiple && this.startValue === this.endValue;\n            this.startValue = this.mapRangeValuesForSlider.get(this.startValue).left;\n            if (isEqualAndMultiple) {\n                this.endValue = this.startValue;\n            } else {\n                this.endValue = this.mapRangeValuesForSlider.get(this.endValue).right;\n            }\n        }\n        this.setProgress();\n    }\n\n    private onThumbMove = (event: MouseEvent) => {\n        if (this.movingProgressBar || !this.draggingThumb) return;\n\n        let newPosition = this.getPercentageByEvent(event);\n\n        if (\n            (this.multiple && this.draggingThumb === \"start\" && newPosition > this.endValue) ||\n            (this.multiple && this.draggingThumb === \"end\" && newPosition < this.startValue)\n        ) {\n            return;\n        }\n\n        const positionInUserRange = this.getUserValueFromSliderValueByMap(newPosition);\n\n        if (this.multiple) {\n            if (this.draggingThumb === \"start\") {\n                this.startValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(positionInUserRange).left\n                    : newPosition;\n            } else if (this.draggingThumb === \"end\") {\n                this.endValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(positionInUserRange).right\n                    : newPosition;\n            }\n\n            this.setValue([this.startValue, this.endValue]);\n\n            const [start, end] = this.value as [number, number];\n\n            if (start === end && this.draggingThumb === \"start\") {\n                this.startValue = this.endValue;\n            } else if (start === end && this.draggingThumb === \"end\") {\n                this.endValue = this.startValue;\n            }\n        } else {\n            const pickLeftValue = newPosition <= 50;\n            const pickRightValue = newPosition > 50;\n\n            if (pickLeftValue) {\n                this.endValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(positionInUserRange).left\n                    : newPosition;\n            } else if (pickRightValue) {\n                this.endValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(positionInUserRange).right\n                    : newPosition;\n            }\n\n            this.startValue = this.endValue;\n            this.setValue(this.endValue);\n        }\n        this.setProgress();\n    };\n\n    private onMouseUp = () => {\n        this.draggingThumb = null;\n        document.removeEventListener(\"mousemove\", this.onThumbMove);\n        document.removeEventListener(\"mouseup\", this.onMouseUp);\n        setTimeout(() => {\n            this.activeMouseDown = false;\n        }, 150);\n    };\n\n    private handleProgressBarMove = (event: MouseEvent) => {\n        this.movingProgressBar = true;\n        const newCenter = this.getPercentageByEvent(event);\n        const startPositionBeforeEvent = this.progressBarEventPositionStart;\n        const startValueBeforeEvent = this.startValueBeforeProgressBarEvent;\n        const range = this.rangeBetweenElementsBeforeProgressBarEvent;\n        let { newStart, newEnd } = calculateNewRange(\n            startValueBeforeEvent,\n            startValueBeforeEvent + range,\n            startPositionBeforeEvent,\n            newCenter\n        );\n        if (newStart < 0 || newEnd > 100) {\n            return;\n        }\n        if (this.needParseValues) {\n            const startValueBeforeEventUserRange = this.getUserValueFromSliderValueByMap(startValueBeforeEvent);\n            const startPositionBeforeEventUserRange = this.getUserValueFromSliderValueByMap(startPositionBeforeEvent);\n            const centerUserRange = this.getUserValueFromSliderValueByMap(newCenter);\n            const valueRange = this.totalRangeBeforeProgressBarEvent;\n            let { newStart, newEnd } = calculateNewRange(\n                startValueBeforeEventUserRange,\n                startValueBeforeEventUserRange + valueRange,\n                startPositionBeforeEventUserRange,\n                centerUserRange\n            );\n            if (newStart < this.min || newEnd > this.max) {\n                return;\n            }\n            this.startValue = this.mapRangeValuesForSlider.get(newStart).left;\n            this.endValue = this.mapRangeValuesForSlider.get(newEnd).right;\n        } else {\n            this.startValue = newStart;\n            this.endValue = newEnd;\n        }\n        this.setValue([this.startValue, this.endValue]);\n        this.setProgress();\n    };\n\n    private handleProgressBarMoveEnd = () => {\n        this.progressBarEventPositionStart = -1;\n        this.startValueBeforeProgressBarEvent = -1;\n        this.rangeBetweenElementsBeforeProgressBarEvent = -1;\n        this.totalRangeBeforeProgressBarEvent = -1;\n        document.removeEventListener(\"mousemove\", this.handleProgressBarMove);\n        document.removeEventListener(\"mouseup\", this.handleProgressBarMoveEnd);\n        setTimeout(() => {\n            this.movingProgressBar = false;\n        }, 150);\n    };\n\n    private setProgress(): void {\n        if (this.multiple) {\n            this.progressLeft = this.startValue;\n            this.progressWidth = `calc(${this.endValue - this.startValue}% + 10px)`;\n        } else {\n            this.progressLeft = 0;\n            this.progressWidth = `calc(${this.endValue}% + 10px)`;\n        }\n    }\n\n    /**\n     * Get the percentage of a mouse event from the track's left edge\n     * @param mouseEvent mouse event\n     * @returns percentage from the left edge\n     */\n    private getPercentageByEvent(mouseEvent: MouseEvent | PointerEvent): number {\n        const trackRect = this.track.nativeElement.getBoundingClientRect();\n        let newLeft = ((mouseEvent.clientX - trackRect.left) / trackRect.width) * 100;\n        newLeft = Math.round(newLeft / this.step) * this.step;\n        newLeft = Math.max(0, Math.min(newLeft, 100));\n        return newLeft;\n    }\n\n    private setValue(value: number | [number, number]) {\n        if (this.disabled) {\n            return;\n        }\n\n        if (this.needParseValues) {\n            if (Array.isArray(value)) {\n                value = value.map((x) => this.getUserValueFromSliderValueByMap(x)) as [number, number];\n            } else {\n                value = this.getUserValueFromSliderValueByMap(value);\n            }\n        }\n        this.value = value;\n        this.valueChange.emit(value);\n        this.writeValue(this.value);\n        this.onChange(this.value);\n        this.onTouched(this.value);\n    }\n\n    private setUserRangeMapValues() {\n        const start = this.min;\n        const end = this.max;\n        let forStart = 0;\n        let forEnd = 100;\n        this.mapRangeValuesForSlider.clear();\n        const mappedValues: { value: number; left: number; right: number }[] = [];\n        for (let i = start; i <= end; i++) {\n            const valuesWithMap = [];\n            for (let j = forStart; j <= forEnd; j++) {\n                const sliderToUserRangeValue = this.mapSliderToUserRange(j);\n                if (sliderToUserRangeValue !== i) {\n                    forStart = j;\n                    break;\n                } else {\n                    valuesWithMap.push(j);\n                }\n            }\n            const left = valuesWithMap[0];\n            const right = valuesWithMap[valuesWithMap.length - 1];\n            mappedValues.push({ value: i, left, right });\n        }\n        adjustLastItem(mappedValues);\n        mappedValues.forEach((mappedValue) => {\n            this.mapRangeValuesForSlider.set(mappedValue.value, { ...mappedValue });\n        });\n    }\n\n    /**\n     * Maps a slider value to a user value in the range [min, max].\n     * @example\n     * If min = 0 and max = 10, mapSliderToUserRange(25) returns 2.5\n     */\n    private mapSliderToUserRange(sliderValue: number) {\n        return Math.floor(this.min + (sliderValue / 100) * (this.max - this.min));\n    }\n\n    /**\n     * Returns the user value from the given slider value by using the map of range values.\n     * @example\n     * If the map is [{value: 0, left: 0, right: 25}, {value: 1, left: 25, right: 50}, {value: 2, left: 50, right: 75}, {value: 3, left: 75, right: 100}]\n     * and the sliderValue is 37, the function returns 1\n     * @param sliderValue the value of the slider\n     * @returns the user value from the given slider value\n     */\n    private getUserValueFromSliderValueByMap(sliderValue: number) {\n        const mapToArray = Array.from(this.mapRangeValuesForSlider).map((x) => {\n            return { value: x[0], ...x[1] };\n        });\n        const mappedValue = mapToArray.find((x) => isInRange(sliderValue, x.left, x.right));\n        return mappedValue?.value ?? sliderValue;\n    }\n\n    private handleArrowKeyLeft() {\n        if (this.multiple) {\n            this._incrementOrDecrementStartAndEndValue(false);\n        } else {\n            this._incrementOrDecrementEndValue(false);\n        }\n        this.setProgress();\n    }\n\n    private handleArrowKeyRight() {\n        if (this.multiple) {\n            this._incrementOrDecrementStartAndEndValue(true);\n        } else {\n            this._incrementOrDecrementEndValue(true);\n        }\n        this.setProgress();\n    }\n\n    private _incrementOrDecrementStartAndEndValue(increment: boolean) {\n        let [start, end] = this.value as [number, number];\n        if (increment) {\n            start += this.step;\n            end += this.step;\n        } else {\n            start -= this.step;\n            end -= this.step;\n        }\n\n        if (this.needParseValues) {\n            if (!this.mapRangeValuesForSlider.has(start) || !this.mapRangeValuesForSlider.has(end)) {\n                return;\n            }\n            const isEqual = start === end;\n            if (isEqual && end === this.max) {\n                start = this.mapRangeValuesForSlider.get(this.max).right;\n                end = start;\n            } else {\n                start = this.mapRangeValuesForSlider.get(start).left;\n                if (isEqual) {\n                    end = start;\n                } else {\n                    end = this.mapRangeValuesForSlider.get(end).right;\n                }\n            }\n        }\n        if (start < 0 || end > 100) {\n            return;\n        }\n        this.startValue = start;\n        this.endValue = end;\n        this.setValue([start, end]);\n    }\n\n    private _incrementOrDecrementEndValue(increment: boolean) {\n        let value = this.value as number;\n        if (increment) {\n            value += this.step;\n        } else {\n            value -= this.step;\n        }\n        let _newEndValue = value;\n        if (this.needParseValues) {\n            const valueParsedInSlider = this.mapRangeValuesForSlider.get(value);\n            if (!valueParsedInSlider) {\n                return;\n            }\n            const pickLeft = valueParsedInSlider.right <= 50;\n            if (pickLeft) {\n                _newEndValue = this.mapRangeValuesForSlider.get(value).left;\n            } else {\n                _newEndValue = this.mapRangeValuesForSlider.get(value).right;\n            }\n        }\n        if (_newEndValue < 0 || _newEndValue > 100) {\n            return;\n        }\n        this.endValue = _newEndValue;\n        this.startValue = this.endValue;\n        this.setValue(this.endValue);\n    }\n\n    private get needParseValues() {\n        return this.max !== 100 || this.min !== 0;\n    }\n}\n\n/**\n * Calculates a new range based on the old range and the positions clicked and finalized.\n *\n * @param oldStart - The starting value of the old range.\n * @param oldEnd - The ending value of the old range.\n * @param clickedPosition - The position where the click occurred.\n * @param finalPosition - The position where the range should end.\n * @returns An object containing the new start and end values of the range.\n */\nconst calculateNewRange = (oldStart: number, oldEnd: number, clickedPosition: number, finalPosition: number) => {\n    const range = oldEnd - oldStart;\n    const newStart = finalPosition - (clickedPosition - oldStart);\n    const newEnd = newStart + range;\n    return { newStart, newEnd };\n};\n\nconst isInRange = (value: number, rangeStart: number, rangeEnd: number): boolean => {\n    const [min, max] = rangeStart < rangeEnd ? [rangeStart, rangeEnd] : [rangeEnd, rangeStart];\n    return value >= min && value <= max;\n};\n\n/**\n * Adjust the last item of a mapped range to fill the gap between it and the penultimate item.\n * The gap is calculated by subtracting the difference between the last item's right and left\n * from the average difference between all the previous items.\n *\n * @param mappedValues - The mapped range to be adjusted.\n *\n * The function works by finding the gap between the last item and the penultimate item and\n * then distributing this gap among the previous items. The distribution is done by finding\n * the items that need to be fixed and then fixing them by shifting their left and right\n * positions.\n *\n * The function returns nothing, but it modifies the mappedValues array in place.\n */\nconst adjustLastItem = (mappedValues: { value: number; left: number; right: number }[]) => {\n    const lastItem = mappedValues[mappedValues.length - 1];\n    const lastDifference = lastItem.right - lastItem.left;\n    const withoutLastItem = mappedValues.slice(0, mappedValues.length - 1);\n    const differences = withoutLastItem.map(({ left, right }) => right - left);\n    const averageDifference = Math.floor(differences.reduce((sum, diff) => sum + diff, 0) / differences.length);\n\n    const _getRandomIndexFromArray = <T>(array: T[], storedChanges: number[]) => {\n        if (storedChanges.length === array.length) {\n            storedChanges = [];\n        }\n        let randomIndex = Math.floor(Math.random() * array.length);\n        let randomIndexAlreadyStored = storedChanges.includes(randomIndex);\n        while (randomIndexAlreadyStored) {\n            randomIndex = Math.floor(Math.random() * withoutLastItem.length);\n            randomIndexAlreadyStored = storedChanges.includes(randomIndex);\n        }\n        storedChanges.push(randomIndex);\n        return { randomIndex, storedChanges };\n    };\n\n    const needFixLastItem = lastDifference < averageDifference;\n    let arr = [];\n    if (needFixLastItem) {\n        const captureItensCount = averageDifference - lastDifference;\n        let randomIndexStored: number[] = [];\n        for (let i = 0; i <= captureItensCount; i++) {\n            const { randomIndex, storedChanges } = _getRandomIndexFromArray(withoutLastItem, randomIndexStored);\n            randomIndexStored = storedChanges;\n            arr.push(randomIndex);\n            const randomItem = withoutLastItem[randomIndex];\n            --lastItem.left;\n            --randomItem.right;\n        }\n        mappedValues.forEach((mappedValue, index) => {\n            const _next = mappedValues[index + 1];\n            if (!_next) {\n                return;\n            }\n            const nextLeft = _next.left;\n            const currentRight = mappedValue.right;\n            if (currentRight !== currentRight + 1) {\n                const _nextDiff = _next.right - nextLeft;\n                const _nextLeft = currentRight + 1;\n                _next.left = _nextLeft;\n                _next.right = _nextLeft + _nextDiff;\n            }\n        });\n    }\n};\n"]}
617
+ const ɵ3 = getDifference;
618
+ export { ɵ0, ɵ1, ɵ2, ɵ3 };
619
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\n@Component({\n    selector: \"s-slider\",\n    templateUrl: \"./slider.component.html\",\n    styleUrls: [\"./slider.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SliderComponent),\n            multi: true,\n        },\n    ],\n})\nexport class SliderComponent implements OnInit, AfterViewInit, ControlValueAccessor, OnChanges {\n    private readonly MAX_RANGE_VALUE = 100;\n    private readonly MIN_RANGE_VALUE = 0;\n    @ViewChild(\"track\")\n    public track!: ElementRef;\n\n    @Input()\n    public multiple = false;\n\n    @Input()\n    public value: number | [number, number] = 0;\n\n    @Output()\n    public valueChange = new EventEmitter<number | [number, number]>();\n\n    @Input()\n    public step = 1;\n\n    @Input()\n    public hiddenThumb = false;\n\n    @Input()\n    public disabled = false;\n\n    @Input()\n    public min = this.MIN_RANGE_VALUE;\n\n    @Input()\n    public max = this.MAX_RANGE_VALUE;\n\n    @Input()\n    public minValueLabel: string;\n\n    @Input()\n    public maxValueLabel: string;\n\n    @Input()\n    public tabindex = 0;\n\n    public startValue = 0;\n    public endValue = 0;\n    public movingProgressBar = false;\n    public progressLeft = 0;\n    public progressWidth = \"\";\n\n    public onChange: (value: number | [number, number]) => void = () => { };\n    public onTouched: (value: number | [number, number]) => void = () => { };\n\n    private draggingThumb: \"start\" | \"end\" | null = null;\n    private progressBarEventPositionStart = -1;\n    private startValueBeforeProgressBarEvent = -1;\n    private rangeBetweenElementsBeforeProgressBarEvent = -1;\n    private totalRangeBeforeProgressBarEvent = -1;\n    /**\n     * Map of valid values for values in range.\n     * @example\n     * with min = -10 and max = 10 will have this map.\n     * {\n     *     -10: { 0 },\n     *     -9: { 10 },\n     *      ...\n     *     10: { 10 }\n     * }\n     */\n    private mapRangeValuesForSlider: Map<number, number> = new Map();\n    private activeMouseDown = false;\n    private focusActive = false;\n\n    public ngOnInit(): void {\n        this.setUserRangeMapValues();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        const hasChangesOnMin = changes.min && !changes.min.firstChange;\n        const hasChangesOnMax = changes.max && !changes.max.firstChange;\n        const hasChanges = hasChangesOnMin || hasChangesOnMax;\n        if (hasChanges) {\n            this.setUserRangeMapValues();\n            this.setRangeValues();\n        }\n    }\n    public ngAfterViewInit(): void {\n        setTimeout(() => {\n            this.setRangeValues();\n        })\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydown($event: KeyboardEvent) {\n        if (this.focusActive && !this.disabled) {\n            const isArrowKeyLeft = $event.key === \"ArrowLeft\";\n            const isArrowKeyRight = $event.key === \"ArrowRight\";\n            if (isArrowKeyLeft) {\n                this.handleArrowKeyLeft();\n            } else if (isArrowKeyRight) {\n                this.handleArrowKeyRight();\n            }\n        }\n    }\n\n    public get tooltipStartText() {\n        return Array.isArray(this.value) ? this.value[0]?.toString() : this.value?.toString();\n    }\n\n    public get tooltipEndText() {\n        return Array.isArray(this.value) ? this.value[1]?.toString() : this.value?.toString();\n    }\n\n    public writeValue(obj: number | [number, number]): void {\n        this.value = obj;\n    }\n\n    public registerOnChange(fn: (value: number | [number, number]) => void): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    public setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    public onFocusIn() {\n        this.focusActive = true;\n    }\n\n    public onBlur() {\n        this.focusActive = false;\n    }\n\n    public onTrackClick(evt: PointerEvent) {\n        if (this.disabled || this.movingProgressBar || this.activeMouseDown) {\n            return;\n        }\n        const trackClickPercentage = this.getPercentageByEvent(evt);\n        const trackClickToUserRange = this.getValueFromMapByValue(trackClickPercentage);\n        const _trackClickValid = this.needParseValues ? trackClickToUserRange : trackClickPercentage;\n        const _setEndValue = () => {\n            const _endValueUserValue = this.getValueFromMapByValue(this.endValue);\n            const _endValue = this.needParseValues ? this.mapRangeValuesForSlider.get(trackClickToUserRange) : trackClickPercentage;\n            if (this.needParseValues && _endValueUserValue !== trackClickToUserRange) {\n                this.endValue = _endValue;\n            } else if (!this.needParseValues) {\n                this.endValue = trackClickPercentage;\n            }\n        };\n\n        const _setStartValue = () => {\n            const _startValueUserValue = this.getValueFromMapByValue(this.startValue);\n            if (this.needParseValues && _startValueUserValue !== trackClickToUserRange) {\n                const _startValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(trackClickToUserRange)\n                    : trackClickPercentage;\n                this.startValue = _startValue;\n            } else if (!this.needParseValues) {\n                this.startValue = trackClickPercentage;\n            }\n        };\n        if (this.multiple) {\n            const [start, end] = this.value as [number, number];\n            const validStart = this.needParseValues ? this.mapRangeValuesForSlider.get(start) : start;\n            const validEnd = this.needParseValues ? this.mapRangeValuesForSlider.get(end) : end;\n            const _updateStart = () => {\n                _setStartValue();\n                this.setValue([trackClickPercentage, validEnd]);\n            };\n\n            const _updateEnd = () => {\n                _setEndValue();\n                this.setValue([validStart, trackClickPercentage]);\n            };\n            const clickPercentageBetweenRange = isInRange(_trackClickValid, start, end);\n            if (_trackClickValid < start) {\n                _updateStart();\n            } else if (_trackClickValid > end) {\n                _updateEnd();\n            } else if (clickPercentageBetweenRange) {\n                const middle = (start + end) / 2;\n                const trackClickPercentageIsExactiddle = _trackClickValid === middle;\n                if (trackClickPercentageIsExactiddle) {\n                    _updateStart();\n                } else {\n                    const setStart = _trackClickValid < middle;\n                    const setEnd = _trackClickValid > middle;\n                    if (setStart) {\n                        _updateStart();\n                    } else if (setEnd) {\n                        _updateEnd();\n                    }\n                }\n            }\n        } else {\n            this.setValue(trackClickPercentage);\n            _setEndValue();\n        }\n\n        this.setProgress();\n    }\n\n    public onProgressMouseDown(evt: PointerEvent) {\n        if (!this.multiple || this.disabled) {\n            return;\n        }\n        this.progressBarEventPositionStart = this.getPercentageByEvent(evt);\n        this.startValueBeforeProgressBarEvent = this.startValue;\n        this.rangeBetweenElementsBeforeProgressBarEvent = this.endValue - this.startValue;\n        if (this.multiple) {\n            const [start, end] = this.value as [number, number];\n            this.totalRangeBeforeProgressBarEvent = end - start;\n        }\n        document.addEventListener(\"mousemove\", this.handleProgressBarMove);\n        document.addEventListener(\"mouseup\", this.handleProgressBarMoveEnd);\n    }\n\n    public onMouseDown(_: MouseEvent, thumb: \"start\" | \"end\"): void {\n        if (this.disabled) return;\n\n        this.draggingThumb = thumb;\n        this.activeMouseDown = true;\n        document.addEventListener(\"mousemove\", this.onThumbMove);\n        document.addEventListener(\"mouseup\", this.onMouseUp);\n    }\n\n    private setRangeValues(): void {\n        const _setStartAndEndValue = (startValue: number, endValue: number) => {\n            this.startValue = this.getClosestValueFromMapSlider(startValue);\n            this.endValue = this.getClosestValueFromMapSlider(endValue);\n        }\n        if (Array.isArray(this.value) && !this.multiple) {\n            throw new Error('You must use \"multiple\" with value as array');\n        }\n        if (this.multiple && Array.isArray(this.value)) {\n            this.startValue = this.value[0];\n            this.endValue = this.value[1];\n        } else if (this.multiple && !Array.isArray(this.value)) {\n            this.value = [this.startValue, this.endValue];\n        } else if (!this.multiple) {\n            this.startValue = this.value as number;\n            this.endValue = this.value as number;\n        }\n\n        if (this.needParseValues) {\n            _setStartAndEndValue(this.startValue, this.endValue);\n            if (this.multiple) {\n                let [_startValue, _endValue] = this.value as [number, number];\n                const difference = getDifference(_endValue, _startValue);\n                const endValueIsGreatherThanMax = _endValue > this.max;\n                const startValueIsLessThanMin = _startValue < this.min;\n                const needUpdateValues = endValueIsGreatherThanMax || startValueIsLessThanMin;\n                if (endValueIsGreatherThanMax) {\n                    _endValue = this.max;\n                    _startValue = _endValue - difference;\n                } else if (startValueIsLessThanMin) {\n                    _startValue = this.min;\n                    _endValue = _startValue + difference;\n                }\n                if (needUpdateValues) {\n                    _setStartAndEndValue(_startValue, _endValue);\n                    this.setValue([this.startValue, this.endValue]);\n                }\n            } else {\n                let _value = this.value as number;\n                const valueGreatherThanMax = _value > this.max;\n                const valueLessThanMin = _value < this.min;\n                const needUpdateValue = valueGreatherThanMax || valueLessThanMin;\n                if (valueGreatherThanMax) {\n                    _value = this.max;\n                } else if (valueLessThanMin) {\n                    _value = this.min;\n                }\n                if (needUpdateValue) {\n                    this.setValue(_value);\n                }\n            }\n        }\n        this.setProgress();\n    }\n\n    private onThumbMove = (event: MouseEvent) => {\n        if (this.movingProgressBar || !this.draggingThumb) return;\n\n        let newPosition = this.getPercentageByEvent(event);\n        if (\n            (this.multiple && this.draggingThumb === \"start\" && newPosition > this.endValue) ||\n            (this.multiple && this.draggingThumb === \"end\" && newPosition < this.startValue)\n        ) {\n            return;\n        }\n\n        const positionInUserRange = this.getValueFromMapByValue(newPosition);\n\n        if (this.multiple) {\n            if (this.draggingThumb === \"start\") {\n                this.startValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(positionInUserRange)\n                    : newPosition;\n            } else if (this.draggingThumb === \"end\") {\n                this.endValue = this.needParseValues\n                    ? this.mapRangeValuesForSlider.get(positionInUserRange)\n                    : newPosition;\n            }\n\n            this.setValue([this.startValue, this.endValue]);\n\n            const [start, end] = this.value as [number, number];\n\n            if (start === end && this.draggingThumb === \"start\") {\n                this.startValue = this.endValue;\n            } else if (start === end && this.draggingThumb === \"end\") {\n                this.endValue = this.startValue;\n            }\n        } else {\n            const currentValue = this.value as number;\n            const _value = this.needParseValues ? positionInUserRange : newPosition;\n            const isAtSameValue = this.needParseValues ? positionInUserRange === this.value : false;\n            const hasStep = this.step !== 0;\n            const newValueIsValidByStep = hasStep ? currentValue + this.step === _value || currentValue - this.step === _value : false;\n            if (isAtSameValue && !newValueIsValidByStep) {\n                return;\n            }\n            this.endValue = this.needParseValues ? this.mapRangeValuesForSlider.get(positionInUserRange) : newPosition;\n            this.startValue = this.endValue;\n            this.setValue(this.endValue);\n        }\n        this.setProgress();\n    };\n\n    private onMouseUp = () => {\n        this.draggingThumb = null;\n        document.removeEventListener(\"mousemove\", this.onThumbMove);\n        document.removeEventListener(\"mouseup\", this.onMouseUp);\n        setTimeout(() => {\n            this.activeMouseDown = false;\n        }, 150);\n    };\n\n    private handleProgressBarMove = (event: MouseEvent) => {\n        this.movingProgressBar = true;\n        const newCenter = this.getPercentageByEvent(event);\n        const startPositionBeforeEvent = this.progressBarEventPositionStart;\n        const startValueBeforeEvent = this.startValueBeforeProgressBarEvent;\n        const range = this.rangeBetweenElementsBeforeProgressBarEvent;\n        let { newStart, newEnd } = calculateNewRange(\n            startValueBeforeEvent,\n            startValueBeforeEvent + range,\n            startPositionBeforeEvent,\n            newCenter\n        );\n        if (newStart < this.MIN_RANGE_VALUE || newEnd > this.MAX_RANGE_VALUE) {\n            return;\n        }\n        if (this.needParseValues) {\n            const startValueBeforeEventUserRange = this.getValueFromMapByValue(startValueBeforeEvent);\n            const startPositionBeforeEventUserRange = this.getValueFromMapByValue(startPositionBeforeEvent);\n            const centerUserRange = this.getValueFromMapByValue(newCenter);\n            const valueRange = this.totalRangeBeforeProgressBarEvent;\n            let { newStart, newEnd } = calculateNewRange(\n                startValueBeforeEventUserRange,\n                startValueBeforeEventUserRange + valueRange,\n                startPositionBeforeEventUserRange,\n                centerUserRange\n            );\n            if (newStart < this.min || newEnd > this.max) {\n                return;\n            }\n            this.startValue = this.mapRangeValuesForSlider.get(newStart);\n            this.endValue = this.mapRangeValuesForSlider.get(newEnd);\n        } else {\n            this.startValue = newStart;\n            this.endValue = newEnd;\n        }\n        this.setValue([this.startValue, this.endValue]);\n        this.setProgress();\n    };\n\n    private handleProgressBarMoveEnd = () => {\n        this.progressBarEventPositionStart = -1;\n        this.startValueBeforeProgressBarEvent = -1;\n        this.rangeBetweenElementsBeforeProgressBarEvent = -1;\n        this.totalRangeBeforeProgressBarEvent = -1;\n        document.removeEventListener(\"mousemove\", this.handleProgressBarMove);\n        document.removeEventListener(\"mouseup\", this.handleProgressBarMoveEnd);\n        setTimeout(() => {\n            this.movingProgressBar = false;\n        }, 150);\n    };\n\n    private setProgress(): void {\n        if (this.multiple) {\n            this.progressLeft = this.startValue;\n            this.progressWidth = `calc(${this.endValue - this.startValue}% + 10px)`;\n        } else {\n            this.progressLeft = 0;\n            this.progressWidth = `calc(${this.endValue}% + 10px)`;\n        }\n    }\n\n    /**\n     * Get the percentage of a mouse event from the track's left edge\n     * @param mouseEvent mouse event\n     * @returns percentage from the left edge\n     */\n    private getPercentageByEvent(mouseEvent: MouseEvent | PointerEvent): number {\n        const trackRect = this.track.nativeElement.getBoundingClientRect();\n        let newLeft = Math.round(((mouseEvent.clientX - trackRect.left) / trackRect.width) * this.MAX_RANGE_VALUE);\n        newLeft = Math.max(0, Math.min(newLeft, this.MAX_RANGE_VALUE));\n        return newLeft;\n    }\n\n    private setValue(value: number | [number, number], parse = true) {\n        if (this.disabled) {\n            return;\n        }\n\n        if (this.needParseValues && parse) {\n            if (Array.isArray(value)) {\n                value = value.map((x) => this.getValueFromMapByValue(x)) as [number, number];\n            } else {\n                value = this.getValueFromMapByValue(value);\n            }\n        }\n        this.value = value;\n        this.valueChange.emit(value);\n        this.writeValue(this.value);\n        this.onChange(this.value);\n        this.onTouched(this.value);\n    }\n\n    private setUserRangeMapValues() {\n        const start = this.min;\n        const end = this.max;\n        if (start > end) {\n            throw new Error('Max value must be greater than min value');\n        }\n        this.mapRangeValuesForSlider.clear();\n        const range = end - start;\n        const decimalPlaces = 2;\n        const stepCount = Math.floor(range / this.step);\n        const values: number[] = [];\n        for (let value = start; value <= end; value += this.step) {\n            values.push(value);\n        }\n        if (values[values.length - 1] !== end) {\n            values.push(end);\n        }\n        const mappedValues = values.map((value) => {\n            let mapped = ((value - start) / range) * this.MAX_RANGE_VALUE;\n            return parseFloat(mapped.toFixed(decimalPlaces));\n        });\n        mappedValues[0] = 0;\n        mappedValues[mappedValues.length - 1] = this.MAX_RANGE_VALUE;\n        const error = this.MAX_RANGE_VALUE - mappedValues[mappedValues.length - 1];\n        const errorPerStep = error / stepCount;\n        for (let i = 1; i < mappedValues.length - 1; i++) {\n            mappedValues[i] += errorPerStep;\n            mappedValues[i] = parseFloat(mappedValues[i].toFixed(decimalPlaces));\n        }\n        values.forEach((value, index) => {\n            this.mapRangeValuesForSlider.set(value, mappedValues[index]);\n        });\n    }\n\n    /**\n     * Returns the user value from the given slider value by using the map of range values.\n     * @example\n     * If the map is 0: { 0 }, 1: { 10 }, 2: { 30 }, 3: { 40 }, 4: { 50 }\n     * and the sliderValue is 37, the function returns 3\n     * or the slider value is 40, the function returns 4\n     * @param sliderValue the value of the slider (values only between range MIN and MAX)\n     * @returns the user value from the given slider value\n     */\n    private getValueFromMapByValue(sliderValue: number) {\n        const mapToArray = Array.from(this.mapRangeValuesForSlider).map(([value, mapped]) => ({ value, mapped }));\n        const exactValue = mapToArray.find((x) => x.mapped == sliderValue);\n        const closest = mapToArray.reduce((prev, curr) => Math.abs(curr.mapped - sliderValue) < Math.abs(prev.mapped - sliderValue) ? curr : prev);\n        return exactValue ? exactValue.value : closest.value;\n    }\n\n    /**\n     * Retrieves the key from the map that is closest to the given slider value.\n     * @param userValue - The value to find the closest key for. (values only between 0 - 100)\n     * @returns The key that corresponds to the closest mapped value.\n     */\n    private getClosestValueFromMapSlider(userValue: number): number {\n        const mapToArray = Array.from(this.mapRangeValuesForSlider).map(([value, mapped]) => ({ value, mapped }));\n        if (userValue >= this.max) {\n            return mapToArray[mapToArray.length - 1].mapped\n        } else if (userValue <= this.min) {\n            return mapToArray[0].mapped\n        }\n        const exactValue = mapToArray.find((x) => x.value == userValue);\n        const closestValue = mapToArray.reduce((prev, curr) => Math.abs(curr.value - userValue) < Math.abs(prev.value - userValue) ? curr : prev);\n        const item = exactValue || closestValue;\n        const isFirstItem = mapToArray[0] === item;\n        const isLastItem = mapToArray[mapToArray.length - 1] === item;\n        if (isFirstItem && userValue > this.min) {\n            return getMidpoint(item.mapped, mapToArray[1].mapped);\n        } else if (isLastItem && userValue < this.max) {\n            return getMidpoint(item.mapped, mapToArray[mapToArray.length - 2].mapped);\n        } else {\n            return item.mapped;\n        }\n    }\n\n\n    private handleArrowKeyLeft() {\n        if (this.multiple) {\n            this._incrementOrDecrementStartAndEndValue(false);\n        } else {\n            this._incrementOrDecrementEndValue(false);\n        }\n        this.setProgress();\n    }\n\n    private handleArrowKeyRight() {\n        if (this.multiple) {\n            this._incrementOrDecrementStartAndEndValue(true);\n        } else {\n            this._incrementOrDecrementEndValue(true);\n        }\n        this.setProgress();\n    }\n\n    private _incrementOrDecrementStartAndEndValue(increment: boolean) {\n        let [start, end] = this.value as [number, number];\n        const difference = getDifference(end, start);\n        if (increment) {\n            start += this.step;\n            end += this.step;\n        } else {\n            start -= this.step;\n            end -= this.step;\n        }\n        const startLessThanMin = start < this.min;\n        const endGreaterThanMax = end > this.max;\n        if (startLessThanMin || endGreaterThanMax) {\n            if (startLessThanMin) {\n                start = this.min;\n                end = start + difference;\n            } else if (endGreaterThanMax) {\n                end = this.max;\n                start = end - difference;\n            }\n        }\n        if (start < this.min || end > this.max) {\n            return;\n        }\n        this.setValue([start, end], false);\n        if (this.needParseValues) {\n            start = this.getClosestValueFromMapSlider(start);\n            end = this.getClosestValueFromMapSlider(end);\n        }\n        this.startValue = start;\n        this.endValue = end;\n    }\n\n    private _incrementOrDecrementEndValue(increment: boolean) {\n        let value = this.value as number;\n        if (increment) {\n            value += this.step;\n        } else {\n            value -= this.step;\n        }\n        let _newEndValue = value;\n        if (this.needParseValues) {\n            _newEndValue = this.getClosestValueFromMapSlider(_newEndValue);\n        }\n        if (_newEndValue < this.MIN_RANGE_VALUE || _newEndValue > this.MAX_RANGE_VALUE) {\n            return;\n        }\n        this.endValue = _newEndValue;\n        this.startValue = this.endValue;\n        this.setValue(_newEndValue);\n    }\n\n    private get needParseValues() {\n        return this.max !== this.MAX_RANGE_VALUE || this.min !== this.MIN_RANGE_VALUE;\n    }\n}\n\n/**\n * Calculates a new range based on the old range and the positions clicked and finalized.\n *\n * @param oldStart - The starting value of the old range.\n * @param oldEnd - The ending value of the old range.\n * @param clickedPosition - The position where the click occurred.\n * @param finalPosition - The position where the range should end.\n * @returns An object containing the new start and end values of the range.\n */\nconst calculateNewRange = (oldStart: number, oldEnd: number, clickedPosition: number, finalPosition: number) => {\n    const range = oldEnd - oldStart;\n    const newStart = finalPosition - (clickedPosition - oldStart);\n    const newEnd = newStart + range;\n    return { newStart, newEnd };\n};\n\nconst isInRange = (value: number, rangeStart: number, rangeEnd: number): boolean => {\n    const [min, max] = rangeStart < rangeEnd ? [rangeStart, rangeEnd] : [rangeEnd, rangeStart];\n    return value >= min && value <= max;\n};\n\nconst getMidpoint = (start: number, end: number) => {\n    const midpoint = (start + end) / 2;\n    return parseFloat(midpoint.toFixed(2));\n}\nconst getDifference = (end: number, start: number) => {\n    return Math.abs(end - start);\n}\n"]}