@design-factory/design-factory 18.1.1 → 19.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/design-factory-initial-branding.css +1 -1
- package/design-factory.css +1 -1
- package/fesm2022/design-factory.mjs +748 -921
- package/fesm2022/design-factory.mjs.map +1 -1
- package/lib/angular/accessibility/components/skip-links-container/skip-links-container.component.d.ts +3 -9
- package/lib/angular/accessibility/directives/skip-link.directive.d.ts +3 -9
- package/lib/angular/card/manage-card-selection.directive.d.ts +5 -5
- package/lib/angular/datepicker/datepicker-range.directive.d.ts +5 -6
- package/lib/angular/datepicker/datepicker.module.d.ts +3 -5
- package/lib/angular/inputs/icon/inputicon.directive.d.ts +5 -6
- package/lib/angular/mediaqueries/ifMedia.directive.d.ts +8 -9
- package/lib/angular/modal/modal.service.d.ts +4 -0
- package/lib/angular/progressbar/progressbar.component.d.ts +18 -28
- package/lib/angular/progressindicator/default/default-spinner.component.d.ts +4 -4
- package/lib/angular/progressindicator/progressindicator-backdrop.component.d.ts +4 -4
- package/lib/angular/progressindicator/progressindicator-container.component.d.ts +5 -7
- package/lib/angular/progressindicator/progressindicator.directive.d.ts +9 -11
- package/lib/angular/selects/events/manage-badge-events.directive.d.ts +4 -5
- package/lib/angular/selects/option-highlight.directive.d.ts +7 -12
- package/lib/angular/sidenav/dfSideNavCollapse.d.ts +16 -18
- package/lib/angular/sidenav/excludeTrap.directive.d.ts +9 -10
- package/lib/angular/sidenav/sidenav.component.d.ts +7 -8
- package/lib/angular/sidenav/sidenavlist.component.d.ts +8 -8
- package/lib/angular/slider/direction/sliderdirection.directive.d.ts +5 -7
- package/lib/angular/slider/lib/slider-element.directive.d.ts +2 -1
- package/lib/angular/slider/lib/slider-handle.directive.d.ts +1 -1
- package/lib/angular/slider/lib/slider-label.directive.d.ts +1 -1
- package/lib/angular/slider/lib/slider.component.d.ts +1 -1
- package/lib/angular/slider/lib/tooltip-wrapper.component.d.ts +1 -1
- package/lib/angular/slider/slider.module.d.ts +1 -1
- package/lib/angular/stepper/stepper.component.d.ts +7 -8
- package/lib/angular/utils/titleTruncate.directive.d.ts +2 -3
- package/lib/angular/waves-of-progress/waves.directive.d.ts +4 -3
- package/lib/index.d.ts +0 -1
- package/package.json +16 -16
- package/schematics/ng-add/index.js +1 -1
- package/styles/scss/agnosui/_variables.scss +9 -3
- package/styles/scss/bootstrap/_variables.scss +54 -12
- package/styles/scss/components/accordion/_accordion.scss +67 -6
- package/styles/scss/components/accordion/_accordion.variables.scss +2 -0
- package/styles/scss/components/alert/_alert.scss +3 -2
- package/styles/scss/components/badge/_badge.scss +13 -3
- package/styles/scss/components/badge/_badge.variables.scss +1 -0
- package/styles/scss/components/button/_button.scss +5 -0
- package/styles/scss/components/form/_form.scss +8 -0
- package/styles/scss/components/sidenav/_sidenav.scss +5 -2
- package/styles/scss/components/toggle/_toggle.scss +1 -0
- package/styles/scss/df-styles-namespace.scss +3 -1
- package/styles/scss/df-styles.scss +3 -1
- package/styles/scss/themes/brand2023/_variables.scss +80 -28
- package/esm2022/design-factory.mjs +0 -5
- package/esm2022/environment.mjs +0 -5
- package/esm2022/index.mjs +0 -5
- package/esm2022/lib/angular/accessibility/accessibility.module.mjs +0 -19
- package/esm2022/lib/angular/accessibility/components/skip-links-container/skip-links-container.component.mjs +0 -32
- package/esm2022/lib/angular/accessibility/directives/skip-link.directive.mjs +0 -64
- package/esm2022/lib/angular/alert/alert.module.mjs +0 -17
- package/esm2022/lib/angular/animation/ngbTransition.mjs +0 -76
- package/esm2022/lib/angular/animation/util.mjs +0 -30
- package/esm2022/lib/angular/card/card-advanced.module.mjs +0 -17
- package/esm2022/lib/angular/card/manage-card-selection.directive.mjs +0 -47
- package/esm2022/lib/angular/datepicker/closedatepicker.directive.mjs +0 -38
- package/esm2022/lib/angular/datepicker/datepicker-keyboard-nav.service.mjs +0 -39
- package/esm2022/lib/angular/datepicker/datepicker-range.directive.mjs +0 -101
- package/esm2022/lib/angular/datepicker/datepicker-range.service.mjs +0 -97
- package/esm2022/lib/angular/datepicker/datepicker.module.mjs +0 -42
- package/esm2022/lib/angular/df.module.mjs +0 -102
- package/esm2022/lib/angular/footer/footer.module.mjs +0 -17
- package/esm2022/lib/angular/icon/amadeus-icon.mjs +0 -79
- package/esm2022/lib/angular/icon/icon.module.mjs +0 -17
- package/esm2022/lib/angular/icon/insert/insert-icon.directive.mjs +0 -47
- package/esm2022/lib/angular/icon/insert/insert-icon.module.mjs +0 -17
- package/esm2022/lib/angular/inputs/click/trigger-click.directive.mjs +0 -28
- package/esm2022/lib/angular/inputs/icon/inputicon.directive.mjs +0 -95
- package/esm2022/lib/angular/inputs/input-advanced.module.mjs +0 -19
- package/esm2022/lib/angular/mediaqueries/ifMedia.directive.mjs +0 -52
- package/esm2022/lib/angular/mediaqueries/media.module.mjs +0 -17
- package/esm2022/lib/angular/mediaqueries/media.service.mjs +0 -46
- package/esm2022/lib/angular/mediaqueries/mediaUtils.service.mjs +0 -185
- package/esm2022/lib/angular/modal/modal.service.mjs +0 -36
- package/esm2022/lib/angular/popover/config/popover.config.mjs +0 -15
- package/esm2022/lib/angular/popover/popover.module.mjs +0 -17
- package/esm2022/lib/angular/progressbar/progressbar.component.mjs +0 -156
- package/esm2022/lib/angular/progressbar/progressbar.module.mjs +0 -18
- package/esm2022/lib/angular/progressindicator/default/default-spinner.component.mjs +0 -23
- package/esm2022/lib/angular/progressindicator/progressindicator-backdrop.component.mjs +0 -29
- package/esm2022/lib/angular/progressindicator/progressindicator-config.mjs +0 -25
- package/esm2022/lib/angular/progressindicator/progressindicator-container.component.mjs +0 -52
- package/esm2022/lib/angular/progressindicator/progressindicator-ref.mjs +0 -8
- package/esm2022/lib/angular/progressindicator/progressindicator.directive.mjs +0 -39
- package/esm2022/lib/angular/progressindicator/progressindicator.module.mjs +0 -45
- package/esm2022/lib/angular/progressindicator/progressindicator.service.mjs +0 -170
- package/esm2022/lib/angular/right-to-left/directionDetection.service.mjs +0 -32
- package/esm2022/lib/angular/selects/events/manage-badge-events.directive.mjs +0 -65
- package/esm2022/lib/angular/selects/nav/manage-nav-select.directive.mjs +0 -108
- package/esm2022/lib/angular/selects/option-highlight.directive.mjs +0 -59
- package/esm2022/lib/angular/selects/select.model.mjs +0 -2
- package/esm2022/lib/angular/selects/select.module.mjs +0 -22
- package/esm2022/lib/angular/sidenav/dfSideNavAnimation.mjs +0 -73
- package/esm2022/lib/angular/sidenav/dfSideNavCollapse.mjs +0 -94
- package/esm2022/lib/angular/sidenav/dfSideNavCollapse.module.mjs +0 -18
- package/esm2022/lib/angular/sidenav/dfSideNavCollapse.service.mjs +0 -37
- package/esm2022/lib/angular/sidenav/dfSideNavCollapseConfig.mjs +0 -27
- package/esm2022/lib/angular/sidenav/excludeTrap.directive.mjs +0 -55
- package/esm2022/lib/angular/sidenav/manage-sidenav.directive.mjs +0 -26
- package/esm2022/lib/angular/sidenav/sidenav-config.mjs +0 -25
- package/esm2022/lib/angular/sidenav/sidenav.component.mjs +0 -86
- package/esm2022/lib/angular/sidenav/sidenav.module.mjs +0 -52
- package/esm2022/lib/angular/sidenav/sidenav.service.mjs +0 -316
- package/esm2022/lib/angular/sidenav/sidenavlist.component.mjs +0 -59
- package/esm2022/lib/angular/slider/direction/sliderdirection.directive.mjs +0 -36
- package/esm2022/lib/angular/slider/lib/change-context.mjs +0 -3
- package/esm2022/lib/angular/slider/lib/compatibility-helper.mjs +0 -15
- package/esm2022/lib/angular/slider/lib/event-listener-helper.mjs +0 -77
- package/esm2022/lib/angular/slider/lib/event-listener.mjs +0 -3
- package/esm2022/lib/angular/slider/lib/math-helper.mjs +0 -15
- package/esm2022/lib/angular/slider/lib/options.mjs +0 -123
- package/esm2022/lib/angular/slider/lib/pointer-type.mjs +0 -9
- package/esm2022/lib/angular/slider/lib/slider-element.directive.mjs +0 -190
- package/esm2022/lib/angular/slider/lib/slider-handle.directive.mjs +0 -65
- package/esm2022/lib/angular/slider/lib/slider-label.directive.mjs +0 -41
- package/esm2022/lib/angular/slider/lib/slider.component.mjs +0 -1998
- package/esm2022/lib/angular/slider/lib/tooltip-wrapper.component.mjs +0 -23
- package/esm2022/lib/angular/slider/lib/value-helper.mjs +0 -50
- package/esm2022/lib/angular/slider/slider.module.mjs +0 -37
- package/esm2022/lib/angular/stepper/stepper.component.mjs +0 -65
- package/esm2022/lib/angular/stepper/stepper.directive.mjs +0 -174
- package/esm2022/lib/angular/stepper/stepper.module.mjs +0 -17
- package/esm2022/lib/angular/stepper/stepper.service.mjs +0 -213
- package/esm2022/lib/angular/toast/toast.module.mjs +0 -17
- package/esm2022/lib/angular/tooltip/tooltip.module.mjs +0 -18
- package/esm2022/lib/angular/tooltip/truncate/tooltipTruncate.directive.mjs +0 -31
- package/esm2022/lib/angular/utils/html-element-helper.mjs +0 -8
- package/esm2022/lib/angular/utils/scrollbar.service.mjs +0 -79
- package/esm2022/lib/angular/utils/titleTruncate.directive.mjs +0 -39
- package/esm2022/lib/angular/waves-of-progress/waves.directive.mjs +0 -86
- package/esm2022/lib/angular/waves-of-progress/waves.module.mjs +0 -16
- package/esm2022/lib/index.mjs +0 -93
- package/lib/angular/datepicker/closedatepicker.directive.d.ts +0 -10
|
@@ -1,1998 +0,0 @@
|
|
|
1
|
-
import { Component, ViewChild, HostBinding, HostListener, Input, EventEmitter, Output, ContentChild, forwardRef } from '@angular/core';
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
|
-
import { distinctUntilChanged, filter } from 'rxjs/operators';
|
|
5
|
-
import { Options, LabelType } from './options';
|
|
6
|
-
import { PointerType } from './pointer-type';
|
|
7
|
-
import { ChangeContext } from './change-context';
|
|
8
|
-
import { ValueHelper } from './value-helper';
|
|
9
|
-
import { CompatibilityHelper } from './compatibility-helper';
|
|
10
|
-
import { MathHelper } from './math-helper';
|
|
11
|
-
import { EventListenerHelper, supportsPassiveEvents } from './event-listener-helper';
|
|
12
|
-
import { SliderElementDirective } from './slider-element.directive';
|
|
13
|
-
import { SliderHandleDirective } from './slider-handle.directive';
|
|
14
|
-
import { SliderLabelDirective } from './slider-label.directive';
|
|
15
|
-
import { CommonModule } from '@angular/common';
|
|
16
|
-
import { TooltipWrapperComponent } from './tooltip-wrapper.component';
|
|
17
|
-
import * as i0 from "@angular/core";
|
|
18
|
-
import * as i1 from "@angular/common";
|
|
19
|
-
export class Tick {
|
|
20
|
-
constructor() {
|
|
21
|
-
this.selected = false;
|
|
22
|
-
this.style = {};
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
class Dragging {
|
|
26
|
-
constructor() {
|
|
27
|
-
this.active = false;
|
|
28
|
-
this.value = 0;
|
|
29
|
-
this.difference = 0;
|
|
30
|
-
this.position = 0;
|
|
31
|
-
this.lowLimit = 0;
|
|
32
|
-
this.highLimit = 0;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
class ModelValues {
|
|
36
|
-
static compare(x, y) {
|
|
37
|
-
if (ValueHelper.isNullOrUndefined(x) && ValueHelper.isNullOrUndefined(y)) {
|
|
38
|
-
return false;
|
|
39
|
-
}
|
|
40
|
-
if (ValueHelper.isNullOrUndefined(x) !== ValueHelper.isNullOrUndefined(y)) {
|
|
41
|
-
return false;
|
|
42
|
-
}
|
|
43
|
-
return x.value === y.value && x.highValue === y.highValue;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
class ModelChange extends ModelValues {
|
|
47
|
-
static compare(x, y) {
|
|
48
|
-
if (ValueHelper.isNullOrUndefined(x) && ValueHelper.isNullOrUndefined(y)) {
|
|
49
|
-
return false;
|
|
50
|
-
}
|
|
51
|
-
if (ValueHelper.isNullOrUndefined(x) !== ValueHelper.isNullOrUndefined(y)) {
|
|
52
|
-
return false;
|
|
53
|
-
}
|
|
54
|
-
return x.value === y.value && x.highValue === y.highValue && x.forceChange === y.forceChange;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
class InputModelChange extends ModelChange {
|
|
58
|
-
}
|
|
59
|
-
class OutputModelChange extends ModelChange {
|
|
60
|
-
}
|
|
61
|
-
const NGX_SLIDER_CONTROL_VALUE_ACCESSOR = {
|
|
62
|
-
provide: NG_VALUE_ACCESSOR,
|
|
63
|
-
/* tslint:disable-next-line: no-use-before-declare */
|
|
64
|
-
useExisting: forwardRef(() => SliderComponent),
|
|
65
|
-
multi: true
|
|
66
|
-
};
|
|
67
|
-
/**
|
|
68
|
-
* @deprecated SliderComponent is deprecated. Use {@link https://design-factory-int.app.net6.paas.westeurope.rnd.az.amadeus.net/#/components/slider/agnosui AgnosUI Slider} instead.
|
|
69
|
-
*/
|
|
70
|
-
export class SliderComponent {
|
|
71
|
-
// Input event that triggers slider refresh (re-positioning of slider elements)
|
|
72
|
-
set manualRefresh(manualRefresh) {
|
|
73
|
-
this.unsubscribeManualRefresh();
|
|
74
|
-
this.manualRefreshSubscription = manualRefresh.subscribe(() => {
|
|
75
|
-
setTimeout(() => this.calculateViewDimensionsAndDetectChanges());
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
// Input event that triggers setting focus on given slider handle
|
|
79
|
-
set triggerFocus(triggerFocus) {
|
|
80
|
-
this.unsubscribeTriggerFocus();
|
|
81
|
-
this.triggerFocusSubscription = triggerFocus.subscribe((pointerType) => {
|
|
82
|
-
this.focusPointer(pointerType);
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
// Slider type, true means range slider
|
|
86
|
-
get range() {
|
|
87
|
-
return !ValueHelper.isNullOrUndefined(this.value) && !ValueHelper.isNullOrUndefined(this.highValue);
|
|
88
|
-
}
|
|
89
|
-
// Whether to show/hide ticks
|
|
90
|
-
get showTicks() {
|
|
91
|
-
return this.viewOptions.showTicks || false;
|
|
92
|
-
}
|
|
93
|
-
constructor(renderer, elementRef, changeDetectionRef, zone) {
|
|
94
|
-
this.renderer = renderer;
|
|
95
|
-
this.elementRef = elementRef;
|
|
96
|
-
this.changeDetectionRef = changeDetectionRef;
|
|
97
|
-
this.zone = zone;
|
|
98
|
-
this.class = 'ngx-slider';
|
|
99
|
-
// Output for low value slider to support two-way bindings
|
|
100
|
-
this.valueChange = new EventEmitter();
|
|
101
|
-
// Output for high value slider to support two-way bindings
|
|
102
|
-
this.highValueChange = new EventEmitter();
|
|
103
|
-
// An object with all the other options of the slider.
|
|
104
|
-
// Each option can be updated at runtime and the slider will automatically be re-rendered.
|
|
105
|
-
this.options = new Options();
|
|
106
|
-
// Event emitted when user starts interaction with the slider
|
|
107
|
-
this.userChangeStart = new EventEmitter();
|
|
108
|
-
// Event emitted on each change coming from user interaction
|
|
109
|
-
this.userChange = new EventEmitter();
|
|
110
|
-
// Event emitted when user finishes interaction with the slider
|
|
111
|
-
this.userChangeEnd = new EventEmitter();
|
|
112
|
-
// Set to true if init method already executed
|
|
113
|
-
this.initHasRun = false;
|
|
114
|
-
// Changes in model inputs are passed through this subject
|
|
115
|
-
// These are all changes coming in from outside the component through input bindings or reactive form inputs
|
|
116
|
-
this.inputModelChangeSubject = new Subject();
|
|
117
|
-
// Changes to model outputs are passed through this subject
|
|
118
|
-
// These are all changes that need to be communicated to output emitters and registered callbacks
|
|
119
|
-
this.outputModelChangeSubject = new Subject();
|
|
120
|
-
// Options synced to model options, based on defaults
|
|
121
|
-
this.viewOptions = new Options();
|
|
122
|
-
// Half of the width or height of the slider handles
|
|
123
|
-
this.handleHalfDimension = 0;
|
|
124
|
-
// Maximum position the slider handle can have
|
|
125
|
-
this.maxHandlePosition = 0;
|
|
126
|
-
// Used to call onStart on the first keydown event
|
|
127
|
-
this.firstKeyDown = false;
|
|
128
|
-
// Values recorded when first dragging the bar
|
|
129
|
-
this.dragging = new Dragging();
|
|
130
|
-
// Host element class bindings
|
|
131
|
-
this.sliderElementVerticalClass = false;
|
|
132
|
-
this.sliderElementAnimateClass = false;
|
|
133
|
-
this.sliderElementWithLegendClass = false;
|
|
134
|
-
this.sliderElementAriaLabel = 'ngx-slider';
|
|
135
|
-
// CSS styles and class flags
|
|
136
|
-
this.barStyle = {};
|
|
137
|
-
this.minPointerStyle = {};
|
|
138
|
-
this.maxPointerStyle = {};
|
|
139
|
-
this.fullBarTransparentClass = false;
|
|
140
|
-
this.selectionBarDraggableClass = false;
|
|
141
|
-
this.ticksUnderValuesClass = false;
|
|
142
|
-
/* If tickStep is set or ticksArray is specified.
|
|
143
|
-
In this case, ticks values should be displayed below the slider. */
|
|
144
|
-
this.intermediateTicks = false;
|
|
145
|
-
// Ticks array as displayed in view
|
|
146
|
-
this.ticks = [];
|
|
147
|
-
// Whether currently moving the slider (between onStart() and onEnd())
|
|
148
|
-
this.moving = false;
|
|
149
|
-
this.eventListenerHelper = new EventListenerHelper(this.renderer);
|
|
150
|
-
}
|
|
151
|
-
// OnInit interface
|
|
152
|
-
ngOnInit() {
|
|
153
|
-
this.viewOptions = new Options();
|
|
154
|
-
Object.assign(this.viewOptions, this.options);
|
|
155
|
-
// We need to run these two things first, before the rest of the init in ngAfterViewInit(),
|
|
156
|
-
// because these two settings are set through @HostBinding and Angular change detection
|
|
157
|
-
// mechanism doesn't like them changing in ngAfterViewInit()
|
|
158
|
-
this.updateDisabledState();
|
|
159
|
-
this.updateVerticalState();
|
|
160
|
-
this.updateAriaLabel();
|
|
161
|
-
}
|
|
162
|
-
// AfterViewInit interface
|
|
163
|
-
ngAfterViewInit() {
|
|
164
|
-
this.applyOptions();
|
|
165
|
-
this.subscribeInputModelChangeSubject();
|
|
166
|
-
this.subscribeOutputModelChangeSubject();
|
|
167
|
-
// Once we apply options, we need to normalise model values for the first time
|
|
168
|
-
this.renormaliseModelValues();
|
|
169
|
-
this.viewLowValue = this.modelValueToViewValue(this.value);
|
|
170
|
-
if (this.range) {
|
|
171
|
-
this.viewHighValue = this.modelValueToViewValue(this.highValue);
|
|
172
|
-
}
|
|
173
|
-
else {
|
|
174
|
-
this.viewHighValue = undefined;
|
|
175
|
-
}
|
|
176
|
-
this.updateVerticalState(); // need to run this again to cover changes to slider elements
|
|
177
|
-
this.manageElementsStyle();
|
|
178
|
-
this.updateDisabledState();
|
|
179
|
-
this.calculateViewDimensions();
|
|
180
|
-
this.addAccessibility();
|
|
181
|
-
this.updateCeilLabel();
|
|
182
|
-
this.updateFloorLabel();
|
|
183
|
-
this.initHandles();
|
|
184
|
-
this.manageEventsBindings();
|
|
185
|
-
this.updateAriaLabel();
|
|
186
|
-
this.subscribeResizeObserver();
|
|
187
|
-
this.initHasRun = true;
|
|
188
|
-
// Run change detection manually to resolve some issues when init procedure changes values used in the view
|
|
189
|
-
if (!this.isRefDestroyed()) {
|
|
190
|
-
this.changeDetectionRef.detectChanges();
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
// OnChanges interface
|
|
194
|
-
ngOnChanges(changes) {
|
|
195
|
-
// Always apply options first
|
|
196
|
-
const options = changes['options'];
|
|
197
|
-
if (!ValueHelper.isNullOrUndefined(options) &&
|
|
198
|
-
JSON.stringify(options.previousValue) !== JSON.stringify(options.currentValue)) {
|
|
199
|
-
this.onChangeOptions();
|
|
200
|
-
}
|
|
201
|
-
// Then value changes
|
|
202
|
-
if (!ValueHelper.isNullOrUndefined(changes['value']) || !ValueHelper.isNullOrUndefined(changes['highValue'])) {
|
|
203
|
-
this.inputModelChangeSubject.next({
|
|
204
|
-
value: this.value,
|
|
205
|
-
highValue: this.highValue,
|
|
206
|
-
forceChange: false,
|
|
207
|
-
internalChange: false
|
|
208
|
-
});
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
// OnDestroy interface
|
|
212
|
-
ngOnDestroy() {
|
|
213
|
-
this.unbindEvents();
|
|
214
|
-
this.unsubscribeResizeObserver();
|
|
215
|
-
this.unsubscribeInputModelChangeSubject();
|
|
216
|
-
this.unsubscribeOutputModelChangeSubject();
|
|
217
|
-
this.unsubscribeManualRefresh();
|
|
218
|
-
this.unsubscribeTriggerFocus();
|
|
219
|
-
}
|
|
220
|
-
// ControlValueAccessor interface
|
|
221
|
-
writeValue(obj) {
|
|
222
|
-
if (obj instanceof Array) {
|
|
223
|
-
this.value = obj[0];
|
|
224
|
-
this.highValue = obj[1];
|
|
225
|
-
}
|
|
226
|
-
else {
|
|
227
|
-
this.value = obj;
|
|
228
|
-
}
|
|
229
|
-
// ngOnChanges() is not called in this instance, so we need to communicate the change manually
|
|
230
|
-
this.inputModelChangeSubject.next({
|
|
231
|
-
value: this.value,
|
|
232
|
-
highValue: this.highValue,
|
|
233
|
-
forceChange: false,
|
|
234
|
-
internalChange: false
|
|
235
|
-
});
|
|
236
|
-
}
|
|
237
|
-
// ControlValueAccessor interface
|
|
238
|
-
registerOnChange(onChangeCallback) {
|
|
239
|
-
this.onChangeCallback = onChangeCallback;
|
|
240
|
-
}
|
|
241
|
-
// ControlValueAccessor interface
|
|
242
|
-
registerOnTouched(onTouchedCallback) {
|
|
243
|
-
this.onTouchedCallback = onTouchedCallback;
|
|
244
|
-
}
|
|
245
|
-
// ControlValueAccessor interface
|
|
246
|
-
setDisabledState(isDisabled) {
|
|
247
|
-
this.viewOptions.disabled = isDisabled;
|
|
248
|
-
this.updateDisabledState();
|
|
249
|
-
}
|
|
250
|
-
setAriaLabel(ariaLabel) {
|
|
251
|
-
this.viewOptions.ariaLabel = ariaLabel;
|
|
252
|
-
this.updateAriaLabel();
|
|
253
|
-
}
|
|
254
|
-
onResize(event) {
|
|
255
|
-
this.calculateViewDimensionsAndDetectChanges();
|
|
256
|
-
}
|
|
257
|
-
subscribeInputModelChangeSubject() {
|
|
258
|
-
this.inputModelChangeSubscription = this.inputModelChangeSubject
|
|
259
|
-
.pipe(distinctUntilChanged(ModelChange.compare),
|
|
260
|
-
// Hack to reset the status of the distinctUntilChanged() - if a "fake" event comes through with forceChange=true,
|
|
261
|
-
// we forcefully by-pass distinctUntilChanged(), but otherwise drop the event
|
|
262
|
-
filter((modelChange) => !modelChange.forceChange && !modelChange.internalChange))
|
|
263
|
-
.subscribe((modelChange) => this.applyInputModelChange(modelChange));
|
|
264
|
-
}
|
|
265
|
-
subscribeOutputModelChangeSubject() {
|
|
266
|
-
this.outputModelChangeSubscription = this.outputModelChangeSubject
|
|
267
|
-
.pipe(distinctUntilChanged(ModelChange.compare))
|
|
268
|
-
.subscribe((modelChange) => this.publishOutputModelChange(modelChange));
|
|
269
|
-
}
|
|
270
|
-
subscribeResizeObserver() {
|
|
271
|
-
if (CompatibilityHelper.isResizeObserverAvailable()) {
|
|
272
|
-
this.resizeObserver = new ResizeObserver(() => this.calculateViewDimensionsAndDetectChanges());
|
|
273
|
-
this.resizeObserver.observe(this.elementRef.nativeElement);
|
|
274
|
-
}
|
|
275
|
-
}
|
|
276
|
-
unsubscribeResizeObserver() {
|
|
277
|
-
if (CompatibilityHelper.isResizeObserverAvailable() && this.resizeObserver !== null) {
|
|
278
|
-
this.resizeObserver?.disconnect();
|
|
279
|
-
this.resizeObserver = undefined;
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
unsubscribeOnMove() {
|
|
283
|
-
if (!ValueHelper.isNullOrUndefined(this.onMoveEventListener)) {
|
|
284
|
-
this.eventListenerHelper?.detachEventListener(this.onMoveEventListener);
|
|
285
|
-
this.onMoveEventListener = undefined;
|
|
286
|
-
}
|
|
287
|
-
}
|
|
288
|
-
unsubscribeOnEnd() {
|
|
289
|
-
if (!ValueHelper.isNullOrUndefined(this.onEndEventListener)) {
|
|
290
|
-
this.eventListenerHelper?.detachEventListener(this.onEndEventListener);
|
|
291
|
-
this.onEndEventListener = undefined;
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
unsubscribeInputModelChangeSubject() {
|
|
295
|
-
if (!ValueHelper.isNullOrUndefined(this.inputModelChangeSubscription)) {
|
|
296
|
-
this.inputModelChangeSubscription?.unsubscribe();
|
|
297
|
-
this.inputModelChangeSubscription = undefined;
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
unsubscribeOutputModelChangeSubject() {
|
|
301
|
-
if (!ValueHelper.isNullOrUndefined(this.outputModelChangeSubscription)) {
|
|
302
|
-
this.outputModelChangeSubscription?.unsubscribe();
|
|
303
|
-
this.outputModelChangeSubscription = undefined;
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
unsubscribeManualRefresh() {
|
|
307
|
-
if (!ValueHelper.isNullOrUndefined(this.manualRefreshSubscription)) {
|
|
308
|
-
this.manualRefreshSubscription.unsubscribe();
|
|
309
|
-
this.manualRefreshSubscription = undefined;
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
unsubscribeTriggerFocus() {
|
|
313
|
-
if (!ValueHelper.isNullOrUndefined(this.triggerFocusSubscription)) {
|
|
314
|
-
this.triggerFocusSubscription.unsubscribe();
|
|
315
|
-
this.triggerFocusSubscription = null;
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
getPointerElement(pointerType) {
|
|
319
|
-
if (pointerType === PointerType.Min) {
|
|
320
|
-
return this.minHandleElement;
|
|
321
|
-
}
|
|
322
|
-
else if (pointerType === PointerType.Max) {
|
|
323
|
-
return this.maxHandleElement;
|
|
324
|
-
}
|
|
325
|
-
return undefined;
|
|
326
|
-
}
|
|
327
|
-
getCurrentTrackingValue() {
|
|
328
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
329
|
-
return this.viewLowValue;
|
|
330
|
-
}
|
|
331
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
332
|
-
return this.viewHighValue;
|
|
333
|
-
}
|
|
334
|
-
return undefined;
|
|
335
|
-
}
|
|
336
|
-
modelValueToViewValue(modelValue) {
|
|
337
|
-
if (ValueHelper.isNullOrUndefined(modelValue)) {
|
|
338
|
-
return NaN;
|
|
339
|
-
}
|
|
340
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray) && !this.viewOptions.bindIndexForStepsArray) {
|
|
341
|
-
return ValueHelper.findStepIndex(+modelValue, this.viewOptions.stepsArray);
|
|
342
|
-
}
|
|
343
|
-
return +modelValue;
|
|
344
|
-
}
|
|
345
|
-
viewValueToModelValue(viewValue) {
|
|
346
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray) && !this.viewOptions.bindIndexForStepsArray) {
|
|
347
|
-
return this.getStepValue(viewValue);
|
|
348
|
-
}
|
|
349
|
-
return viewValue;
|
|
350
|
-
}
|
|
351
|
-
getStepValue(sliderValue) {
|
|
352
|
-
const step = this.viewOptions.stepsArray[sliderValue];
|
|
353
|
-
return !ValueHelper.isNullOrUndefined(step) ? step.value : NaN;
|
|
354
|
-
}
|
|
355
|
-
applyViewChange() {
|
|
356
|
-
this.value = this.viewValueToModelValue(this.viewLowValue);
|
|
357
|
-
if (this.range) {
|
|
358
|
-
this.highValue = this.viewValueToModelValue(this.viewHighValue);
|
|
359
|
-
}
|
|
360
|
-
this.outputModelChangeSubject.next({
|
|
361
|
-
value: this.value,
|
|
362
|
-
highValue: this.highValue,
|
|
363
|
-
userEventInitiated: true,
|
|
364
|
-
forceChange: false
|
|
365
|
-
});
|
|
366
|
-
// At this point all changes are applied and outputs are emitted, so we should be done.
|
|
367
|
-
// However, input changes are communicated in different stream and we need to be ready to
|
|
368
|
-
// act on the next input change even if it is exactly the same as last input change.
|
|
369
|
-
// Therefore, we send a special event to reset the stream.
|
|
370
|
-
this.inputModelChangeSubject.next({
|
|
371
|
-
value: this.value,
|
|
372
|
-
highValue: this.highValue,
|
|
373
|
-
forceChange: false,
|
|
374
|
-
internalChange: true
|
|
375
|
-
});
|
|
376
|
-
}
|
|
377
|
-
// Apply model change to the slider view
|
|
378
|
-
applyInputModelChange(modelChange) {
|
|
379
|
-
const normalisedModelChange = this.normaliseModelValues(modelChange);
|
|
380
|
-
// If normalised model change is different, apply the change to the model values
|
|
381
|
-
const normalisationChange = !ModelValues.compare(modelChange, normalisedModelChange);
|
|
382
|
-
if (normalisationChange) {
|
|
383
|
-
this.value = normalisedModelChange.value;
|
|
384
|
-
this.highValue = normalisedModelChange.highValue;
|
|
385
|
-
}
|
|
386
|
-
this.viewLowValue = this.modelValueToViewValue(normalisedModelChange.value);
|
|
387
|
-
if (this.range) {
|
|
388
|
-
this.viewHighValue = this.modelValueToViewValue(normalisedModelChange.highValue);
|
|
389
|
-
}
|
|
390
|
-
else {
|
|
391
|
-
this.viewHighValue = undefined;
|
|
392
|
-
}
|
|
393
|
-
this.updateLowHandle(this.valueToPosition(this.viewLowValue));
|
|
394
|
-
if (this.range) {
|
|
395
|
-
this.updateHighHandle(this.valueToPosition(this.viewHighValue));
|
|
396
|
-
}
|
|
397
|
-
this.updateSelectionBar();
|
|
398
|
-
this.updateTicksScale();
|
|
399
|
-
this.updateAriaAttributes();
|
|
400
|
-
if (this.range) {
|
|
401
|
-
this.updateCombinedLabel();
|
|
402
|
-
}
|
|
403
|
-
// At the end, we need to communicate the model change to the outputs as well
|
|
404
|
-
// Normalisation changes are also always forced out to ensure that subscribers always end up in correct state
|
|
405
|
-
this.outputModelChangeSubject.next({
|
|
406
|
-
value: normalisedModelChange.value,
|
|
407
|
-
highValue: normalisedModelChange.highValue,
|
|
408
|
-
forceChange: normalisationChange,
|
|
409
|
-
userEventInitiated: false
|
|
410
|
-
});
|
|
411
|
-
}
|
|
412
|
-
// Publish model change to output event emitters and registered callbacks
|
|
413
|
-
publishOutputModelChange(modelChange) {
|
|
414
|
-
const emitOutputs = () => {
|
|
415
|
-
this.valueChange.emit(modelChange.value);
|
|
416
|
-
if (this.range) {
|
|
417
|
-
this.highValueChange.emit(modelChange.highValue);
|
|
418
|
-
}
|
|
419
|
-
if (!ValueHelper.isNullOrUndefined(this.onChangeCallback)) {
|
|
420
|
-
if (this.range) {
|
|
421
|
-
this.onChangeCallback([modelChange.value, modelChange.highValue]);
|
|
422
|
-
}
|
|
423
|
-
else {
|
|
424
|
-
this.onChangeCallback(modelChange.value);
|
|
425
|
-
}
|
|
426
|
-
}
|
|
427
|
-
if (!ValueHelper.isNullOrUndefined(this.onTouchedCallback)) {
|
|
428
|
-
if (this.range) {
|
|
429
|
-
this.onTouchedCallback([modelChange.value, modelChange.highValue]);
|
|
430
|
-
}
|
|
431
|
-
else {
|
|
432
|
-
this.onTouchedCallback(modelChange.value);
|
|
433
|
-
}
|
|
434
|
-
}
|
|
435
|
-
};
|
|
436
|
-
if (modelChange.userEventInitiated) {
|
|
437
|
-
// If this change was initiated by a user event, we can emit outputs in the same tick
|
|
438
|
-
emitOutputs();
|
|
439
|
-
this.userChange.emit(this.getChangeContext());
|
|
440
|
-
}
|
|
441
|
-
else {
|
|
442
|
-
// But, if the change was initated by something else like a change in input bindings,
|
|
443
|
-
// we need to wait until next tick to emit the outputs to keep Angular change detection happy
|
|
444
|
-
setTimeout(() => {
|
|
445
|
-
emitOutputs();
|
|
446
|
-
});
|
|
447
|
-
}
|
|
448
|
-
}
|
|
449
|
-
normaliseModelValues(input) {
|
|
450
|
-
const normalisedInput = new ModelValues();
|
|
451
|
-
normalisedInput.value = input.value;
|
|
452
|
-
normalisedInput.highValue = input.highValue;
|
|
453
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray)) {
|
|
454
|
-
// When using steps array, only round to nearest step in the array
|
|
455
|
-
// No other enforcement can be done, as the step array may be out of order, and that is perfectly fine
|
|
456
|
-
if (this.viewOptions.enforceStepsArray) {
|
|
457
|
-
const valueIndex = ValueHelper.findStepIndex(normalisedInput.value, this.viewOptions.stepsArray);
|
|
458
|
-
normalisedInput.value = this.viewOptions.stepsArray[valueIndex].value;
|
|
459
|
-
if (this.range) {
|
|
460
|
-
const highValueIndex = ValueHelper.findStepIndex(normalisedInput.highValue, this.viewOptions.stepsArray);
|
|
461
|
-
normalisedInput.highValue = this.viewOptions.stepsArray[highValueIndex].value;
|
|
462
|
-
}
|
|
463
|
-
}
|
|
464
|
-
return normalisedInput;
|
|
465
|
-
}
|
|
466
|
-
if (this.viewOptions.enforceStep) {
|
|
467
|
-
normalisedInput.value = this.roundStep(normalisedInput.value);
|
|
468
|
-
if (this.range) {
|
|
469
|
-
normalisedInput.highValue = this.roundStep(normalisedInput.highValue);
|
|
470
|
-
}
|
|
471
|
-
}
|
|
472
|
-
if (this.viewOptions.enforceRange) {
|
|
473
|
-
normalisedInput.value = MathHelper.clampToRange(normalisedInput.value, this.viewOptions.floor, this.viewOptions.ceil);
|
|
474
|
-
if (this.range) {
|
|
475
|
-
normalisedInput.highValue = MathHelper.clampToRange(normalisedInput.highValue, this.viewOptions.floor, this.viewOptions.ceil);
|
|
476
|
-
}
|
|
477
|
-
// Make sure that range slider invariant (value <= highValue) is always satisfied
|
|
478
|
-
if (this.range && input.value > input.highValue) {
|
|
479
|
-
// We know that both values are now clamped correctly, they may just be in the wrong order
|
|
480
|
-
// So the easy solution is to swap them... except swapping is sometimes disabled in options, so we make the two values the same
|
|
481
|
-
if (this.viewOptions.noSwitching) {
|
|
482
|
-
normalisedInput.value = normalisedInput.highValue;
|
|
483
|
-
}
|
|
484
|
-
else {
|
|
485
|
-
const tempValue = input.value;
|
|
486
|
-
normalisedInput.value = input.highValue;
|
|
487
|
-
normalisedInput.highValue = tempValue;
|
|
488
|
-
}
|
|
489
|
-
}
|
|
490
|
-
}
|
|
491
|
-
return normalisedInput;
|
|
492
|
-
}
|
|
493
|
-
renormaliseModelValues() {
|
|
494
|
-
const previousModelValues = {
|
|
495
|
-
value: this.value,
|
|
496
|
-
highValue: this.highValue
|
|
497
|
-
};
|
|
498
|
-
const normalisedModelValues = this.normaliseModelValues(previousModelValues);
|
|
499
|
-
if (!ModelValues.compare(normalisedModelValues, previousModelValues)) {
|
|
500
|
-
this.value = normalisedModelValues.value;
|
|
501
|
-
this.highValue = normalisedModelValues.highValue;
|
|
502
|
-
this.outputModelChangeSubject.next({
|
|
503
|
-
value: this.value,
|
|
504
|
-
highValue: this.highValue,
|
|
505
|
-
forceChange: true,
|
|
506
|
-
userEventInitiated: false
|
|
507
|
-
});
|
|
508
|
-
}
|
|
509
|
-
}
|
|
510
|
-
onChangeOptions() {
|
|
511
|
-
if (!this.initHasRun) {
|
|
512
|
-
return;
|
|
513
|
-
}
|
|
514
|
-
const previousOptionsInfluencingEventBindings = this.getOptionsInfluencingEventBindings(this.viewOptions);
|
|
515
|
-
this.applyOptions();
|
|
516
|
-
const newOptionsInfluencingEventBindings = this.getOptionsInfluencingEventBindings(this.viewOptions);
|
|
517
|
-
// Avoid re-binding events in case nothing changes that can influence it
|
|
518
|
-
// It makes it possible to change options while dragging the slider
|
|
519
|
-
const rebindEvents = !ValueHelper.areArraysEqual(previousOptionsInfluencingEventBindings, newOptionsInfluencingEventBindings);
|
|
520
|
-
// With new options, we need to re-normalise model values if necessary
|
|
521
|
-
this.renormaliseModelValues();
|
|
522
|
-
this.viewLowValue = this.modelValueToViewValue(this.value);
|
|
523
|
-
if (this.range) {
|
|
524
|
-
this.viewHighValue = this.modelValueToViewValue(this.highValue);
|
|
525
|
-
}
|
|
526
|
-
else {
|
|
527
|
-
this.viewHighValue = undefined;
|
|
528
|
-
}
|
|
529
|
-
this.resetSlider(rebindEvents);
|
|
530
|
-
}
|
|
531
|
-
// Read the user options and apply them to the slider model
|
|
532
|
-
applyOptions() {
|
|
533
|
-
this.viewOptions = new Options();
|
|
534
|
-
Object.assign(this.viewOptions, this.options);
|
|
535
|
-
this.viewOptions.draggableRange = this.range && this.viewOptions.draggableRange;
|
|
536
|
-
this.viewOptions.draggableRangeOnly = this.range && this.viewOptions.draggableRangeOnly;
|
|
537
|
-
if (this.viewOptions.draggableRangeOnly) {
|
|
538
|
-
this.viewOptions.draggableRange = true;
|
|
539
|
-
}
|
|
540
|
-
this.viewOptions.showTicks =
|
|
541
|
-
this.viewOptions.showTicks ||
|
|
542
|
-
this.viewOptions.showTicksValues ||
|
|
543
|
-
!ValueHelper.isNullOrUndefined(this.viewOptions.ticksArray);
|
|
544
|
-
if (this.viewOptions.showTicks &&
|
|
545
|
-
(!ValueHelper.isNullOrUndefined(this.viewOptions.tickStep) ||
|
|
546
|
-
!ValueHelper.isNullOrUndefined(this.viewOptions.ticksArray))) {
|
|
547
|
-
this.intermediateTicks = true;
|
|
548
|
-
}
|
|
549
|
-
this.viewOptions.showSelectionBar =
|
|
550
|
-
this.viewOptions.showSelectionBar ||
|
|
551
|
-
this.viewOptions.showSelectionBarEnd ||
|
|
552
|
-
!ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue);
|
|
553
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray)) {
|
|
554
|
-
this.applyStepsArrayOptions();
|
|
555
|
-
}
|
|
556
|
-
else {
|
|
557
|
-
this.applyFloorCeilOptions();
|
|
558
|
-
}
|
|
559
|
-
if (ValueHelper.isNullOrUndefined(this.viewOptions.combineLabels)) {
|
|
560
|
-
this.viewOptions.combineLabels = (minValue, maxValue) => {
|
|
561
|
-
return minValue + ' - ' + maxValue;
|
|
562
|
-
};
|
|
563
|
-
}
|
|
564
|
-
if (this.viewOptions.logScale && this.viewOptions.floor === 0) {
|
|
565
|
-
throw Error("Can't use floor=0 with logarithmic scale");
|
|
566
|
-
}
|
|
567
|
-
}
|
|
568
|
-
applyStepsArrayOptions() {
|
|
569
|
-
this.viewOptions.floor = 0;
|
|
570
|
-
this.viewOptions.ceil = this.viewOptions.stepsArray.length - 1;
|
|
571
|
-
this.viewOptions.step = 1;
|
|
572
|
-
if (ValueHelper.isNullOrUndefined(this.viewOptions.translate)) {
|
|
573
|
-
this.viewOptions.translate = (modelValue) => {
|
|
574
|
-
if (this.viewOptions.bindIndexForStepsArray) {
|
|
575
|
-
return String(this.getStepValue(modelValue));
|
|
576
|
-
}
|
|
577
|
-
return String(modelValue);
|
|
578
|
-
};
|
|
579
|
-
}
|
|
580
|
-
}
|
|
581
|
-
applyFloorCeilOptions() {
|
|
582
|
-
if (ValueHelper.isNullOrUndefined(this.viewOptions.step)) {
|
|
583
|
-
this.viewOptions.step = 1;
|
|
584
|
-
}
|
|
585
|
-
else {
|
|
586
|
-
this.viewOptions.step = +this.viewOptions.step;
|
|
587
|
-
if (this.viewOptions.step <= 0) {
|
|
588
|
-
this.viewOptions.step = 1;
|
|
589
|
-
}
|
|
590
|
-
}
|
|
591
|
-
if (ValueHelper.isNullOrUndefined(this.viewOptions.ceil) || ValueHelper.isNullOrUndefined(this.viewOptions.floor)) {
|
|
592
|
-
throw Error('floor and ceil options must be supplied');
|
|
593
|
-
}
|
|
594
|
-
this.viewOptions.ceil = +this.viewOptions.ceil;
|
|
595
|
-
this.viewOptions.floor = +this.viewOptions.floor;
|
|
596
|
-
if (ValueHelper.isNullOrUndefined(this.viewOptions.translate)) {
|
|
597
|
-
this.viewOptions.translate = (value) => String(value);
|
|
598
|
-
}
|
|
599
|
-
}
|
|
600
|
-
// Resets slider
|
|
601
|
-
resetSlider(rebindEvents = true) {
|
|
602
|
-
this.manageElementsStyle();
|
|
603
|
-
this.addAccessibility();
|
|
604
|
-
this.updateCeilLabel();
|
|
605
|
-
this.updateFloorLabel();
|
|
606
|
-
if (rebindEvents) {
|
|
607
|
-
this.unbindEvents();
|
|
608
|
-
this.manageEventsBindings();
|
|
609
|
-
}
|
|
610
|
-
this.updateDisabledState();
|
|
611
|
-
this.updateAriaLabel();
|
|
612
|
-
this.calculateViewDimensions();
|
|
613
|
-
this.refocusPointerIfNeeded();
|
|
614
|
-
}
|
|
615
|
-
// Sets focus on the specified pointer
|
|
616
|
-
focusPointer(pointerType) {
|
|
617
|
-
// If not supplied, use min pointer as default
|
|
618
|
-
if (pointerType !== PointerType.Min && pointerType !== PointerType.Max) {
|
|
619
|
-
pointerType = PointerType.Min;
|
|
620
|
-
}
|
|
621
|
-
if (pointerType === PointerType.Min) {
|
|
622
|
-
this.minHandleElement?.focus();
|
|
623
|
-
}
|
|
624
|
-
else if (this.range && pointerType === PointerType.Max) {
|
|
625
|
-
this.maxHandleElement?.focus();
|
|
626
|
-
}
|
|
627
|
-
}
|
|
628
|
-
refocusPointerIfNeeded() {
|
|
629
|
-
if (!ValueHelper.isNullOrUndefined(this.currentFocusPointer)) {
|
|
630
|
-
this.onPointerFocus(this.currentFocusPointer);
|
|
631
|
-
const element = this.getPointerElement(this.currentFocusPointer);
|
|
632
|
-
element?.focus();
|
|
633
|
-
}
|
|
634
|
-
}
|
|
635
|
-
// Update each elements style based on options
|
|
636
|
-
manageElementsStyle() {
|
|
637
|
-
this.updateScale();
|
|
638
|
-
this.floorLabelElement?.setAlwaysHide(this.viewOptions.showTicksValues || this.viewOptions.hideLimitLabels);
|
|
639
|
-
this.ceilLabelElement?.setAlwaysHide(this.viewOptions.showTicksValues || this.viewOptions.hideLimitLabels);
|
|
640
|
-
const hideLabelsForTicks = this.viewOptions.showTicksValues && !this.intermediateTicks;
|
|
641
|
-
this.minHandleLabelElement?.setAlwaysHide(hideLabelsForTicks || this.viewOptions.hidePointerLabels);
|
|
642
|
-
this.maxHandleLabelElement?.setAlwaysHide(hideLabelsForTicks || !this.range || this.viewOptions.hidePointerLabels);
|
|
643
|
-
this.combinedLabelElement?.setAlwaysHide(hideLabelsForTicks || !this.range || this.viewOptions.hidePointerLabels);
|
|
644
|
-
this.selectionBarElement?.setAlwaysHide(!this.range && !this.viewOptions.showSelectionBar);
|
|
645
|
-
this.leftOuterSelectionBarElement?.setAlwaysHide(!this.range || !this.viewOptions.showOuterSelectionBars);
|
|
646
|
-
this.rightOuterSelectionBarElement?.setAlwaysHide(!this.range || !this.viewOptions.showOuterSelectionBars);
|
|
647
|
-
this.fullBarTransparentClass = this.range && this.viewOptions.showOuterSelectionBars;
|
|
648
|
-
this.selectionBarDraggableClass = this.viewOptions.draggableRange && !this.viewOptions.onlyBindHandles;
|
|
649
|
-
this.ticksUnderValuesClass = this.intermediateTicks && this.options.showTicksValues;
|
|
650
|
-
if (this.sliderElementVerticalClass !== this.viewOptions.vertical) {
|
|
651
|
-
this.updateVerticalState();
|
|
652
|
-
// The above change in host component class will not be applied until the end of this cycle
|
|
653
|
-
// However, functions calculating the slider position expect the slider to be already styled as vertical
|
|
654
|
-
// So as a workaround, we need to reset the slider once again to compute the correct values
|
|
655
|
-
setTimeout(() => {
|
|
656
|
-
this.resetSlider();
|
|
657
|
-
});
|
|
658
|
-
}
|
|
659
|
-
// Changing animate class may interfere with slider reset/initialisation, so we should set it separately,
|
|
660
|
-
// after all is properly set up
|
|
661
|
-
if (this.sliderElementAnimateClass !== this.viewOptions.animate) {
|
|
662
|
-
setTimeout(() => {
|
|
663
|
-
this.sliderElementAnimateClass = this.viewOptions.animate;
|
|
664
|
-
});
|
|
665
|
-
}
|
|
666
|
-
this.updateRotate();
|
|
667
|
-
}
|
|
668
|
-
// Manage the events bindings based on readOnly and disabled options
|
|
669
|
-
manageEventsBindings() {
|
|
670
|
-
if (this.viewOptions.disabled || this.viewOptions.readOnly) {
|
|
671
|
-
this.unbindEvents();
|
|
672
|
-
}
|
|
673
|
-
else {
|
|
674
|
-
this.bindEvents();
|
|
675
|
-
}
|
|
676
|
-
}
|
|
677
|
-
// Set the disabled state based on disabled option
|
|
678
|
-
updateDisabledState() {
|
|
679
|
-
this.sliderElementDisabledAttr = this.viewOptions.disabled ? 'disabled' : undefined;
|
|
680
|
-
}
|
|
681
|
-
// Set the aria-label state based on ariaLabel option
|
|
682
|
-
updateAriaLabel() {
|
|
683
|
-
this.sliderElementAriaLabel = this.viewOptions.ariaLabel || 'nxg-slider';
|
|
684
|
-
}
|
|
685
|
-
// Set vertical state based on vertical option
|
|
686
|
-
updateVerticalState() {
|
|
687
|
-
this.sliderElementVerticalClass = this.viewOptions.vertical;
|
|
688
|
-
for (const element of this.getAllSliderElements()) {
|
|
689
|
-
// This is also called before ngAfterInit, so need to check that view child bindings work
|
|
690
|
-
if (!ValueHelper.isNullOrUndefined(element)) {
|
|
691
|
-
element.setVertical(this.viewOptions.vertical);
|
|
692
|
-
}
|
|
693
|
-
}
|
|
694
|
-
}
|
|
695
|
-
updateScale() {
|
|
696
|
-
for (const element of this.getAllSliderElements()) {
|
|
697
|
-
element.setScale(this.viewOptions.scale);
|
|
698
|
-
}
|
|
699
|
-
}
|
|
700
|
-
updateRotate() {
|
|
701
|
-
for (const element of this.getAllSliderElements()) {
|
|
702
|
-
element.setRotate(this.viewOptions.rotate);
|
|
703
|
-
}
|
|
704
|
-
}
|
|
705
|
-
getAllSliderElements() {
|
|
706
|
-
return [
|
|
707
|
-
this.leftOuterSelectionBarElement,
|
|
708
|
-
this.rightOuterSelectionBarElement,
|
|
709
|
-
this.fullBarElement,
|
|
710
|
-
this.selectionBarElement,
|
|
711
|
-
this.minHandleElement,
|
|
712
|
-
this.maxHandleElement,
|
|
713
|
-
this.floorLabelElement,
|
|
714
|
-
this.ceilLabelElement,
|
|
715
|
-
this.minHandleLabelElement,
|
|
716
|
-
this.maxHandleLabelElement,
|
|
717
|
-
this.combinedLabelElement,
|
|
718
|
-
this.ticksElement
|
|
719
|
-
];
|
|
720
|
-
}
|
|
721
|
-
// Initialize slider handles positions and labels
|
|
722
|
-
// Run only once during initialization and every time view port changes size
|
|
723
|
-
initHandles() {
|
|
724
|
-
this.updateLowHandle(this.valueToPosition(this.viewLowValue));
|
|
725
|
-
/*
|
|
726
|
-
the order here is important since the selection bar should be
|
|
727
|
-
updated after the high handle but before the combined label
|
|
728
|
-
*/
|
|
729
|
-
if (this.range) {
|
|
730
|
-
this.updateHighHandle(this.valueToPosition(this.viewHighValue));
|
|
731
|
-
}
|
|
732
|
-
this.updateSelectionBar();
|
|
733
|
-
if (this.range) {
|
|
734
|
-
this.updateCombinedLabel();
|
|
735
|
-
}
|
|
736
|
-
this.updateTicksScale();
|
|
737
|
-
}
|
|
738
|
-
// Adds accessibility attributes, run only once during initialization
|
|
739
|
-
addAccessibility() {
|
|
740
|
-
this.updateAriaAttributes();
|
|
741
|
-
this.minHandleElement.role = 'slider';
|
|
742
|
-
if (this.viewOptions.keyboardSupport && !(this.viewOptions.readOnly || this.viewOptions.disabled)) {
|
|
743
|
-
this.minHandleElement.tabindex = '0';
|
|
744
|
-
}
|
|
745
|
-
else {
|
|
746
|
-
this.minHandleElement.tabindex = '';
|
|
747
|
-
}
|
|
748
|
-
this.minHandleElement.ariaOrientation =
|
|
749
|
-
this.viewOptions.vertical || this.viewOptions.rotate !== 0 ? 'vertical' : 'horizontal';
|
|
750
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabel)) {
|
|
751
|
-
this.minHandleElement.ariaLabel = this.viewOptions.ariaLabel;
|
|
752
|
-
}
|
|
753
|
-
else if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabelledBy)) {
|
|
754
|
-
this.minHandleElement.ariaLabelledBy = this.viewOptions.ariaLabelledBy;
|
|
755
|
-
}
|
|
756
|
-
if (this.range) {
|
|
757
|
-
this.maxHandleElement.role = 'slider';
|
|
758
|
-
if (this.viewOptions.keyboardSupport && !(this.viewOptions.readOnly || this.viewOptions.disabled)) {
|
|
759
|
-
this.maxHandleElement.tabindex = '0';
|
|
760
|
-
}
|
|
761
|
-
else {
|
|
762
|
-
this.maxHandleElement.tabindex = '';
|
|
763
|
-
}
|
|
764
|
-
this.maxHandleElement.ariaOrientation =
|
|
765
|
-
this.viewOptions.vertical || this.viewOptions.rotate !== 0 ? 'vertical' : 'horizontal';
|
|
766
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabelHigh)) {
|
|
767
|
-
this.maxHandleElement.ariaLabel = this.viewOptions.ariaLabelHigh;
|
|
768
|
-
}
|
|
769
|
-
else if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabelledByHigh)) {
|
|
770
|
-
this.maxHandleElement.ariaLabelledBy = this.viewOptions.ariaLabelledByHigh;
|
|
771
|
-
}
|
|
772
|
-
}
|
|
773
|
-
}
|
|
774
|
-
// Updates aria attributes according to current values
|
|
775
|
-
updateAriaAttributes() {
|
|
776
|
-
this.minHandleElement.ariaValueNow = (+this.value).toString();
|
|
777
|
-
this.minHandleElement.ariaValueText = this.viewOptions.translate(+this.value, LabelType.Low);
|
|
778
|
-
this.minHandleElement.ariaValueMin = this.viewOptions.floor.toString();
|
|
779
|
-
this.minHandleElement.ariaValueMax = this.viewOptions.ceil.toString();
|
|
780
|
-
if (this.range) {
|
|
781
|
-
this.maxHandleElement.ariaValueNow = (+this.highValue).toString();
|
|
782
|
-
this.maxHandleElement.ariaValueText = this.viewOptions.translate(+this.highValue, LabelType.High);
|
|
783
|
-
this.maxHandleElement.ariaValueMin = this.viewOptions.floor.toString();
|
|
784
|
-
this.maxHandleElement.ariaValueMax = this.viewOptions.ceil.toString();
|
|
785
|
-
}
|
|
786
|
-
}
|
|
787
|
-
// Calculate dimensions that are dependent on view port size
|
|
788
|
-
// Run once during initialization and every time view port changes size.
|
|
789
|
-
calculateViewDimensions() {
|
|
790
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.handleDimension)) {
|
|
791
|
-
this.minHandleElement.setDimension(this.viewOptions.handleDimension);
|
|
792
|
-
}
|
|
793
|
-
else {
|
|
794
|
-
this.minHandleElement.calculateDimension();
|
|
795
|
-
}
|
|
796
|
-
const handleWidth = this.minHandleElement.dimension;
|
|
797
|
-
this.handleHalfDimension = handleWidth / 2;
|
|
798
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.barDimension)) {
|
|
799
|
-
this.fullBarElement.setDimension(this.viewOptions.barDimension);
|
|
800
|
-
}
|
|
801
|
-
else {
|
|
802
|
-
this.fullBarElement.calculateDimension();
|
|
803
|
-
}
|
|
804
|
-
this.maxHandlePosition = this.fullBarElement.dimension - handleWidth;
|
|
805
|
-
if (this.initHasRun) {
|
|
806
|
-
this.updateFloorLabel();
|
|
807
|
-
this.updateCeilLabel();
|
|
808
|
-
this.initHandles();
|
|
809
|
-
}
|
|
810
|
-
}
|
|
811
|
-
calculateViewDimensionsAndDetectChanges() {
|
|
812
|
-
this.calculateViewDimensions();
|
|
813
|
-
if (!this.isRefDestroyed()) {
|
|
814
|
-
this.changeDetectionRef.detectChanges();
|
|
815
|
-
}
|
|
816
|
-
}
|
|
817
|
-
/**
|
|
818
|
-
* If the slider reference is already destroyed
|
|
819
|
-
* @returns boolean - true if ref is destroyed
|
|
820
|
-
*/
|
|
821
|
-
isRefDestroyed() {
|
|
822
|
-
return this.changeDetectionRef['destroyed'];
|
|
823
|
-
}
|
|
824
|
-
// Update the ticks position
|
|
825
|
-
updateTicksScale() {
|
|
826
|
-
if (!this.viewOptions.showTicks) {
|
|
827
|
-
setTimeout(() => {
|
|
828
|
-
this.sliderElementWithLegendClass = false;
|
|
829
|
-
});
|
|
830
|
-
return;
|
|
831
|
-
}
|
|
832
|
-
const ticksArray = !ValueHelper.isNullOrUndefined(this.viewOptions.ticksArray)
|
|
833
|
-
? this.viewOptions.ticksArray
|
|
834
|
-
: this.getTicksArray();
|
|
835
|
-
const translate = this.viewOptions.vertical ? 'translateY' : 'translateX';
|
|
836
|
-
if (this.viewOptions.rightToLeft) {
|
|
837
|
-
ticksArray.reverse();
|
|
838
|
-
}
|
|
839
|
-
const tickValueStep = !ValueHelper.isNullOrUndefined(this.viewOptions.tickValueStep)
|
|
840
|
-
? this.viewOptions.tickValueStep
|
|
841
|
-
: !ValueHelper.isNullOrUndefined(this.viewOptions.tickStep)
|
|
842
|
-
? this.viewOptions.tickStep
|
|
843
|
-
: this.viewOptions.step;
|
|
844
|
-
let hasAtLeastOneLegend = false;
|
|
845
|
-
const newTicks = ticksArray.map((value) => {
|
|
846
|
-
let position = this.valueToPosition(value);
|
|
847
|
-
if (this.viewOptions.vertical) {
|
|
848
|
-
position = this.maxHandlePosition - position;
|
|
849
|
-
}
|
|
850
|
-
const translation = translate + '(' + Math.round(position) + 'px)';
|
|
851
|
-
const tick = new Tick();
|
|
852
|
-
tick.selected = this.isTickSelected(value);
|
|
853
|
-
tick.style = {
|
|
854
|
-
'-webkit-transform': translation,
|
|
855
|
-
'-moz-transform': translation,
|
|
856
|
-
'-o-transform': translation,
|
|
857
|
-
'-ms-transform': translation,
|
|
858
|
-
transform: translation
|
|
859
|
-
};
|
|
860
|
-
if (tick.selected && !ValueHelper.isNullOrUndefined(this.viewOptions.getSelectionBarColor)) {
|
|
861
|
-
tick.style['background-color'] = this.getSelectionBarColor();
|
|
862
|
-
}
|
|
863
|
-
if (!tick.selected && !ValueHelper.isNullOrUndefined(this.viewOptions.getTickColor)) {
|
|
864
|
-
tick.style['background-color'] = this.getTickColor(value);
|
|
865
|
-
}
|
|
866
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.ticksTooltip)) {
|
|
867
|
-
tick.tooltip = this.viewOptions.ticksTooltip(value);
|
|
868
|
-
tick.tooltipPlacement = this.viewOptions.vertical ? 'right' : 'top';
|
|
869
|
-
}
|
|
870
|
-
if (this.viewOptions.showTicksValues &&
|
|
871
|
-
!ValueHelper.isNullOrUndefined(tickValueStep) &&
|
|
872
|
-
MathHelper.isModuloWithinPrecisionLimit(value, tickValueStep, this.viewOptions.precisionLimit)) {
|
|
873
|
-
tick.value = this.getDisplayValue(value, LabelType.TickValue);
|
|
874
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.ticksValuesTooltip)) {
|
|
875
|
-
tick.valueTooltip = this.viewOptions.ticksValuesTooltip(value);
|
|
876
|
-
tick.valueTooltipPlacement = this.viewOptions.vertical ? 'right' : 'top';
|
|
877
|
-
}
|
|
878
|
-
}
|
|
879
|
-
let legend;
|
|
880
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray)) {
|
|
881
|
-
const step = this.viewOptions.stepsArray[value];
|
|
882
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.getStepLegend)) {
|
|
883
|
-
legend = this.viewOptions.getStepLegend(step);
|
|
884
|
-
}
|
|
885
|
-
else if (!ValueHelper.isNullOrUndefined(step)) {
|
|
886
|
-
legend = step.legend;
|
|
887
|
-
}
|
|
888
|
-
}
|
|
889
|
-
else if (!ValueHelper.isNullOrUndefined(this.viewOptions.getLegend)) {
|
|
890
|
-
legend = this.viewOptions.getLegend(value);
|
|
891
|
-
}
|
|
892
|
-
if (!ValueHelper.isNullOrUndefined(legend)) {
|
|
893
|
-
tick.legend = legend;
|
|
894
|
-
hasAtLeastOneLegend = true;
|
|
895
|
-
}
|
|
896
|
-
return tick;
|
|
897
|
-
});
|
|
898
|
-
setTimeout(() => {
|
|
899
|
-
this.sliderElementWithLegendClass = hasAtLeastOneLegend;
|
|
900
|
-
});
|
|
901
|
-
// We should avoid re-creating the ticks array if possible
|
|
902
|
-
// This both improves performance and makes CSS animations work correctly
|
|
903
|
-
if (!ValueHelper.isNullOrUndefined(this.ticks) && this.ticks.length === newTicks.length) {
|
|
904
|
-
for (let i = 0; i < newTicks.length; ++i) {
|
|
905
|
-
Object.assign(this.ticks[i], newTicks[i]);
|
|
906
|
-
}
|
|
907
|
-
}
|
|
908
|
-
else {
|
|
909
|
-
this.ticks = newTicks;
|
|
910
|
-
}
|
|
911
|
-
if (!this.isRefDestroyed()) {
|
|
912
|
-
this.changeDetectionRef.detectChanges();
|
|
913
|
-
}
|
|
914
|
-
}
|
|
915
|
-
getTicksArray() {
|
|
916
|
-
const step = !ValueHelper.isNullOrUndefined(this.viewOptions.tickStep)
|
|
917
|
-
? this.viewOptions.tickStep
|
|
918
|
-
: this.viewOptions.step;
|
|
919
|
-
const ticksArray = [];
|
|
920
|
-
const numberOfValues = 1 +
|
|
921
|
-
Math.floor(MathHelper.roundToPrecisionLimit(Math.abs(this.viewOptions.ceil - this.viewOptions.floor) / step, this.viewOptions.precisionLimit));
|
|
922
|
-
for (let index = 0; index < numberOfValues; ++index) {
|
|
923
|
-
ticksArray.push(MathHelper.roundToPrecisionLimit(this.viewOptions.floor + step * index, this.viewOptions.precisionLimit));
|
|
924
|
-
}
|
|
925
|
-
return ticksArray;
|
|
926
|
-
}
|
|
927
|
-
isTickSelected(value) {
|
|
928
|
-
if (!this.range) {
|
|
929
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue)) {
|
|
930
|
-
const center = this.viewOptions.showSelectionBarFromValue;
|
|
931
|
-
if (this.viewLowValue > center && value >= center && value <= this.viewLowValue) {
|
|
932
|
-
return true;
|
|
933
|
-
}
|
|
934
|
-
else if (this.viewLowValue < center && value <= center && value >= this.viewLowValue) {
|
|
935
|
-
return true;
|
|
936
|
-
}
|
|
937
|
-
}
|
|
938
|
-
else if (this.viewOptions.showSelectionBarEnd) {
|
|
939
|
-
if (value >= this.viewLowValue) {
|
|
940
|
-
return true;
|
|
941
|
-
}
|
|
942
|
-
}
|
|
943
|
-
else if (this.viewOptions.showSelectionBar && value <= this.viewLowValue) {
|
|
944
|
-
return true;
|
|
945
|
-
}
|
|
946
|
-
}
|
|
947
|
-
if (this.range && value >= this.viewLowValue && value <= this.viewHighValue) {
|
|
948
|
-
return true;
|
|
949
|
-
}
|
|
950
|
-
return false;
|
|
951
|
-
}
|
|
952
|
-
// Update position of the floor label
|
|
953
|
-
updateFloorLabel() {
|
|
954
|
-
if (!this.floorLabelElement.alwaysHide) {
|
|
955
|
-
this.floorLabelElement.setValue(this.getDisplayValue(this.viewOptions.floor, LabelType.Floor));
|
|
956
|
-
this.floorLabelElement.calculateDimension();
|
|
957
|
-
const position = this.viewOptions.rightToLeft
|
|
958
|
-
? this.fullBarElement.dimension - this.floorLabelElement.dimension
|
|
959
|
-
: 0;
|
|
960
|
-
this.floorLabelElement.setPosition(position);
|
|
961
|
-
}
|
|
962
|
-
}
|
|
963
|
-
// Update position of the ceiling label
|
|
964
|
-
updateCeilLabel() {
|
|
965
|
-
if (!this.ceilLabelElement.alwaysHide) {
|
|
966
|
-
this.ceilLabelElement.setValue(this.getDisplayValue(this.viewOptions.ceil, LabelType.Ceil));
|
|
967
|
-
this.ceilLabelElement.calculateDimension();
|
|
968
|
-
const position = this.viewOptions.rightToLeft
|
|
969
|
-
? 0
|
|
970
|
-
: this.fullBarElement.dimension - this.ceilLabelElement.dimension;
|
|
971
|
-
this.ceilLabelElement.setPosition(position);
|
|
972
|
-
}
|
|
973
|
-
}
|
|
974
|
-
// Update slider handles and label positions
|
|
975
|
-
updateHandles(which, newPos) {
|
|
976
|
-
if (which === PointerType.Min) {
|
|
977
|
-
this.updateLowHandle(newPos);
|
|
978
|
-
}
|
|
979
|
-
else if (which === PointerType.Max) {
|
|
980
|
-
this.updateHighHandle(newPos);
|
|
981
|
-
}
|
|
982
|
-
this.updateSelectionBar();
|
|
983
|
-
this.updateTicksScale();
|
|
984
|
-
if (this.range) {
|
|
985
|
-
this.updateCombinedLabel();
|
|
986
|
-
}
|
|
987
|
-
}
|
|
988
|
-
// Helper function to work out the position for handle labels depending on RTL or not
|
|
989
|
-
getHandleLabelPos(labelType, newPos) {
|
|
990
|
-
const labelDimension = labelType === PointerType.Min ? this.minHandleLabelElement.dimension : this.maxHandleLabelElement.dimension;
|
|
991
|
-
const nearHandlePos = newPos - labelDimension / 2 + this.handleHalfDimension;
|
|
992
|
-
const endOfBarPos = this.fullBarElement.dimension - labelDimension;
|
|
993
|
-
if (!this.viewOptions.boundPointerLabels) {
|
|
994
|
-
return nearHandlePos;
|
|
995
|
-
}
|
|
996
|
-
if ((this.viewOptions.rightToLeft && labelType === PointerType.Min) ||
|
|
997
|
-
(!this.viewOptions.rightToLeft && labelType === PointerType.Max)) {
|
|
998
|
-
return Math.min(nearHandlePos, endOfBarPos);
|
|
999
|
-
}
|
|
1000
|
-
else {
|
|
1001
|
-
return Math.min(Math.max(nearHandlePos, 0), endOfBarPos);
|
|
1002
|
-
}
|
|
1003
|
-
}
|
|
1004
|
-
// Update low slider handle position and label
|
|
1005
|
-
updateLowHandle(newPos) {
|
|
1006
|
-
this.minHandleElement.setPosition(newPos);
|
|
1007
|
-
this.minHandleLabelElement.setValue(this.getDisplayValue(this.viewLowValue, LabelType.Low));
|
|
1008
|
-
this.minHandleLabelElement.setPosition(this.getHandleLabelPos(PointerType.Min, newPos));
|
|
1009
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.getPointerColor)) {
|
|
1010
|
-
this.minPointerStyle = {
|
|
1011
|
-
backgroundColor: this.getPointerColor(PointerType.Min)
|
|
1012
|
-
};
|
|
1013
|
-
}
|
|
1014
|
-
if (this.viewOptions.autoHideLimitLabels) {
|
|
1015
|
-
this.updateFloorAndCeilLabelsVisibility();
|
|
1016
|
-
}
|
|
1017
|
-
}
|
|
1018
|
-
// Update high slider handle position and label
|
|
1019
|
-
updateHighHandle(newPos) {
|
|
1020
|
-
this.maxHandleElement.setPosition(newPos);
|
|
1021
|
-
this.maxHandleLabelElement.setValue(this.getDisplayValue(this.viewHighValue, LabelType.High));
|
|
1022
|
-
this.maxHandleLabelElement.setPosition(this.getHandleLabelPos(PointerType.Max, newPos));
|
|
1023
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.getPointerColor)) {
|
|
1024
|
-
this.maxPointerStyle = {
|
|
1025
|
-
backgroundColor: this.getPointerColor(PointerType.Max)
|
|
1026
|
-
};
|
|
1027
|
-
}
|
|
1028
|
-
if (this.viewOptions.autoHideLimitLabels) {
|
|
1029
|
-
this.updateFloorAndCeilLabelsVisibility();
|
|
1030
|
-
}
|
|
1031
|
-
}
|
|
1032
|
-
// Show/hide floor/ceiling label
|
|
1033
|
-
updateFloorAndCeilLabelsVisibility() {
|
|
1034
|
-
// Show based only on hideLimitLabels if pointer labels are hidden
|
|
1035
|
-
if (this.viewOptions.hidePointerLabels) {
|
|
1036
|
-
return;
|
|
1037
|
-
}
|
|
1038
|
-
let floorLabelHidden = false;
|
|
1039
|
-
let ceilLabelHidden = false;
|
|
1040
|
-
const isMinLabelAtFloor = this.isLabelBelowFloorLabel(this.minHandleLabelElement);
|
|
1041
|
-
const isMinLabelAtCeil = this.isLabelAboveCeilLabel(this.minHandleLabelElement);
|
|
1042
|
-
const isMaxLabelAtCeil = this.isLabelAboveCeilLabel(this.maxHandleLabelElement);
|
|
1043
|
-
const isCombinedLabelAtFloor = this.isLabelBelowFloorLabel(this.combinedLabelElement);
|
|
1044
|
-
const isCombinedLabelAtCeil = this.isLabelAboveCeilLabel(this.combinedLabelElement);
|
|
1045
|
-
if (isMinLabelAtFloor) {
|
|
1046
|
-
floorLabelHidden = true;
|
|
1047
|
-
this.floorLabelElement.hide();
|
|
1048
|
-
}
|
|
1049
|
-
else {
|
|
1050
|
-
floorLabelHidden = false;
|
|
1051
|
-
this.floorLabelElement.show();
|
|
1052
|
-
}
|
|
1053
|
-
if (isMinLabelAtCeil) {
|
|
1054
|
-
ceilLabelHidden = true;
|
|
1055
|
-
this.ceilLabelElement.hide();
|
|
1056
|
-
}
|
|
1057
|
-
else {
|
|
1058
|
-
ceilLabelHidden = false;
|
|
1059
|
-
this.ceilLabelElement.show();
|
|
1060
|
-
}
|
|
1061
|
-
if (this.range) {
|
|
1062
|
-
const hideCeil = this.combinedLabelElement.isVisible() ? isCombinedLabelAtCeil : isMaxLabelAtCeil;
|
|
1063
|
-
const hideFloor = this.combinedLabelElement.isVisible() ? isCombinedLabelAtFloor : isMinLabelAtFloor;
|
|
1064
|
-
if (hideCeil) {
|
|
1065
|
-
this.ceilLabelElement.hide();
|
|
1066
|
-
}
|
|
1067
|
-
else if (!ceilLabelHidden) {
|
|
1068
|
-
this.ceilLabelElement.show();
|
|
1069
|
-
}
|
|
1070
|
-
// Hide or show floor label
|
|
1071
|
-
if (hideFloor) {
|
|
1072
|
-
this.floorLabelElement.hide();
|
|
1073
|
-
}
|
|
1074
|
-
else if (!floorLabelHidden) {
|
|
1075
|
-
this.floorLabelElement.show();
|
|
1076
|
-
}
|
|
1077
|
-
}
|
|
1078
|
-
}
|
|
1079
|
-
isLabelBelowFloorLabel(label) {
|
|
1080
|
-
const pos = label.position;
|
|
1081
|
-
const dim = label.dimension;
|
|
1082
|
-
const floorPos = this.floorLabelElement.position;
|
|
1083
|
-
const floorDim = this.floorLabelElement.dimension;
|
|
1084
|
-
return this.viewOptions.rightToLeft ? pos + dim >= floorPos - 2 : pos <= floorPos + floorDim + 2;
|
|
1085
|
-
}
|
|
1086
|
-
isLabelAboveCeilLabel(label) {
|
|
1087
|
-
const pos = label.position;
|
|
1088
|
-
const dim = label.dimension;
|
|
1089
|
-
const ceilPos = this.ceilLabelElement.position;
|
|
1090
|
-
const ceilDim = this.ceilLabelElement.dimension;
|
|
1091
|
-
return this.viewOptions.rightToLeft ? pos <= ceilPos + ceilDim + 2 : pos + dim >= ceilPos - 2;
|
|
1092
|
-
}
|
|
1093
|
-
// Update slider selection bar, combined label and range label
|
|
1094
|
-
updateSelectionBar() {
|
|
1095
|
-
let position = 0;
|
|
1096
|
-
let dimension = 0;
|
|
1097
|
-
const isSelectionBarFromRight = this.viewOptions.rightToLeft
|
|
1098
|
-
? !this.viewOptions.showSelectionBarEnd
|
|
1099
|
-
: this.viewOptions.showSelectionBarEnd;
|
|
1100
|
-
const positionForRange = this.viewOptions.rightToLeft
|
|
1101
|
-
? this.maxHandleElement.position + this.handleHalfDimension
|
|
1102
|
-
: this.minHandleElement.position + this.handleHalfDimension;
|
|
1103
|
-
if (this.range) {
|
|
1104
|
-
dimension = Math.abs(this.maxHandleElement.position - this.minHandleElement.position);
|
|
1105
|
-
position = positionForRange;
|
|
1106
|
-
}
|
|
1107
|
-
else {
|
|
1108
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue)) {
|
|
1109
|
-
const center = this.viewOptions.showSelectionBarFromValue;
|
|
1110
|
-
const centerPosition = this.valueToPosition(center);
|
|
1111
|
-
const isModelGreaterThanCenter = this.viewOptions.rightToLeft
|
|
1112
|
-
? this.viewLowValue <= center
|
|
1113
|
-
: this.viewLowValue > center;
|
|
1114
|
-
if (isModelGreaterThanCenter) {
|
|
1115
|
-
dimension = this.minHandleElement.position - centerPosition;
|
|
1116
|
-
position = centerPosition + this.handleHalfDimension;
|
|
1117
|
-
}
|
|
1118
|
-
else {
|
|
1119
|
-
dimension = centerPosition - this.minHandleElement.position;
|
|
1120
|
-
position = this.minHandleElement.position + this.handleHalfDimension;
|
|
1121
|
-
}
|
|
1122
|
-
}
|
|
1123
|
-
else if (isSelectionBarFromRight) {
|
|
1124
|
-
dimension = Math.ceil(Math.abs(this.maxHandlePosition - this.minHandleElement.position) + this.handleHalfDimension);
|
|
1125
|
-
position = Math.floor(this.minHandleElement.position + this.handleHalfDimension);
|
|
1126
|
-
}
|
|
1127
|
-
else {
|
|
1128
|
-
dimension = this.minHandleElement.position + this.handleHalfDimension;
|
|
1129
|
-
position = 0;
|
|
1130
|
-
}
|
|
1131
|
-
}
|
|
1132
|
-
this.selectionBarElement.setDimension(dimension);
|
|
1133
|
-
this.selectionBarElement.setPosition(position);
|
|
1134
|
-
if (this.range && this.viewOptions.showOuterSelectionBars) {
|
|
1135
|
-
if (this.viewOptions.rightToLeft) {
|
|
1136
|
-
this.rightOuterSelectionBarElement.setDimension(position);
|
|
1137
|
-
this.rightOuterSelectionBarElement.setPosition(0);
|
|
1138
|
-
this.fullBarElement.calculateDimension();
|
|
1139
|
-
this.leftOuterSelectionBarElement.setDimension(this.fullBarElement.dimension - (position + dimension));
|
|
1140
|
-
this.leftOuterSelectionBarElement.setPosition(position + dimension);
|
|
1141
|
-
}
|
|
1142
|
-
else {
|
|
1143
|
-
this.leftOuterSelectionBarElement.setDimension(position);
|
|
1144
|
-
this.leftOuterSelectionBarElement.setPosition(0);
|
|
1145
|
-
this.fullBarElement.calculateDimension();
|
|
1146
|
-
this.rightOuterSelectionBarElement.setDimension(this.fullBarElement.dimension - (position + dimension));
|
|
1147
|
-
this.rightOuterSelectionBarElement.setPosition(position + dimension);
|
|
1148
|
-
}
|
|
1149
|
-
}
|
|
1150
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.getSelectionBarColor)) {
|
|
1151
|
-
const color = this.getSelectionBarColor();
|
|
1152
|
-
this.barStyle = {
|
|
1153
|
-
backgroundColor: color
|
|
1154
|
-
};
|
|
1155
|
-
}
|
|
1156
|
-
else if (!ValueHelper.isNullOrUndefined(this.viewOptions.selectionBarGradient)) {
|
|
1157
|
-
const offset = !ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue)
|
|
1158
|
-
? this.valueToPosition(this.viewOptions.showSelectionBarFromValue)
|
|
1159
|
-
: 0;
|
|
1160
|
-
const reversed = (offset - position > 0 && !isSelectionBarFromRight) || (offset - position <= 0 && isSelectionBarFromRight);
|
|
1161
|
-
const direction = this.viewOptions.vertical ? (reversed ? 'bottom' : 'top') : reversed ? 'left' : 'right';
|
|
1162
|
-
this.barStyle = {
|
|
1163
|
-
backgroundImage: 'linear-gradient(to ' +
|
|
1164
|
-
direction +
|
|
1165
|
-
', ' +
|
|
1166
|
-
this.viewOptions.selectionBarGradient.from +
|
|
1167
|
-
' 0%,' +
|
|
1168
|
-
this.viewOptions.selectionBarGradient.to +
|
|
1169
|
-
' 100%)'
|
|
1170
|
-
};
|
|
1171
|
-
if (this.viewOptions.vertical) {
|
|
1172
|
-
this.barStyle.backgroundPosition =
|
|
1173
|
-
'center ' + (offset + dimension + position + (reversed ? -this.handleHalfDimension : 0)) + 'px';
|
|
1174
|
-
this.barStyle.backgroundSize = '100% ' + (this.fullBarElement.dimension - this.handleHalfDimension) + 'px';
|
|
1175
|
-
}
|
|
1176
|
-
else {
|
|
1177
|
-
this.barStyle.backgroundPosition = offset - position + (reversed ? this.handleHalfDimension : 0) + 'px center';
|
|
1178
|
-
this.barStyle.backgroundSize = this.fullBarElement.dimension - this.handleHalfDimension + 'px 100%';
|
|
1179
|
-
}
|
|
1180
|
-
}
|
|
1181
|
-
}
|
|
1182
|
-
// Wrapper around the getSelectionBarColor of the user to pass to correct parameters
|
|
1183
|
-
getSelectionBarColor() {
|
|
1184
|
-
if (this.range) {
|
|
1185
|
-
return this.viewOptions.getSelectionBarColor(this.value, this.highValue);
|
|
1186
|
-
}
|
|
1187
|
-
return this.viewOptions.getSelectionBarColor(this.value);
|
|
1188
|
-
}
|
|
1189
|
-
// Wrapper around the getPointerColor of the user to pass to correct parameters
|
|
1190
|
-
getPointerColor(pointerType) {
|
|
1191
|
-
if (pointerType === PointerType.Max) {
|
|
1192
|
-
return this.viewOptions.getPointerColor(this.highValue, pointerType);
|
|
1193
|
-
}
|
|
1194
|
-
return this.viewOptions.getPointerColor(this.value, pointerType);
|
|
1195
|
-
}
|
|
1196
|
-
// Wrapper around the getTickColor of the user to pass to correct parameters
|
|
1197
|
-
getTickColor(value) {
|
|
1198
|
-
return this.viewOptions.getTickColor(value);
|
|
1199
|
-
}
|
|
1200
|
-
// Update combined label position and value
|
|
1201
|
-
updateCombinedLabel() {
|
|
1202
|
-
let isLabelOverlap = false;
|
|
1203
|
-
if (this.viewOptions.rightToLeft) {
|
|
1204
|
-
isLabelOverlap =
|
|
1205
|
-
this.minHandleLabelElement.position - this.minHandleLabelElement.dimension - 10 <=
|
|
1206
|
-
this.maxHandleLabelElement.position;
|
|
1207
|
-
}
|
|
1208
|
-
else {
|
|
1209
|
-
isLabelOverlap =
|
|
1210
|
-
this.minHandleLabelElement.position + this.minHandleLabelElement.dimension + 10 >=
|
|
1211
|
-
this.maxHandleLabelElement.position;
|
|
1212
|
-
}
|
|
1213
|
-
if (isLabelOverlap) {
|
|
1214
|
-
const lowDisplayValue = this.getDisplayValue(this.viewLowValue, LabelType.Low);
|
|
1215
|
-
const highDisplayValue = this.getDisplayValue(this.viewHighValue, LabelType.High);
|
|
1216
|
-
const combinedLabelValue = this.viewOptions.rightToLeft
|
|
1217
|
-
? this.viewOptions.combineLabels(highDisplayValue, lowDisplayValue)
|
|
1218
|
-
: this.viewOptions.combineLabels(lowDisplayValue, highDisplayValue);
|
|
1219
|
-
this.combinedLabelElement.setValue(combinedLabelValue);
|
|
1220
|
-
const pos = this.viewOptions.boundPointerLabels
|
|
1221
|
-
? Math.min(Math.max(this.selectionBarElement.position +
|
|
1222
|
-
this.selectionBarElement.dimension / 2 -
|
|
1223
|
-
this.combinedLabelElement.dimension / 2, 0), this.fullBarElement.dimension - this.combinedLabelElement.dimension)
|
|
1224
|
-
: this.selectionBarElement.position +
|
|
1225
|
-
this.selectionBarElement.dimension / 2 -
|
|
1226
|
-
this.combinedLabelElement.dimension / 2;
|
|
1227
|
-
this.combinedLabelElement.setPosition(pos);
|
|
1228
|
-
this.minHandleLabelElement.hide();
|
|
1229
|
-
this.maxHandleLabelElement.hide();
|
|
1230
|
-
this.combinedLabelElement.show();
|
|
1231
|
-
}
|
|
1232
|
-
else {
|
|
1233
|
-
this.updateHighHandle(this.valueToPosition(this.viewHighValue));
|
|
1234
|
-
this.updateLowHandle(this.valueToPosition(this.viewLowValue));
|
|
1235
|
-
this.maxHandleLabelElement.show();
|
|
1236
|
-
this.minHandleLabelElement.show();
|
|
1237
|
-
this.combinedLabelElement.hide();
|
|
1238
|
-
}
|
|
1239
|
-
if (this.viewOptions.autoHideLimitLabels) {
|
|
1240
|
-
this.updateFloorAndCeilLabelsVisibility();
|
|
1241
|
-
}
|
|
1242
|
-
}
|
|
1243
|
-
// Return the translated value if a translate function is provided else the original value
|
|
1244
|
-
getDisplayValue(value, which) {
|
|
1245
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray) && !this.viewOptions.bindIndexForStepsArray) {
|
|
1246
|
-
value = this.getStepValue(value);
|
|
1247
|
-
}
|
|
1248
|
-
return this.viewOptions.translate(value, which);
|
|
1249
|
-
}
|
|
1250
|
-
// Round value to step and precision based on minValue
|
|
1251
|
-
roundStep(value, customStep) {
|
|
1252
|
-
const step = !ValueHelper.isNullOrUndefined(customStep) ? customStep : this.viewOptions.step;
|
|
1253
|
-
let steppedDifference = MathHelper.roundToPrecisionLimit((value - this.viewOptions.floor) / step, this.viewOptions.precisionLimit);
|
|
1254
|
-
steppedDifference = Math.round(steppedDifference) * step;
|
|
1255
|
-
return MathHelper.roundToPrecisionLimit(this.viewOptions.floor + steppedDifference, this.viewOptions.precisionLimit);
|
|
1256
|
-
}
|
|
1257
|
-
// Translate value to pixel position
|
|
1258
|
-
valueToPosition(val) {
|
|
1259
|
-
let fn = ValueHelper.linearValueToPosition;
|
|
1260
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.customValueToPosition)) {
|
|
1261
|
-
fn = this.viewOptions.customValueToPosition;
|
|
1262
|
-
}
|
|
1263
|
-
else if (this.viewOptions.logScale) {
|
|
1264
|
-
fn = ValueHelper.logValueToPosition;
|
|
1265
|
-
}
|
|
1266
|
-
val = MathHelper.clampToRange(val, this.viewOptions.floor, this.viewOptions.ceil);
|
|
1267
|
-
let percent = fn(val, this.viewOptions.floor, this.viewOptions.ceil);
|
|
1268
|
-
if (ValueHelper.isNullOrUndefined(percent)) {
|
|
1269
|
-
percent = 0;
|
|
1270
|
-
}
|
|
1271
|
-
if (this.viewOptions.rightToLeft) {
|
|
1272
|
-
percent = 1 - percent;
|
|
1273
|
-
}
|
|
1274
|
-
return percent * this.maxHandlePosition;
|
|
1275
|
-
}
|
|
1276
|
-
// Translate position to model value
|
|
1277
|
-
positionToValue(position) {
|
|
1278
|
-
let percent = position / this.maxHandlePosition;
|
|
1279
|
-
if (this.viewOptions.rightToLeft) {
|
|
1280
|
-
percent = 1 - percent;
|
|
1281
|
-
}
|
|
1282
|
-
let fn = ValueHelper.linearPositionToValue;
|
|
1283
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.customPositionToValue)) {
|
|
1284
|
-
fn = this.viewOptions.customPositionToValue;
|
|
1285
|
-
}
|
|
1286
|
-
else if (this.viewOptions.logScale) {
|
|
1287
|
-
fn = ValueHelper.logPositionToValue;
|
|
1288
|
-
}
|
|
1289
|
-
const value = fn(percent, this.viewOptions.floor, this.viewOptions.ceil);
|
|
1290
|
-
return !ValueHelper.isNullOrUndefined(value) ? value : 0;
|
|
1291
|
-
}
|
|
1292
|
-
// Get the X-coordinate or Y-coordinate of an event
|
|
1293
|
-
getEventXY(event, targetTouchId) {
|
|
1294
|
-
if (event instanceof MouseEvent) {
|
|
1295
|
-
return this.viewOptions.vertical || this.viewOptions.rotate !== 0 ? event.clientY : event.clientX;
|
|
1296
|
-
}
|
|
1297
|
-
let touchIndex = 0;
|
|
1298
|
-
const touches = event.touches;
|
|
1299
|
-
if (!ValueHelper.isNullOrUndefined(targetTouchId)) {
|
|
1300
|
-
for (let i = 0; i < touches.length; i++) {
|
|
1301
|
-
if (touches[i].identifier === targetTouchId) {
|
|
1302
|
-
touchIndex = i;
|
|
1303
|
-
break;
|
|
1304
|
-
}
|
|
1305
|
-
}
|
|
1306
|
-
}
|
|
1307
|
-
// Return the target touch or if the target touch was not found in the event
|
|
1308
|
-
// returns the coordinates of the first touch
|
|
1309
|
-
return this.viewOptions.vertical || this.viewOptions.rotate !== 0
|
|
1310
|
-
? touches[touchIndex].clientY
|
|
1311
|
-
: touches[touchIndex].clientX;
|
|
1312
|
-
}
|
|
1313
|
-
// Compute the event position depending on whether the slider is horizontal or vertical
|
|
1314
|
-
getEventPosition(event, targetTouchId) {
|
|
1315
|
-
const sliderElementBoundingRect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
1316
|
-
const sliderPos = this.viewOptions.vertical || this.viewOptions.rotate !== 0
|
|
1317
|
-
? sliderElementBoundingRect.bottom
|
|
1318
|
-
: sliderElementBoundingRect.left;
|
|
1319
|
-
let eventPos = 0;
|
|
1320
|
-
if (this.viewOptions.vertical || this.viewOptions.rotate !== 0) {
|
|
1321
|
-
eventPos = -this.getEventXY(event, targetTouchId) + sliderPos;
|
|
1322
|
-
}
|
|
1323
|
-
else {
|
|
1324
|
-
eventPos = this.getEventXY(event, targetTouchId) - sliderPos;
|
|
1325
|
-
}
|
|
1326
|
-
return eventPos * this.viewOptions.scale - this.handleHalfDimension;
|
|
1327
|
-
}
|
|
1328
|
-
// Get the handle closest to an event
|
|
1329
|
-
getNearestHandle(event) {
|
|
1330
|
-
if (!this.range) {
|
|
1331
|
-
return PointerType.Min;
|
|
1332
|
-
}
|
|
1333
|
-
const position = this.getEventPosition(event);
|
|
1334
|
-
const distanceMin = Math.abs(position - this.minHandleElement.position);
|
|
1335
|
-
const distanceMax = Math.abs(position - this.maxHandleElement.position);
|
|
1336
|
-
if (distanceMin < distanceMax) {
|
|
1337
|
-
return PointerType.Min;
|
|
1338
|
-
}
|
|
1339
|
-
else if (distanceMin > distanceMax) {
|
|
1340
|
-
return PointerType.Max;
|
|
1341
|
-
}
|
|
1342
|
-
else if (!this.viewOptions.rightToLeft) {
|
|
1343
|
-
// if event is at the same distance from min/max then if it's at left of minH, we return minH else maxH
|
|
1344
|
-
return position < this.minHandleElement.position ? PointerType.Min : PointerType.Max;
|
|
1345
|
-
}
|
|
1346
|
-
// reverse in rtl
|
|
1347
|
-
return position > this.minHandleElement.position ? PointerType.Min : PointerType.Max;
|
|
1348
|
-
}
|
|
1349
|
-
// Bind mouse and touch events to slider handles
|
|
1350
|
-
bindEvents() {
|
|
1351
|
-
const draggableRange = this.viewOptions.draggableRange;
|
|
1352
|
-
if (!this.viewOptions.onlyBindHandles) {
|
|
1353
|
-
this.selectionBarElement.on('mousedown', (event) => this.onBarStart(draggableRange, event, true, true, undefined, true));
|
|
1354
|
-
}
|
|
1355
|
-
if (this.viewOptions.draggableRangeOnly) {
|
|
1356
|
-
this.minHandleElement.on('mousedown', (event) => this.onBarStart(draggableRange, event, true, true, PointerType.Min));
|
|
1357
|
-
this.maxHandleElement.on('mousedown', (event) => this.onBarStart(draggableRange, event, true, true, PointerType.Max));
|
|
1358
|
-
}
|
|
1359
|
-
else {
|
|
1360
|
-
this.minHandleElement.on('mousedown', (event) => this.onStart(event, true, true, PointerType.Min));
|
|
1361
|
-
if (this.range) {
|
|
1362
|
-
this.maxHandleElement.on('mousedown', (event) => this.onStart(event, true, true, PointerType.Max));
|
|
1363
|
-
}
|
|
1364
|
-
if (!this.viewOptions.onlyBindHandles) {
|
|
1365
|
-
this.fullBarElement.on('mousedown', (event) => this.onStart(event, true, true, undefined, true));
|
|
1366
|
-
this.ticksElement.on('mousedown', (event) => this.onStart(event, true, true, undefined, true, true));
|
|
1367
|
-
}
|
|
1368
|
-
}
|
|
1369
|
-
if (!this.viewOptions.onlyBindHandles) {
|
|
1370
|
-
this.selectionBarElement.onPassive('touchstart', (event) => this.onBarStart(draggableRange, event, true, true, undefined, true));
|
|
1371
|
-
}
|
|
1372
|
-
if (this.viewOptions.draggableRangeOnly) {
|
|
1373
|
-
this.minHandleElement.onPassive('touchstart', (event) => this.onBarStart(draggableRange, event, true, true, PointerType.Min));
|
|
1374
|
-
this.maxHandleElement.onPassive('touchstart', (event) => this.onBarStart(draggableRange, event, true, true, PointerType.Max));
|
|
1375
|
-
}
|
|
1376
|
-
else {
|
|
1377
|
-
this.minHandleElement.onPassive('touchstart', (event) => this.onStart(event, true, true, PointerType.Min));
|
|
1378
|
-
if (this.range) {
|
|
1379
|
-
this.maxHandleElement.onPassive('touchstart', (event) => this.onStart(event, true, true, PointerType.Max));
|
|
1380
|
-
}
|
|
1381
|
-
if (!this.viewOptions.onlyBindHandles) {
|
|
1382
|
-
this.fullBarElement.onPassive('touchstart', (event) => this.onStart(event, true, true, undefined, true));
|
|
1383
|
-
this.ticksElement.onPassive('touchstart', (event) => this.onStart(event, false, false, undefined, true, true));
|
|
1384
|
-
}
|
|
1385
|
-
}
|
|
1386
|
-
if (this.viewOptions.keyboardSupport) {
|
|
1387
|
-
this.minHandleElement.on('focus', () => this.onPointerFocus(PointerType.Min));
|
|
1388
|
-
if (this.range) {
|
|
1389
|
-
this.maxHandleElement.on('focus', () => this.onPointerFocus(PointerType.Max));
|
|
1390
|
-
}
|
|
1391
|
-
}
|
|
1392
|
-
}
|
|
1393
|
-
getOptionsInfluencingEventBindings(options) {
|
|
1394
|
-
return [
|
|
1395
|
-
options.disabled,
|
|
1396
|
-
options.readOnly,
|
|
1397
|
-
options.draggableRange,
|
|
1398
|
-
options.draggableRangeOnly,
|
|
1399
|
-
options.onlyBindHandles,
|
|
1400
|
-
options.keyboardSupport
|
|
1401
|
-
];
|
|
1402
|
-
}
|
|
1403
|
-
// Unbind mouse and touch events to slider handles
|
|
1404
|
-
unbindEvents() {
|
|
1405
|
-
this.unsubscribeOnMove();
|
|
1406
|
-
this.unsubscribeOnEnd();
|
|
1407
|
-
for (const element of this.getAllSliderElements()) {
|
|
1408
|
-
if (!ValueHelper.isNullOrUndefined(element)) {
|
|
1409
|
-
element.off();
|
|
1410
|
-
}
|
|
1411
|
-
}
|
|
1412
|
-
}
|
|
1413
|
-
onBarStart(draggableRange, event, bindMove, bindEnd, pointerType, simulateImmediateMove, simulateImmediateEnd) {
|
|
1414
|
-
if (draggableRange) {
|
|
1415
|
-
this.onDragStart(event, bindMove, bindEnd, pointerType);
|
|
1416
|
-
}
|
|
1417
|
-
else {
|
|
1418
|
-
this.onStart(event, bindMove, bindEnd, pointerType, simulateImmediateMove, simulateImmediateEnd);
|
|
1419
|
-
}
|
|
1420
|
-
}
|
|
1421
|
-
// onStart event handler
|
|
1422
|
-
onStart(event, bindMove, bindEnd, pointerType, simulateImmediateMove, simulateImmediateEnd) {
|
|
1423
|
-
event.stopPropagation();
|
|
1424
|
-
// Only call preventDefault() when handling non-passive events (passive events don't need it)
|
|
1425
|
-
if (!CompatibilityHelper.isTouchEvent(event) && !supportsPassiveEvents) {
|
|
1426
|
-
event.preventDefault();
|
|
1427
|
-
}
|
|
1428
|
-
this.moving = false;
|
|
1429
|
-
// We have to do this in case the HTML where the sliders are on
|
|
1430
|
-
// have been animated into view.
|
|
1431
|
-
this.calculateViewDimensions();
|
|
1432
|
-
if (ValueHelper.isNullOrUndefined(pointerType)) {
|
|
1433
|
-
pointerType = this.getNearestHandle(event);
|
|
1434
|
-
}
|
|
1435
|
-
this.currentTrackingPointer = pointerType;
|
|
1436
|
-
const pointerElement = this.getPointerElement(pointerType);
|
|
1437
|
-
pointerElement.active = true;
|
|
1438
|
-
if (this.viewOptions.keyboardSupport) {
|
|
1439
|
-
pointerElement.focus();
|
|
1440
|
-
}
|
|
1441
|
-
if (bindMove) {
|
|
1442
|
-
this.unsubscribeOnMove();
|
|
1443
|
-
const onMoveCallback = (e) => this.dragging.active ? this.onDragMove(e) : this.onMove(e);
|
|
1444
|
-
if (CompatibilityHelper.isTouchEvent(event)) {
|
|
1445
|
-
this.onMoveEventListener = this.eventListenerHelper.attachPassiveEventListener(document, 'touchmove', onMoveCallback);
|
|
1446
|
-
}
|
|
1447
|
-
else {
|
|
1448
|
-
this.onMoveEventListener = this.eventListenerHelper.attachEventListener(document, 'mousemove', onMoveCallback);
|
|
1449
|
-
}
|
|
1450
|
-
}
|
|
1451
|
-
if (bindEnd) {
|
|
1452
|
-
this.unsubscribeOnEnd();
|
|
1453
|
-
const onEndCallback = (e) => this.onEnd(e);
|
|
1454
|
-
if (CompatibilityHelper.isTouchEvent(event)) {
|
|
1455
|
-
this.onEndEventListener = this.eventListenerHelper.attachPassiveEventListener(document, 'touchend', onEndCallback);
|
|
1456
|
-
}
|
|
1457
|
-
else {
|
|
1458
|
-
this.onEndEventListener = this.eventListenerHelper.attachEventListener(document, 'mouseup', onEndCallback);
|
|
1459
|
-
}
|
|
1460
|
-
}
|
|
1461
|
-
this.userChangeStart.emit(this.getChangeContext());
|
|
1462
|
-
if (CompatibilityHelper.isTouchEvent(event) &&
|
|
1463
|
-
!ValueHelper.isNullOrUndefined(event.changedTouches)) {
|
|
1464
|
-
// Store the touch identifier
|
|
1465
|
-
if (ValueHelper.isNullOrUndefined(this.touchId)) {
|
|
1466
|
-
this.touchId = event.changedTouches[0].identifier;
|
|
1467
|
-
}
|
|
1468
|
-
}
|
|
1469
|
-
// Click events, either with mouse or touch gesture are weird. Sometimes they result in full
|
|
1470
|
-
// start, move, end sequence, and sometimes, they don't - they only invoke mousedown
|
|
1471
|
-
// As a workaround, we simulate the first move event and the end event if it's necessary
|
|
1472
|
-
if (simulateImmediateMove) {
|
|
1473
|
-
this.onMove(event, true);
|
|
1474
|
-
}
|
|
1475
|
-
if (simulateImmediateEnd) {
|
|
1476
|
-
this.onEnd(event);
|
|
1477
|
-
}
|
|
1478
|
-
}
|
|
1479
|
-
// onMove event handler
|
|
1480
|
-
onMove(event, fromTick) {
|
|
1481
|
-
let touchForThisSlider;
|
|
1482
|
-
if (CompatibilityHelper.isTouchEvent(event)) {
|
|
1483
|
-
const changedTouches = event.changedTouches;
|
|
1484
|
-
for (let i = 0; i < changedTouches.length; i++) {
|
|
1485
|
-
if (changedTouches[i].identifier === this.touchId) {
|
|
1486
|
-
touchForThisSlider = changedTouches[i];
|
|
1487
|
-
break;
|
|
1488
|
-
}
|
|
1489
|
-
}
|
|
1490
|
-
if (ValueHelper.isNullOrUndefined(touchForThisSlider)) {
|
|
1491
|
-
return;
|
|
1492
|
-
}
|
|
1493
|
-
}
|
|
1494
|
-
if (this.viewOptions.animate && !this.viewOptions.animateOnMove) {
|
|
1495
|
-
if (this.moving) {
|
|
1496
|
-
this.sliderElementAnimateClass = false;
|
|
1497
|
-
}
|
|
1498
|
-
}
|
|
1499
|
-
this.moving = true;
|
|
1500
|
-
const newPos = !ValueHelper.isNullOrUndefined(touchForThisSlider)
|
|
1501
|
-
? this.getEventPosition(event, touchForThisSlider.identifier)
|
|
1502
|
-
: this.getEventPosition(event);
|
|
1503
|
-
let newValue;
|
|
1504
|
-
const ceilValue = this.viewOptions.rightToLeft ? this.viewOptions.floor : this.viewOptions.ceil;
|
|
1505
|
-
const floorValue = this.viewOptions.rightToLeft ? this.viewOptions.ceil : this.viewOptions.floor;
|
|
1506
|
-
if (newPos <= 0) {
|
|
1507
|
-
newValue = floorValue;
|
|
1508
|
-
}
|
|
1509
|
-
else if (newPos >= this.maxHandlePosition) {
|
|
1510
|
-
newValue = ceilValue;
|
|
1511
|
-
}
|
|
1512
|
-
else {
|
|
1513
|
-
newValue = this.positionToValue(newPos);
|
|
1514
|
-
if (fromTick && !ValueHelper.isNullOrUndefined(this.viewOptions.tickStep)) {
|
|
1515
|
-
newValue = this.roundStep(newValue, this.viewOptions.tickStep);
|
|
1516
|
-
}
|
|
1517
|
-
else {
|
|
1518
|
-
newValue = this.roundStep(newValue);
|
|
1519
|
-
}
|
|
1520
|
-
}
|
|
1521
|
-
this.positionTrackingHandle(newValue);
|
|
1522
|
-
}
|
|
1523
|
-
onEnd(event) {
|
|
1524
|
-
if (CompatibilityHelper.isTouchEvent(event)) {
|
|
1525
|
-
const changedTouches = event.changedTouches;
|
|
1526
|
-
if (changedTouches[0].identifier !== this.touchId) {
|
|
1527
|
-
return;
|
|
1528
|
-
}
|
|
1529
|
-
}
|
|
1530
|
-
this.moving = false;
|
|
1531
|
-
if (this.viewOptions.animate) {
|
|
1532
|
-
this.sliderElementAnimateClass = true;
|
|
1533
|
-
}
|
|
1534
|
-
this.touchId = undefined;
|
|
1535
|
-
if (!this.viewOptions.keyboardSupport) {
|
|
1536
|
-
this.minHandleElement.active = false;
|
|
1537
|
-
this.maxHandleElement.active = false;
|
|
1538
|
-
this.currentTrackingPointer = undefined;
|
|
1539
|
-
}
|
|
1540
|
-
this.dragging.active = false;
|
|
1541
|
-
this.unsubscribeOnMove();
|
|
1542
|
-
this.unsubscribeOnEnd();
|
|
1543
|
-
this.userChangeEnd.emit(this.getChangeContext());
|
|
1544
|
-
}
|
|
1545
|
-
onPointerFocus(pointerType) {
|
|
1546
|
-
const pointerElement = this.getPointerElement(pointerType);
|
|
1547
|
-
pointerElement.on('blur', () => this.onPointerBlur(pointerElement));
|
|
1548
|
-
pointerElement.on('keydown', (event) => this.onKeyboardEvent(event));
|
|
1549
|
-
pointerElement.on('keyup', () => this.onKeyUp());
|
|
1550
|
-
pointerElement.active = true;
|
|
1551
|
-
this.currentTrackingPointer = pointerType;
|
|
1552
|
-
this.currentFocusPointer = pointerType;
|
|
1553
|
-
this.firstKeyDown = true;
|
|
1554
|
-
}
|
|
1555
|
-
onKeyUp() {
|
|
1556
|
-
this.firstKeyDown = true;
|
|
1557
|
-
this.userChangeEnd.emit(this.getChangeContext());
|
|
1558
|
-
}
|
|
1559
|
-
onPointerBlur(pointer) {
|
|
1560
|
-
pointer.off('blur');
|
|
1561
|
-
pointer.off('keydown');
|
|
1562
|
-
pointer.off('keyup');
|
|
1563
|
-
pointer.active = false;
|
|
1564
|
-
if (ValueHelper.isNullOrUndefined(this.touchId)) {
|
|
1565
|
-
this.currentTrackingPointer = undefined;
|
|
1566
|
-
this.currentFocusPointer = undefined;
|
|
1567
|
-
}
|
|
1568
|
-
}
|
|
1569
|
-
getKeyActions(currentValue) {
|
|
1570
|
-
const valueRange = this.viewOptions.ceil - this.viewOptions.floor;
|
|
1571
|
-
let increaseStep = currentValue + this.viewOptions.step;
|
|
1572
|
-
let decreaseStep = currentValue - this.viewOptions.step;
|
|
1573
|
-
let increasePage = currentValue + valueRange / 10;
|
|
1574
|
-
let decreasePage = currentValue - valueRange / 10;
|
|
1575
|
-
if (this.viewOptions.reversedControls) {
|
|
1576
|
-
increaseStep = currentValue - this.viewOptions.step;
|
|
1577
|
-
decreaseStep = currentValue + this.viewOptions.step;
|
|
1578
|
-
increasePage = currentValue - valueRange / 10;
|
|
1579
|
-
decreasePage = currentValue + valueRange / 10;
|
|
1580
|
-
}
|
|
1581
|
-
// Left to right default actions
|
|
1582
|
-
const actions = {
|
|
1583
|
-
UP: increaseStep,
|
|
1584
|
-
DOWN: decreaseStep,
|
|
1585
|
-
LEFT: decreaseStep,
|
|
1586
|
-
RIGHT: increaseStep,
|
|
1587
|
-
PAGEUP: increasePage,
|
|
1588
|
-
PAGEDOWN: decreasePage,
|
|
1589
|
-
HOME: this.viewOptions.reversedControls ? this.viewOptions.ceil : this.viewOptions.floor,
|
|
1590
|
-
END: this.viewOptions.reversedControls ? this.viewOptions.floor : this.viewOptions.ceil
|
|
1591
|
-
};
|
|
1592
|
-
// right to left means swapping right and left arrows
|
|
1593
|
-
if (this.viewOptions.rightToLeft) {
|
|
1594
|
-
actions['LEFT'] = increaseStep;
|
|
1595
|
-
actions['RIGHT'] = decreaseStep;
|
|
1596
|
-
// right to left and vertical means we also swap up and down
|
|
1597
|
-
if (this.viewOptions.vertical || this.viewOptions.rotate !== 0) {
|
|
1598
|
-
actions['UP'] = decreaseStep;
|
|
1599
|
-
actions['DOWN'] = increaseStep;
|
|
1600
|
-
}
|
|
1601
|
-
}
|
|
1602
|
-
return actions;
|
|
1603
|
-
}
|
|
1604
|
-
onKeyboardEvent(event) {
|
|
1605
|
-
const currentValue = this.getCurrentTrackingValue();
|
|
1606
|
-
const keyCode = !ValueHelper.isNullOrUndefined(event.keyCode) ? event.keyCode : event.which;
|
|
1607
|
-
const keys = {
|
|
1608
|
-
38: 'UP',
|
|
1609
|
-
40: 'DOWN',
|
|
1610
|
-
37: 'LEFT',
|
|
1611
|
-
39: 'RIGHT',
|
|
1612
|
-
33: 'PAGEUP',
|
|
1613
|
-
34: 'PAGEDOWN',
|
|
1614
|
-
36: 'HOME',
|
|
1615
|
-
35: 'END'
|
|
1616
|
-
};
|
|
1617
|
-
const actions = this.getKeyActions(currentValue);
|
|
1618
|
-
const key = keys[keyCode];
|
|
1619
|
-
const action = actions[key];
|
|
1620
|
-
if (ValueHelper.isNullOrUndefined(action) || ValueHelper.isNullOrUndefined(this.currentTrackingPointer)) {
|
|
1621
|
-
return;
|
|
1622
|
-
}
|
|
1623
|
-
event.preventDefault();
|
|
1624
|
-
if (this.firstKeyDown) {
|
|
1625
|
-
this.firstKeyDown = false;
|
|
1626
|
-
this.userChangeStart.emit(this.getChangeContext());
|
|
1627
|
-
}
|
|
1628
|
-
const actionValue = MathHelper.clampToRange(action, this.viewOptions.floor, this.viewOptions.ceil);
|
|
1629
|
-
const newValue = this.roundStep(actionValue);
|
|
1630
|
-
if (!this.viewOptions.draggableRangeOnly) {
|
|
1631
|
-
this.positionTrackingHandle(newValue);
|
|
1632
|
-
}
|
|
1633
|
-
else {
|
|
1634
|
-
const difference = this.viewHighValue - this.viewLowValue;
|
|
1635
|
-
let newMinValue;
|
|
1636
|
-
let newMaxValue;
|
|
1637
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
1638
|
-
newMinValue = newValue;
|
|
1639
|
-
newMaxValue = newValue + difference;
|
|
1640
|
-
if (newMaxValue > this.viewOptions.ceil) {
|
|
1641
|
-
newMaxValue = this.viewOptions.ceil;
|
|
1642
|
-
newMinValue = newMaxValue - difference;
|
|
1643
|
-
}
|
|
1644
|
-
}
|
|
1645
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
1646
|
-
newMaxValue = newValue;
|
|
1647
|
-
newMinValue = newValue - difference;
|
|
1648
|
-
if (newMinValue < this.viewOptions.floor) {
|
|
1649
|
-
newMinValue = this.viewOptions.floor;
|
|
1650
|
-
newMaxValue = newMinValue + difference;
|
|
1651
|
-
}
|
|
1652
|
-
}
|
|
1653
|
-
this.positionTrackingBar(newMinValue, newMaxValue);
|
|
1654
|
-
}
|
|
1655
|
-
}
|
|
1656
|
-
// onDragStart event handler, handles dragging of the middle bar
|
|
1657
|
-
onDragStart(event, bindMove, bindEnd, pointerType) {
|
|
1658
|
-
const position = this.getEventPosition(event);
|
|
1659
|
-
this.dragging = new Dragging();
|
|
1660
|
-
this.dragging.active = true;
|
|
1661
|
-
this.dragging.value = this.positionToValue(position);
|
|
1662
|
-
this.dragging.difference = this.viewHighValue - this.viewLowValue;
|
|
1663
|
-
this.dragging.lowLimit = this.viewOptions.rightToLeft
|
|
1664
|
-
? this.minHandleElement.position - position
|
|
1665
|
-
: position - this.minHandleElement.position;
|
|
1666
|
-
this.dragging.highLimit = this.viewOptions.rightToLeft
|
|
1667
|
-
? position - this.maxHandleElement.position
|
|
1668
|
-
: this.maxHandleElement.position - position;
|
|
1669
|
-
this.onStart(event, bindMove, bindEnd, pointerType);
|
|
1670
|
-
}
|
|
1671
|
-
/** Get min value depending on whether the newPos is outOfBounds above or below the bar and rightToLeft */
|
|
1672
|
-
getMinValue(newPos, outOfBounds, isAbove) {
|
|
1673
|
-
const isRTL = this.viewOptions.rightToLeft;
|
|
1674
|
-
let value;
|
|
1675
|
-
if (outOfBounds) {
|
|
1676
|
-
if (isAbove) {
|
|
1677
|
-
value = isRTL ? this.viewOptions.floor : this.viewOptions.ceil - this.dragging.difference;
|
|
1678
|
-
}
|
|
1679
|
-
else {
|
|
1680
|
-
value = isRTL ? this.viewOptions.ceil - this.dragging.difference : this.viewOptions.floor;
|
|
1681
|
-
}
|
|
1682
|
-
}
|
|
1683
|
-
else {
|
|
1684
|
-
value = isRTL
|
|
1685
|
-
? this.positionToValue(newPos + this.dragging.lowLimit)
|
|
1686
|
-
: this.positionToValue(newPos - this.dragging.lowLimit);
|
|
1687
|
-
}
|
|
1688
|
-
return this.roundStep(value);
|
|
1689
|
-
}
|
|
1690
|
-
/** Get max value depending on whether the newPos is outOfBounds above or below the bar and rightToLeft */
|
|
1691
|
-
getMaxValue(newPos, outOfBounds, isAbove) {
|
|
1692
|
-
const isRTL = this.viewOptions.rightToLeft;
|
|
1693
|
-
let value;
|
|
1694
|
-
if (outOfBounds) {
|
|
1695
|
-
if (isAbove) {
|
|
1696
|
-
value = isRTL ? this.viewOptions.floor + this.dragging.difference : this.viewOptions.ceil;
|
|
1697
|
-
}
|
|
1698
|
-
else {
|
|
1699
|
-
value = isRTL ? this.viewOptions.ceil : this.viewOptions.floor + this.dragging.difference;
|
|
1700
|
-
}
|
|
1701
|
-
}
|
|
1702
|
-
else {
|
|
1703
|
-
if (isRTL) {
|
|
1704
|
-
value = this.positionToValue(newPos + this.dragging.lowLimit) + this.dragging.difference;
|
|
1705
|
-
}
|
|
1706
|
-
else {
|
|
1707
|
-
value = this.positionToValue(newPos - this.dragging.lowLimit) + this.dragging.difference;
|
|
1708
|
-
}
|
|
1709
|
-
}
|
|
1710
|
-
return this.roundStep(value);
|
|
1711
|
-
}
|
|
1712
|
-
onDragMove(event) {
|
|
1713
|
-
const newPos = this.getEventPosition(event);
|
|
1714
|
-
if (this.viewOptions.animate && !this.viewOptions.animateOnMove) {
|
|
1715
|
-
if (this.moving) {
|
|
1716
|
-
this.sliderElementAnimateClass = false;
|
|
1717
|
-
}
|
|
1718
|
-
}
|
|
1719
|
-
this.moving = true;
|
|
1720
|
-
let ceilLimit, floorLimit, floorHandleElement, ceilHandleElement;
|
|
1721
|
-
if (this.viewOptions.rightToLeft) {
|
|
1722
|
-
ceilLimit = this.dragging.lowLimit;
|
|
1723
|
-
floorLimit = this.dragging.highLimit;
|
|
1724
|
-
floorHandleElement = this.maxHandleElement;
|
|
1725
|
-
ceilHandleElement = this.minHandleElement;
|
|
1726
|
-
}
|
|
1727
|
-
else {
|
|
1728
|
-
ceilLimit = this.dragging.highLimit;
|
|
1729
|
-
floorLimit = this.dragging.lowLimit;
|
|
1730
|
-
floorHandleElement = this.minHandleElement;
|
|
1731
|
-
ceilHandleElement = this.maxHandleElement;
|
|
1732
|
-
}
|
|
1733
|
-
const isUnderFloorLimit = newPos <= floorLimit;
|
|
1734
|
-
const isOverCeilLimit = newPos >= this.maxHandlePosition - ceilLimit;
|
|
1735
|
-
let newMinValue;
|
|
1736
|
-
let newMaxValue;
|
|
1737
|
-
if (isUnderFloorLimit) {
|
|
1738
|
-
if (floorHandleElement.position === 0) {
|
|
1739
|
-
return;
|
|
1740
|
-
}
|
|
1741
|
-
newMinValue = this.getMinValue(newPos, true, false);
|
|
1742
|
-
newMaxValue = this.getMaxValue(newPos, true, false);
|
|
1743
|
-
}
|
|
1744
|
-
else if (isOverCeilLimit) {
|
|
1745
|
-
if (ceilHandleElement.position === this.maxHandlePosition) {
|
|
1746
|
-
return;
|
|
1747
|
-
}
|
|
1748
|
-
newMaxValue = this.getMaxValue(newPos, true, true);
|
|
1749
|
-
newMinValue = this.getMinValue(newPos, true, true);
|
|
1750
|
-
}
|
|
1751
|
-
else {
|
|
1752
|
-
newMinValue = this.getMinValue(newPos, false, false);
|
|
1753
|
-
newMaxValue = this.getMaxValue(newPos, false, false);
|
|
1754
|
-
}
|
|
1755
|
-
this.positionTrackingBar(newMinValue, newMaxValue);
|
|
1756
|
-
}
|
|
1757
|
-
// Set the new value and position for the entire bar
|
|
1758
|
-
positionTrackingBar(newMinValue, newMaxValue) {
|
|
1759
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.minLimit) && newMinValue < this.viewOptions.minLimit) {
|
|
1760
|
-
newMinValue = this.viewOptions.minLimit;
|
|
1761
|
-
newMaxValue = MathHelper.roundToPrecisionLimit(newMinValue + this.dragging.difference, this.viewOptions.precisionLimit);
|
|
1762
|
-
}
|
|
1763
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.maxLimit) && newMaxValue > this.viewOptions.maxLimit) {
|
|
1764
|
-
newMaxValue = this.viewOptions.maxLimit;
|
|
1765
|
-
newMinValue = MathHelper.roundToPrecisionLimit(newMaxValue - this.dragging.difference, this.viewOptions.precisionLimit);
|
|
1766
|
-
}
|
|
1767
|
-
this.viewLowValue = newMinValue;
|
|
1768
|
-
this.viewHighValue = newMaxValue;
|
|
1769
|
-
this.applyViewChange();
|
|
1770
|
-
this.updateHandles(PointerType.Min, this.valueToPosition(newMinValue));
|
|
1771
|
-
this.updateHandles(PointerType.Max, this.valueToPosition(newMaxValue));
|
|
1772
|
-
}
|
|
1773
|
-
// Set the new value and position to the current tracking handle
|
|
1774
|
-
positionTrackingHandle(newValue) {
|
|
1775
|
-
newValue = this.applyMinMaxLimit(newValue);
|
|
1776
|
-
if (this.range) {
|
|
1777
|
-
if (this.viewOptions.pushRange) {
|
|
1778
|
-
newValue = this.applyPushRange(newValue);
|
|
1779
|
-
}
|
|
1780
|
-
else {
|
|
1781
|
-
if (this.viewOptions.noSwitching) {
|
|
1782
|
-
if (this.currentTrackingPointer === PointerType.Min && newValue > this.viewHighValue) {
|
|
1783
|
-
newValue = this.applyMinMaxRange(this.viewHighValue);
|
|
1784
|
-
}
|
|
1785
|
-
else if (this.currentTrackingPointer === PointerType.Max && newValue < this.viewLowValue) {
|
|
1786
|
-
newValue = this.applyMinMaxRange(this.viewLowValue);
|
|
1787
|
-
}
|
|
1788
|
-
}
|
|
1789
|
-
newValue = this.applyMinMaxRange(newValue);
|
|
1790
|
-
/* This is to check if we need to switch the min and max handles */
|
|
1791
|
-
if (this.currentTrackingPointer === PointerType.Min && newValue > this.viewHighValue) {
|
|
1792
|
-
this.viewLowValue = this.viewHighValue;
|
|
1793
|
-
this.applyViewChange();
|
|
1794
|
-
this.updateHandles(PointerType.Min, this.maxHandleElement.position);
|
|
1795
|
-
this.updateAriaAttributes();
|
|
1796
|
-
this.currentTrackingPointer = PointerType.Max;
|
|
1797
|
-
this.minHandleElement.active = false;
|
|
1798
|
-
this.maxHandleElement.active = true;
|
|
1799
|
-
if (this.viewOptions.keyboardSupport) {
|
|
1800
|
-
this.maxHandleElement.focus();
|
|
1801
|
-
}
|
|
1802
|
-
}
|
|
1803
|
-
else if (this.currentTrackingPointer === PointerType.Max && newValue < this.viewLowValue) {
|
|
1804
|
-
this.viewHighValue = this.viewLowValue;
|
|
1805
|
-
this.applyViewChange();
|
|
1806
|
-
this.updateHandles(PointerType.Max, this.minHandleElement.position);
|
|
1807
|
-
this.updateAriaAttributes();
|
|
1808
|
-
this.currentTrackingPointer = PointerType.Min;
|
|
1809
|
-
this.maxHandleElement.active = false;
|
|
1810
|
-
this.minHandleElement.active = true;
|
|
1811
|
-
if (this.viewOptions.keyboardSupport) {
|
|
1812
|
-
this.minHandleElement.focus();
|
|
1813
|
-
}
|
|
1814
|
-
}
|
|
1815
|
-
}
|
|
1816
|
-
}
|
|
1817
|
-
if (this.getCurrentTrackingValue() !== newValue) {
|
|
1818
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
1819
|
-
this.viewLowValue = newValue;
|
|
1820
|
-
this.applyViewChange();
|
|
1821
|
-
}
|
|
1822
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
1823
|
-
this.viewHighValue = newValue;
|
|
1824
|
-
this.applyViewChange();
|
|
1825
|
-
}
|
|
1826
|
-
this.updateHandles(this.currentTrackingPointer, this.valueToPosition(newValue));
|
|
1827
|
-
this.updateAriaAttributes();
|
|
1828
|
-
}
|
|
1829
|
-
}
|
|
1830
|
-
applyMinMaxLimit(newValue) {
|
|
1831
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.minLimit) && newValue < this.viewOptions.minLimit) {
|
|
1832
|
-
return this.viewOptions.minLimit;
|
|
1833
|
-
}
|
|
1834
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.maxLimit) && newValue > this.viewOptions.maxLimit) {
|
|
1835
|
-
return this.viewOptions.maxLimit;
|
|
1836
|
-
}
|
|
1837
|
-
return newValue;
|
|
1838
|
-
}
|
|
1839
|
-
applyMinMaxRange(newValue) {
|
|
1840
|
-
const oppositeValue = this.currentTrackingPointer === PointerType.Min ? this.viewHighValue : this.viewLowValue;
|
|
1841
|
-
const difference = Math.abs(newValue - oppositeValue);
|
|
1842
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.minRange)) {
|
|
1843
|
-
if (difference < this.viewOptions.minRange) {
|
|
1844
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
1845
|
-
return MathHelper.roundToPrecisionLimit(this.viewHighValue - this.viewOptions.minRange, this.viewOptions.precisionLimit);
|
|
1846
|
-
}
|
|
1847
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
1848
|
-
return MathHelper.roundToPrecisionLimit(this.viewLowValue + this.viewOptions.minRange, this.viewOptions.precisionLimit);
|
|
1849
|
-
}
|
|
1850
|
-
}
|
|
1851
|
-
}
|
|
1852
|
-
if (!ValueHelper.isNullOrUndefined(this.viewOptions.maxRange)) {
|
|
1853
|
-
if (difference > this.viewOptions.maxRange) {
|
|
1854
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
1855
|
-
return MathHelper.roundToPrecisionLimit(this.viewHighValue - this.viewOptions.maxRange, this.viewOptions.precisionLimit);
|
|
1856
|
-
}
|
|
1857
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
1858
|
-
return MathHelper.roundToPrecisionLimit(this.viewLowValue + this.viewOptions.maxRange, this.viewOptions.precisionLimit);
|
|
1859
|
-
}
|
|
1860
|
-
}
|
|
1861
|
-
}
|
|
1862
|
-
return newValue;
|
|
1863
|
-
}
|
|
1864
|
-
applyPushRange(newValue) {
|
|
1865
|
-
const difference = this.currentTrackingPointer === PointerType.Min ? this.viewHighValue - newValue : newValue - this.viewLowValue;
|
|
1866
|
-
const minRange = !ValueHelper.isNullOrUndefined(this.viewOptions.minRange)
|
|
1867
|
-
? this.viewOptions.minRange
|
|
1868
|
-
: this.viewOptions.step;
|
|
1869
|
-
const maxRange = this.viewOptions.maxRange;
|
|
1870
|
-
// if smaller than minRange
|
|
1871
|
-
if (difference < minRange) {
|
|
1872
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
1873
|
-
this.viewHighValue = MathHelper.roundToPrecisionLimit(Math.min(newValue + minRange, this.viewOptions.ceil), this.viewOptions.precisionLimit);
|
|
1874
|
-
newValue = MathHelper.roundToPrecisionLimit(this.viewHighValue - minRange, this.viewOptions.precisionLimit);
|
|
1875
|
-
this.applyViewChange();
|
|
1876
|
-
this.updateHandles(PointerType.Max, this.valueToPosition(this.viewHighValue));
|
|
1877
|
-
}
|
|
1878
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
1879
|
-
this.viewLowValue = MathHelper.roundToPrecisionLimit(Math.max(newValue - minRange, this.viewOptions.floor), this.viewOptions.precisionLimit);
|
|
1880
|
-
newValue = MathHelper.roundToPrecisionLimit(this.viewLowValue + minRange, this.viewOptions.precisionLimit);
|
|
1881
|
-
this.applyViewChange();
|
|
1882
|
-
this.updateHandles(PointerType.Min, this.valueToPosition(this.viewLowValue));
|
|
1883
|
-
}
|
|
1884
|
-
this.updateAriaAttributes();
|
|
1885
|
-
}
|
|
1886
|
-
else if (!ValueHelper.isNullOrUndefined(maxRange) && difference > maxRange) {
|
|
1887
|
-
// if greater than maxRange
|
|
1888
|
-
if (this.currentTrackingPointer === PointerType.Min) {
|
|
1889
|
-
this.viewHighValue = MathHelper.roundToPrecisionLimit(newValue + maxRange, this.viewOptions.precisionLimit);
|
|
1890
|
-
this.applyViewChange();
|
|
1891
|
-
this.updateHandles(PointerType.Max, this.valueToPosition(this.viewHighValue));
|
|
1892
|
-
}
|
|
1893
|
-
else if (this.currentTrackingPointer === PointerType.Max) {
|
|
1894
|
-
this.viewLowValue = MathHelper.roundToPrecisionLimit(newValue - maxRange, this.viewOptions.precisionLimit);
|
|
1895
|
-
this.applyViewChange();
|
|
1896
|
-
this.updateHandles(PointerType.Min, this.valueToPosition(this.viewLowValue));
|
|
1897
|
-
}
|
|
1898
|
-
this.updateAriaAttributes();
|
|
1899
|
-
}
|
|
1900
|
-
return newValue;
|
|
1901
|
-
}
|
|
1902
|
-
getChangeContext() {
|
|
1903
|
-
const changeContext = new ChangeContext();
|
|
1904
|
-
changeContext.pointerType = this.currentTrackingPointer;
|
|
1905
|
-
changeContext.value = +this.value;
|
|
1906
|
-
if (this.range) {
|
|
1907
|
-
changeContext.highValue = +this.highValue;
|
|
1908
|
-
}
|
|
1909
|
-
return changeContext;
|
|
1910
|
-
}
|
|
1911
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1912
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: SliderComponent, isStandalone: true, selector: "ngx-slider", inputs: { value: "value", highValue: "highValue", options: "options", manualRefresh: "manualRefresh", triggerFocus: "triggerFocus" }, outputs: { valueChange: "valueChange", highValueChange: "highValueChange", userChangeStart: "userChangeStart", userChange: "userChange", userChangeEnd: "userChangeEnd" }, host: { listeners: { "window:resize": "onResize($event)" }, properties: { "class": "this.class", "class.vertical": "this.sliderElementVerticalClass", "class.animate": "this.sliderElementAnimateClass", "class.with-legend": "this.sliderElementWithLegendClass", "attr.disabled": "this.sliderElementDisabledAttr", "attr.aria-label": "this.sliderElementAriaLabel" } }, providers: [NGX_SLIDER_CONTROL_VALUE_ACCESSOR], queries: [{ propertyName: "tooltipTemplate", first: true, predicate: ["tooltipTemplate"], descendants: true }], viewQueries: [{ propertyName: "leftOuterSelectionBarElement", first: true, predicate: ["leftOuterSelectionBar"], descendants: true, read: SliderElementDirective }, { propertyName: "rightOuterSelectionBarElement", first: true, predicate: ["rightOuterSelectionBar"], descendants: true, read: SliderElementDirective }, { propertyName: "fullBarElement", first: true, predicate: ["fullBar"], descendants: true, read: SliderElementDirective }, { propertyName: "selectionBarElement", first: true, predicate: ["selectionBar"], descendants: true, read: SliderElementDirective }, { propertyName: "minHandleElement", first: true, predicate: ["minHandle"], descendants: true, read: SliderHandleDirective }, { propertyName: "maxHandleElement", first: true, predicate: ["maxHandle"], descendants: true, read: SliderHandleDirective }, { propertyName: "floorLabelElement", first: true, predicate: ["floorLabel"], descendants: true, read: SliderLabelDirective }, { propertyName: "ceilLabelElement", first: true, predicate: ["ceilLabel"], descendants: true, read: SliderLabelDirective }, { propertyName: "minHandleLabelElement", first: true, predicate: ["minHandleLabel"], descendants: true, read: SliderLabelDirective }, { propertyName: "maxHandleLabelElement", first: true, predicate: ["maxHandleLabel"], descendants: true, read: SliderLabelDirective }, { propertyName: "combinedLabelElement", first: true, predicate: ["combinedLabel"], descendants: true, read: SliderLabelDirective }, { propertyName: "ticksElement", first: true, predicate: ["ticksElement"], descendants: true, read: SliderElementDirective }], usesOnChanges: true, ngImport: i0, template: "<!-- // 0 Left selection bar outside two handles -->\n<span\n ngxSliderElement\n #leftOuterSelectionBar\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-left-out-selection\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 1 Right selection bar outside two handles -->\n<span\n ngxSliderElement\n #rightOuterSelectionBar\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-right-out-selection\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 2 The whole slider bar -->\n<span\n ngxSliderElement\n #fullBar\n [class.ngx-slider-transparent]=\"fullBarTransparentClass\"\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-full-bar\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 3 Selection bar between two handles -->\n<span\n ngxSliderElement\n #selectionBar\n [class.ngx-slider-draggable]=\"selectionBarDraggableClass\"\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-selection-bar\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar ngx-slider-selection\" [ngStyle]=\"barStyle\"></span>\n</span>\n<!-- // 4 Low slider handle -->\n<span\n ngxSliderHandle\n #minHandle\n class=\"ngx-slider-span ngx-slider-pointer ngx-slider-pointer-min\"\n [ngStyle]=\"minPointerStyle\"\n></span>\n<!-- // 5 High slider handle -->\n<span\n ngxSliderHandle\n #maxHandle\n [style.display]=\"range ? 'inherit' : 'none'\"\n class=\"ngx-slider-span ngx-slider-pointer ngx-slider-pointer-max\"\n [ngStyle]=\"maxPointerStyle\"\n></span>\n<!-- // 6 Floor label -->\n<span ngxSliderLabel #floorLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-limit ngx-slider-floor\"></span>\n<!-- // 7 Ceiling label -->\n<span ngxSliderLabel #ceilLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-limit ngx-slider-ceil\"></span>\n<!-- // 8 Label above the low slider handle -->\n<span ngxSliderLabel #minHandleLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-model-value\"></span>\n<!-- // 9 Label above the high slider handle -->\n<span ngxSliderLabel #maxHandleLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-model-high\"></span>\n<!-- // 10 Combined range label when the slider handles are close ex. 15 - 17 -->\n<span ngxSliderLabel #combinedLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-combined\"></span>\n<!-- // 11 The ticks -->\n<span\n ngxSliderElement\n #ticksElement\n [hidden]=\"!showTicks\"\n [class.ngx-slider-ticks-values-under]=\"ticksUnderValuesClass\"\n class=\"ngx-slider-ticks\"\n>\n @for (t of ticks; track t) {\n <span class=\"ngx-slider-tick\" [ngClass]=\"{ 'ngx-slider-selected': t.selected }\" [ngStyle]=\"t.style\">\n <ngx-slider-tooltip-wrapper\n [template]=\"tooltipTemplate\"\n [tooltip]=\"t.tooltip\"\n [placement]=\"t.tooltipPlacement\"\n ></ngx-slider-tooltip-wrapper>\n @if (t.value !== null) {\n <ngx-slider-tooltip-wrapper\n class=\"ngx-slider-span ngx-slider-tick-value\"\n [template]=\"tooltipTemplate\"\n [tooltip]=\"t.valueTooltip\"\n [placement]=\"t.valueTooltipPlacement\"\n [content]=\"t.value\"\n ></ngx-slider-tooltip-wrapper>\n }\n @if (t.legend !== null) {\n <span class=\"ngx-slider-span ngx-slider-tick-legend\" [innerHTML]=\"t.legend\"></span>\n }\n </span>\n }\n</span>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: TooltipWrapperComponent, selector: "ngx-slider-tooltip-wrapper", inputs: ["template", "tooltip", "placement", "content"] }, { kind: "directive", type: SliderLabelDirective, selector: "[ngxSliderLabel]" }, { kind: "directive", type: SliderHandleDirective, selector: "[ngxSliderHandle]" }, { kind: "directive", type: SliderElementDirective, selector: "[ngxSliderElement]" }] }); }
|
|
1913
|
-
}
|
|
1914
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SliderComponent, decorators: [{
|
|
1915
|
-
type: Component,
|
|
1916
|
-
args: [{ selector: 'ngx-slider', providers: [NGX_SLIDER_CONTROL_VALUE_ACCESSOR], standalone: true, imports: [CommonModule, TooltipWrapperComponent, SliderLabelDirective, SliderHandleDirective, SliderElementDirective], template: "<!-- // 0 Left selection bar outside two handles -->\n<span\n ngxSliderElement\n #leftOuterSelectionBar\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-left-out-selection\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 1 Right selection bar outside two handles -->\n<span\n ngxSliderElement\n #rightOuterSelectionBar\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-right-out-selection\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 2 The whole slider bar -->\n<span\n ngxSliderElement\n #fullBar\n [class.ngx-slider-transparent]=\"fullBarTransparentClass\"\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-full-bar\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 3 Selection bar between two handles -->\n<span\n ngxSliderElement\n #selectionBar\n [class.ngx-slider-draggable]=\"selectionBarDraggableClass\"\n class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-selection-bar\"\n>\n <span class=\"ngx-slider-span ngx-slider-bar ngx-slider-selection\" [ngStyle]=\"barStyle\"></span>\n</span>\n<!-- // 4 Low slider handle -->\n<span\n ngxSliderHandle\n #minHandle\n class=\"ngx-slider-span ngx-slider-pointer ngx-slider-pointer-min\"\n [ngStyle]=\"minPointerStyle\"\n></span>\n<!-- // 5 High slider handle -->\n<span\n ngxSliderHandle\n #maxHandle\n [style.display]=\"range ? 'inherit' : 'none'\"\n class=\"ngx-slider-span ngx-slider-pointer ngx-slider-pointer-max\"\n [ngStyle]=\"maxPointerStyle\"\n></span>\n<!-- // 6 Floor label -->\n<span ngxSliderLabel #floorLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-limit ngx-slider-floor\"></span>\n<!-- // 7 Ceiling label -->\n<span ngxSliderLabel #ceilLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-limit ngx-slider-ceil\"></span>\n<!-- // 8 Label above the low slider handle -->\n<span ngxSliderLabel #minHandleLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-model-value\"></span>\n<!-- // 9 Label above the high slider handle -->\n<span ngxSliderLabel #maxHandleLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-model-high\"></span>\n<!-- // 10 Combined range label when the slider handles are close ex. 15 - 17 -->\n<span ngxSliderLabel #combinedLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-combined\"></span>\n<!-- // 11 The ticks -->\n<span\n ngxSliderElement\n #ticksElement\n [hidden]=\"!showTicks\"\n [class.ngx-slider-ticks-values-under]=\"ticksUnderValuesClass\"\n class=\"ngx-slider-ticks\"\n>\n @for (t of ticks; track t) {\n <span class=\"ngx-slider-tick\" [ngClass]=\"{ 'ngx-slider-selected': t.selected }\" [ngStyle]=\"t.style\">\n <ngx-slider-tooltip-wrapper\n [template]=\"tooltipTemplate\"\n [tooltip]=\"t.tooltip\"\n [placement]=\"t.tooltipPlacement\"\n ></ngx-slider-tooltip-wrapper>\n @if (t.value !== null) {\n <ngx-slider-tooltip-wrapper\n class=\"ngx-slider-span ngx-slider-tick-value\"\n [template]=\"tooltipTemplate\"\n [tooltip]=\"t.valueTooltip\"\n [placement]=\"t.valueTooltipPlacement\"\n [content]=\"t.value\"\n ></ngx-slider-tooltip-wrapper>\n }\n @if (t.legend !== null) {\n <span class=\"ngx-slider-span ngx-slider-tick-legend\" [innerHTML]=\"t.legend\"></span>\n }\n </span>\n }\n</span>\n" }]
|
|
1917
|
-
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }], propDecorators: { class: [{
|
|
1918
|
-
type: HostBinding,
|
|
1919
|
-
args: ['class']
|
|
1920
|
-
}], value: [{
|
|
1921
|
-
type: Input
|
|
1922
|
-
}], valueChange: [{
|
|
1923
|
-
type: Output
|
|
1924
|
-
}], highValue: [{
|
|
1925
|
-
type: Input
|
|
1926
|
-
}], highValueChange: [{
|
|
1927
|
-
type: Output
|
|
1928
|
-
}], options: [{
|
|
1929
|
-
type: Input
|
|
1930
|
-
}], userChangeStart: [{
|
|
1931
|
-
type: Output
|
|
1932
|
-
}], userChange: [{
|
|
1933
|
-
type: Output
|
|
1934
|
-
}], userChangeEnd: [{
|
|
1935
|
-
type: Output
|
|
1936
|
-
}], manualRefresh: [{
|
|
1937
|
-
type: Input
|
|
1938
|
-
}], triggerFocus: [{
|
|
1939
|
-
type: Input
|
|
1940
|
-
}], leftOuterSelectionBarElement: [{
|
|
1941
|
-
type: ViewChild,
|
|
1942
|
-
args: ['leftOuterSelectionBar', { read: SliderElementDirective }]
|
|
1943
|
-
}], rightOuterSelectionBarElement: [{
|
|
1944
|
-
type: ViewChild,
|
|
1945
|
-
args: ['rightOuterSelectionBar', { read: SliderElementDirective }]
|
|
1946
|
-
}], fullBarElement: [{
|
|
1947
|
-
type: ViewChild,
|
|
1948
|
-
args: ['fullBar', { read: SliderElementDirective }]
|
|
1949
|
-
}], selectionBarElement: [{
|
|
1950
|
-
type: ViewChild,
|
|
1951
|
-
args: ['selectionBar', { read: SliderElementDirective }]
|
|
1952
|
-
}], minHandleElement: [{
|
|
1953
|
-
type: ViewChild,
|
|
1954
|
-
args: ['minHandle', { read: SliderHandleDirective }]
|
|
1955
|
-
}], maxHandleElement: [{
|
|
1956
|
-
type: ViewChild,
|
|
1957
|
-
args: ['maxHandle', { read: SliderHandleDirective }]
|
|
1958
|
-
}], floorLabelElement: [{
|
|
1959
|
-
type: ViewChild,
|
|
1960
|
-
args: ['floorLabel', { read: SliderLabelDirective }]
|
|
1961
|
-
}], ceilLabelElement: [{
|
|
1962
|
-
type: ViewChild,
|
|
1963
|
-
args: ['ceilLabel', { read: SliderLabelDirective }]
|
|
1964
|
-
}], minHandleLabelElement: [{
|
|
1965
|
-
type: ViewChild,
|
|
1966
|
-
args: ['minHandleLabel', { read: SliderLabelDirective }]
|
|
1967
|
-
}], maxHandleLabelElement: [{
|
|
1968
|
-
type: ViewChild,
|
|
1969
|
-
args: ['maxHandleLabel', { read: SliderLabelDirective }]
|
|
1970
|
-
}], combinedLabelElement: [{
|
|
1971
|
-
type: ViewChild,
|
|
1972
|
-
args: ['combinedLabel', { read: SliderLabelDirective }]
|
|
1973
|
-
}], ticksElement: [{
|
|
1974
|
-
type: ViewChild,
|
|
1975
|
-
args: ['ticksElement', { read: SliderElementDirective }]
|
|
1976
|
-
}], tooltipTemplate: [{
|
|
1977
|
-
type: ContentChild,
|
|
1978
|
-
args: ['tooltipTemplate']
|
|
1979
|
-
}], sliderElementVerticalClass: [{
|
|
1980
|
-
type: HostBinding,
|
|
1981
|
-
args: ['class.vertical']
|
|
1982
|
-
}], sliderElementAnimateClass: [{
|
|
1983
|
-
type: HostBinding,
|
|
1984
|
-
args: ['class.animate']
|
|
1985
|
-
}], sliderElementWithLegendClass: [{
|
|
1986
|
-
type: HostBinding,
|
|
1987
|
-
args: ['class.with-legend']
|
|
1988
|
-
}], sliderElementDisabledAttr: [{
|
|
1989
|
-
type: HostBinding,
|
|
1990
|
-
args: ['attr.disabled']
|
|
1991
|
-
}], sliderElementAriaLabel: [{
|
|
1992
|
-
type: HostBinding,
|
|
1993
|
-
args: ['attr.aria-label']
|
|
1994
|
-
}], onResize: [{
|
|
1995
|
-
type: HostListener,
|
|
1996
|
-
args: ['window:resize', ['$event']]
|
|
1997
|
-
}] } });
|
|
1998
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-factory/src/lib/angular/slider/lib/slider.component.ts","../../../../../../../projects/design-factory/src/lib/angular/slider/lib/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ViewChild,\n  AfterViewInit,\n  OnChanges,\n  OnDestroy,\n  HostBinding,\n  HostListener,\n  Input,\n  ElementRef,\n  Renderer2,\n  EventEmitter,\n  Output,\n  ContentChild,\n  TemplateRef,\n  ChangeDetectorRef,\n  SimpleChanges,\n  forwardRef,\n  NgZone\n} from '@angular/core';\n\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Subject, Subscription } from 'rxjs';\nimport { distinctUntilChanged, filter } from 'rxjs/operators';\n\nimport { Options, LabelType, ValueToPositionFunction, PositionToValueFunction, CustomStepDefinition } from './options';\nimport { PointerType } from './pointer-type';\nimport { ChangeContext } from './change-context';\nimport { ValueHelper } from './value-helper';\nimport { CompatibilityHelper } from './compatibility-helper';\nimport { MathHelper } from './math-helper';\nimport { EventListener } from './event-listener';\nimport { EventListenerHelper, supportsPassiveEvents } from './event-listener-helper';\nimport { SliderElementDirective } from './slider-element.directive';\nimport { SliderHandleDirective } from './slider-handle.directive';\nimport { SliderLabelDirective } from './slider-label.directive';\nimport { CommonModule } from '@angular/common';\nimport { TooltipWrapperComponent } from './tooltip-wrapper.component';\n\n// Declaration for ResizeObserver a new API available in some of newest browsers:\n// https://developer.mozilla.org/en-US/docs/Web/API/ResizeObserver\ndeclare class ResizeObserver {\n  constructor(callback: () => void);\n  observe(target: any): void;\n  unobserve(target: any): void;\n  disconnect(): void;\n}\n\nexport class Tick {\n  selected: boolean = false;\n  style: any = {};\n  tooltip?: string;\n  tooltipPlacement?: string;\n  value?: string;\n  valueTooltip?: string;\n  valueTooltipPlacement?: string;\n  legend?: string;\n}\n\nclass Dragging {\n  active: boolean = false;\n  value: number = 0;\n  difference: number = 0;\n  position: number = 0;\n  lowLimit: number = 0;\n  highLimit: number = 0;\n}\n\nclass ModelValues {\n  value?: number;\n  highValue?: number;\n\n  public static compare(x?: ModelValues, y?: ModelValues): boolean {\n    if (ValueHelper.isNullOrUndefined(x) && ValueHelper.isNullOrUndefined(y)) {\n      return false;\n    }\n    if (ValueHelper.isNullOrUndefined(x) !== ValueHelper.isNullOrUndefined(y)) {\n      return false;\n    }\n    return x!.value === y!.value && x!.highValue === y!.highValue;\n  }\n}\n\nclass ModelChange extends ModelValues {\n  // Flag used to by-pass distinctUntilChanged() filter on input values\n  // (sometimes there is a need to pass values through even though the model values have not changed)\n  forceChange?: boolean;\n\n  public static override compare(x?: ModelChange, y?: ModelChange): boolean {\n    if (ValueHelper.isNullOrUndefined(x) && ValueHelper.isNullOrUndefined(y)) {\n      return false;\n    }\n    if (ValueHelper.isNullOrUndefined(x) !== ValueHelper.isNullOrUndefined(y)) {\n      return false;\n    }\n    return x!.value === y!.value && x!.highValue === y!.highValue && x!.forceChange === y!.forceChange;\n  }\n}\n\nclass InputModelChange extends ModelChange {\n  internalChange?: boolean;\n}\n\nclass OutputModelChange extends ModelChange {\n  userEventInitiated?: boolean;\n}\n\nconst NGX_SLIDER_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  /* tslint:disable-next-line: no-use-before-declare */\n  useExisting: forwardRef(() => SliderComponent),\n  multi: true\n};\n\n/**\n * @deprecated SliderComponent is deprecated. Use {@link https://design-factory-int.app.net6.paas.westeurope.rnd.az.amadeus.net/#/components/slider/agnosui  AgnosUI Slider} instead.\n */\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'ngx-slider',\n  templateUrl: './slider.component.html',\n  providers: [NGX_SLIDER_CONTROL_VALUE_ACCESSOR],\n  standalone: true,\n  imports: [CommonModule, TooltipWrapperComponent, SliderLabelDirective, SliderHandleDirective, SliderElementDirective]\n})\nexport class SliderComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor {\n  @HostBinding('class') class = 'ngx-slider';\n  // Model for low value of slider. For simple slider, this is the only input. For range slider, this is the low value.\n  @Input()\n  public value?: number;\n  // Output for low value slider to support two-way bindings\n  @Output()\n  public valueChange: EventEmitter<number> = new EventEmitter();\n\n  // Model for high value of slider. Not used in simple slider. For range slider, this is the high value.\n  @Input()\n  public highValue?: number;\n  // Output for high value slider to support two-way bindings\n  @Output()\n  public highValueChange: EventEmitter<number> = new EventEmitter();\n\n  // An object with all the other options of the slider.\n  // Each option can be updated at runtime and the slider will automatically be re-rendered.\n  @Input()\n  public options: Options = new Options();\n\n  // Event emitted when user starts interaction with the slider\n  @Output()\n  public userChangeStart: EventEmitter<ChangeContext> = new EventEmitter();\n\n  // Event emitted on each change coming from user interaction\n  @Output()\n  public userChange: EventEmitter<ChangeContext> = new EventEmitter();\n\n  // Event emitted when user finishes interaction with the slider\n  @Output()\n  public userChangeEnd: EventEmitter<ChangeContext> = new EventEmitter();\n\n  private manualRefreshSubscription: any;\n  // Input event that triggers slider refresh (re-positioning of slider elements)\n  @Input() set manualRefresh(manualRefresh: EventEmitter<void>) {\n    this.unsubscribeManualRefresh();\n\n    this.manualRefreshSubscription = manualRefresh.subscribe(() => {\n      setTimeout(() => this.calculateViewDimensionsAndDetectChanges());\n    });\n  }\n\n  private triggerFocusSubscription: any;\n  // Input event that triggers setting focus on given slider handle\n  @Input() set triggerFocus(triggerFocus: EventEmitter<void>) {\n    this.unsubscribeTriggerFocus();\n\n    this.triggerFocusSubscription = triggerFocus.subscribe((pointerType: PointerType) => {\n      this.focusPointer(pointerType);\n    });\n  }\n\n  // Slider type, true means range slider\n  public get range(): boolean {\n    return !ValueHelper.isNullOrUndefined(this.value) && !ValueHelper.isNullOrUndefined(this.highValue);\n  }\n\n  // Set to true if init method already executed\n  private initHasRun: boolean = false;\n\n  // Changes in model inputs are passed through this subject\n  // These are all changes coming in from outside the component through input bindings or reactive form inputs\n  private inputModelChangeSubject: Subject<InputModelChange> = new Subject<InputModelChange>();\n  private inputModelChangeSubscription?: Subscription;\n\n  // Changes to model outputs are passed through this subject\n  // These are all changes that need to be communicated to output emitters and registered callbacks\n  private outputModelChangeSubject: Subject<OutputModelChange> = new Subject<OutputModelChange>();\n  private outputModelChangeSubscription?: Subscription;\n\n  // Low value synced to model low value\n  private viewLowValue?: number;\n  // High value synced to model high value\n  private viewHighValue?: number;\n  // Options synced to model options, based on defaults\n  private viewOptions: Options = new Options();\n\n  // Half of the width or height of the slider handles\n  private handleHalfDimension: number = 0;\n  // Maximum position the slider handle can have\n  private maxHandlePosition: number = 0;\n\n  // Which handle is currently tracked for move events\n  private currentTrackingPointer?: PointerType;\n  // Internal variable to keep track of the focus element\n  private currentFocusPointer?: PointerType;\n  // Used to call onStart on the first keydown event\n  private firstKeyDown = false;\n  // Current touch id of touch event being handled\n  private touchId?: number;\n  // Values recorded when first dragging the bar\n  private dragging: Dragging = new Dragging();\n\n  /* Slider DOM elements */\n\n  // Left selection bar outside two handles\n  @ViewChild('leftOuterSelectionBar', { read: SliderElementDirective })\n  private leftOuterSelectionBarElement?: SliderElementDirective;\n\n  // Right selection bar outside two handles\n  @ViewChild('rightOuterSelectionBar', { read: SliderElementDirective })\n  private rightOuterSelectionBarElement?: SliderElementDirective;\n\n  // The whole slider bar\n  @ViewChild('fullBar', { read: SliderElementDirective })\n  private fullBarElement?: SliderElementDirective;\n\n  // Highlight between two handles\n  @ViewChild('selectionBar', { read: SliderElementDirective })\n  private selectionBarElement?: SliderElementDirective;\n\n  // Left slider handle\n  @ViewChild('minHandle', { read: SliderHandleDirective })\n  private minHandleElement?: SliderHandleDirective;\n\n  // Right slider handle\n  @ViewChild('maxHandle', { read: SliderHandleDirective })\n  private maxHandleElement?: SliderHandleDirective;\n\n  // Floor label\n  @ViewChild('floorLabel', { read: SliderLabelDirective })\n  private floorLabelElement?: SliderLabelDirective;\n\n  // Ceiling label\n  @ViewChild('ceilLabel', { read: SliderLabelDirective })\n  private ceilLabelElement?: SliderLabelDirective;\n\n  // Label above the low value\n  @ViewChild('minHandleLabel', { read: SliderLabelDirective })\n  private minHandleLabelElement?: SliderLabelDirective;\n\n  // Label above the high value\n  @ViewChild('maxHandleLabel', { read: SliderLabelDirective })\n  private maxHandleLabelElement?: SliderLabelDirective;\n\n  // Combined label\n  @ViewChild('combinedLabel', { read: SliderLabelDirective })\n  private combinedLabelElement?: SliderLabelDirective;\n\n  // The ticks\n  @ViewChild('ticksElement', { read: SliderElementDirective })\n  private ticksElement?: SliderElementDirective;\n\n  // Optional custom template for displaying tooltips\n  @ContentChild('tooltipTemplate')\n  public tooltipTemplate!: TemplateRef<any>;\n\n  // Host element class bindings\n  @HostBinding('class.vertical')\n  public sliderElementVerticalClass = false;\n  @HostBinding('class.animate')\n  public sliderElementAnimateClass = false;\n  @HostBinding('class.with-legend')\n  public sliderElementWithLegendClass = false;\n  @HostBinding('attr.disabled')\n  public sliderElementDisabledAttr?: string;\n  @HostBinding('attr.aria-label')\n  public sliderElementAriaLabel: string = 'ngx-slider';\n\n  // CSS styles and class flags\n  public barStyle: any = {};\n  public minPointerStyle: any = {};\n  public maxPointerStyle: any = {};\n  public fullBarTransparentClass = false;\n  public selectionBarDraggableClass = false;\n  public ticksUnderValuesClass = false;\n\n  // Whether to show/hide ticks\n  public get showTicks(): boolean {\n    return this.viewOptions.showTicks || false;\n  }\n\n  /* If tickStep is set or ticksArray is specified.\n     In this case, ticks values should be displayed below the slider. */\n  private intermediateTicks: boolean = false;\n  // Ticks array as displayed in view\n  public ticks: Tick[] = [];\n\n  // Event listeners\n  private eventListenerHelper?: EventListenerHelper;\n  private onMoveEventListener?: EventListener;\n  private onEndEventListener?: EventListener;\n  // Whether currently moving the slider (between onStart() and onEnd())\n  private moving: boolean = false;\n\n  // Observer for slider element resize events\n  private resizeObserver?: ResizeObserver;\n\n  // Callbacks for reactive forms support\n  private onTouchedCallback?: (value: any) => void;\n  private onChangeCallback?: (value: any) => void;\n\n  public constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef,\n    private changeDetectionRef: ChangeDetectorRef,\n    private zone: NgZone\n  ) {\n    this.eventListenerHelper = new EventListenerHelper(this.renderer);\n  }\n\n  // OnInit interface\n  public ngOnInit(): void {\n    this.viewOptions = new Options();\n    Object.assign(this.viewOptions, this.options);\n\n    // We need to run these two things first, before the rest of the init in ngAfterViewInit(),\n    // because these two settings are set through @HostBinding and Angular change detection\n    // mechanism doesn't like them changing in ngAfterViewInit()\n\n    this.updateDisabledState();\n    this.updateVerticalState();\n    this.updateAriaLabel();\n  }\n\n  // AfterViewInit interface\n  public ngAfterViewInit(): void {\n    this.applyOptions();\n\n    this.subscribeInputModelChangeSubject();\n    this.subscribeOutputModelChangeSubject();\n\n    // Once we apply options, we need to normalise model values for the first time\n    this.renormaliseModelValues();\n\n    this.viewLowValue = this.modelValueToViewValue(this.value!);\n    if (this.range) {\n      this.viewHighValue = this.modelValueToViewValue(this.highValue!);\n    } else {\n      this.viewHighValue = undefined;\n    }\n\n    this.updateVerticalState(); // need to run this again to cover changes to slider elements\n    this.manageElementsStyle();\n    this.updateDisabledState();\n    this.calculateViewDimensions();\n    this.addAccessibility();\n    this.updateCeilLabel();\n    this.updateFloorLabel();\n    this.initHandles();\n    this.manageEventsBindings();\n    this.updateAriaLabel();\n\n    this.subscribeResizeObserver();\n\n    this.initHasRun = true;\n\n    // Run change detection manually to resolve some issues when init procedure changes values used in the view\n    if (!this.isRefDestroyed()) {\n      this.changeDetectionRef.detectChanges();\n    }\n  }\n\n  // OnChanges interface\n  public ngOnChanges(changes: SimpleChanges): void {\n    // Always apply options first\n    const options = changes['options'];\n    if (\n      !ValueHelper.isNullOrUndefined(options) &&\n      JSON.stringify(options.previousValue) !== JSON.stringify(options.currentValue)\n    ) {\n      this.onChangeOptions();\n    }\n\n    // Then value changes\n    if (!ValueHelper.isNullOrUndefined(changes['value']) || !ValueHelper.isNullOrUndefined(changes['highValue'])) {\n      this.inputModelChangeSubject.next({\n        value: this.value,\n        highValue: this.highValue,\n        forceChange: false,\n        internalChange: false\n      });\n    }\n  }\n\n  // OnDestroy interface\n  public ngOnDestroy(): void {\n    this.unbindEvents();\n\n    this.unsubscribeResizeObserver();\n    this.unsubscribeInputModelChangeSubject();\n    this.unsubscribeOutputModelChangeSubject();\n    this.unsubscribeManualRefresh();\n    this.unsubscribeTriggerFocus();\n  }\n\n  // ControlValueAccessor interface\n  public writeValue(obj: any): void {\n    if (obj instanceof Array) {\n      this.value = obj[0];\n      this.highValue = obj[1];\n    } else {\n      this.value = obj;\n    }\n\n    // ngOnChanges() is not called in this instance, so we need to communicate the change manually\n    this.inputModelChangeSubject.next({\n      value: this.value,\n      highValue: this.highValue,\n      forceChange: false,\n      internalChange: false\n    });\n  }\n\n  // ControlValueAccessor interface\n  public registerOnChange(onChangeCallback: any): void {\n    this.onChangeCallback = onChangeCallback;\n  }\n\n  // ControlValueAccessor interface\n  public registerOnTouched(onTouchedCallback: any): void {\n    this.onTouchedCallback = onTouchedCallback;\n  }\n\n  // ControlValueAccessor interface\n  public setDisabledState(isDisabled: boolean): void {\n    this.viewOptions.disabled = isDisabled;\n    this.updateDisabledState();\n  }\n\n  public setAriaLabel(ariaLabel: string): void {\n    this.viewOptions.ariaLabel = ariaLabel;\n    this.updateAriaLabel();\n  }\n\n  @HostListener('window:resize', ['$event'])\n  public onResize(event: any): void {\n    this.calculateViewDimensionsAndDetectChanges();\n  }\n\n  private subscribeInputModelChangeSubject(): void {\n    this.inputModelChangeSubscription = this.inputModelChangeSubject\n      .pipe(\n        distinctUntilChanged(ModelChange.compare as unknown as any),\n        // Hack to reset the status of the distinctUntilChanged() - if a \"fake\" event comes through with forceChange=true,\n        // we forcefully by-pass distinctUntilChanged(), but otherwise drop the event\n        filter((modelChange: InputModelChange) => !modelChange.forceChange && !modelChange.internalChange)\n      )\n      .subscribe((modelChange: InputModelChange) => this.applyInputModelChange(modelChange));\n  }\n\n  private subscribeOutputModelChangeSubject(): void {\n    this.outputModelChangeSubscription = this.outputModelChangeSubject\n      .pipe(distinctUntilChanged(ModelChange.compare))\n      .subscribe((modelChange: any) => this.publishOutputModelChange(modelChange));\n  }\n\n  private subscribeResizeObserver(): void {\n    if (CompatibilityHelper.isResizeObserverAvailable()) {\n      this.resizeObserver = new ResizeObserver((): void => this.calculateViewDimensionsAndDetectChanges());\n      this.resizeObserver.observe(this.elementRef.nativeElement);\n    }\n  }\n\n  private unsubscribeResizeObserver(): void {\n    if (CompatibilityHelper.isResizeObserverAvailable() && this.resizeObserver !== null) {\n      this.resizeObserver?.disconnect();\n      this.resizeObserver = undefined;\n    }\n  }\n\n  private unsubscribeOnMove(): void {\n    if (!ValueHelper.isNullOrUndefined(this.onMoveEventListener)) {\n      this.eventListenerHelper?.detachEventListener(this.onMoveEventListener!);\n      this.onMoveEventListener = undefined;\n    }\n  }\n\n  private unsubscribeOnEnd(): void {\n    if (!ValueHelper.isNullOrUndefined(this.onEndEventListener)) {\n      this.eventListenerHelper?.detachEventListener(this.onEndEventListener!);\n      this.onEndEventListener = undefined;\n    }\n  }\n\n  private unsubscribeInputModelChangeSubject(): void {\n    if (!ValueHelper.isNullOrUndefined(this.inputModelChangeSubscription)) {\n      this.inputModelChangeSubscription?.unsubscribe();\n      this.inputModelChangeSubscription = undefined;\n    }\n  }\n\n  private unsubscribeOutputModelChangeSubject(): void {\n    if (!ValueHelper.isNullOrUndefined(this.outputModelChangeSubscription)) {\n      this.outputModelChangeSubscription?.unsubscribe();\n      this.outputModelChangeSubscription = undefined;\n    }\n  }\n\n  private unsubscribeManualRefresh(): void {\n    if (!ValueHelper.isNullOrUndefined(this.manualRefreshSubscription)) {\n      this.manualRefreshSubscription.unsubscribe();\n      this.manualRefreshSubscription = undefined;\n    }\n  }\n\n  private unsubscribeTriggerFocus(): void {\n    if (!ValueHelper.isNullOrUndefined(this.triggerFocusSubscription)) {\n      this.triggerFocusSubscription.unsubscribe();\n      this.triggerFocusSubscription = null;\n    }\n  }\n\n  private getPointerElement(pointerType: PointerType): SliderHandleDirective | undefined {\n    if (pointerType === PointerType.Min) {\n      return this.minHandleElement;\n    } else if (pointerType === PointerType.Max) {\n      return this.maxHandleElement;\n    }\n    return undefined;\n  }\n\n  private getCurrentTrackingValue(): number | undefined {\n    if (this.currentTrackingPointer === PointerType.Min) {\n      return this.viewLowValue;\n    } else if (this.currentTrackingPointer === PointerType.Max) {\n      return this.viewHighValue;\n    }\n    return undefined;\n  }\n\n  private modelValueToViewValue(modelValue: number): number {\n    if (ValueHelper.isNullOrUndefined(modelValue)) {\n      return NaN;\n    }\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray) && !this.viewOptions.bindIndexForStepsArray) {\n      return ValueHelper.findStepIndex(+modelValue, this.viewOptions.stepsArray!);\n    }\n    return +modelValue;\n  }\n\n  private viewValueToModelValue(viewValue: number): number {\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray) && !this.viewOptions.bindIndexForStepsArray) {\n      return this.getStepValue(viewValue);\n    }\n    return viewValue;\n  }\n\n  private getStepValue(sliderValue: number): number {\n    const step: CustomStepDefinition = this.viewOptions.stepsArray![sliderValue];\n    return !ValueHelper.isNullOrUndefined(step) ? step.value : NaN;\n  }\n\n  private applyViewChange(): void {\n    this.value = this.viewValueToModelValue(this.viewLowValue!);\n    if (this.range) {\n      this.highValue = this.viewValueToModelValue(this.viewHighValue!);\n    }\n\n    this.outputModelChangeSubject.next({\n      value: this.value,\n      highValue: this.highValue,\n      userEventInitiated: true,\n      forceChange: false\n    });\n\n    // At this point all changes are applied and outputs are emitted, so we should be done.\n    // However, input changes are communicated in different stream and we need to be ready to\n    // act on the next input change even if it is exactly the same as last input change.\n    // Therefore, we send a special event to reset the stream.\n    this.inputModelChangeSubject.next({\n      value: this.value,\n      highValue: this.highValue,\n      forceChange: false,\n      internalChange: true\n    });\n  }\n\n  // Apply model change to the slider view\n  private applyInputModelChange(modelChange: InputModelChange): void {\n    const normalisedModelChange: ModelValues = this.normaliseModelValues(modelChange);\n\n    // If normalised model change is different, apply the change to the model values\n    const normalisationChange: boolean = !ModelValues.compare(modelChange, normalisedModelChange);\n    if (normalisationChange) {\n      this.value = normalisedModelChange.value;\n      this.highValue = normalisedModelChange.highValue;\n    }\n\n    this.viewLowValue = this.modelValueToViewValue(normalisedModelChange.value!);\n    if (this.range) {\n      this.viewHighValue = this.modelValueToViewValue(normalisedModelChange.highValue!);\n    } else {\n      this.viewHighValue = undefined;\n    }\n\n    this.updateLowHandle(this.valueToPosition(this.viewLowValue));\n    if (this.range) {\n      this.updateHighHandle(this.valueToPosition(this.viewHighValue!));\n    }\n    this.updateSelectionBar();\n    this.updateTicksScale();\n    this.updateAriaAttributes();\n    if (this.range) {\n      this.updateCombinedLabel();\n    }\n\n    // At the end, we need to communicate the model change to the outputs as well\n    // Normalisation changes are also always forced out to ensure that subscribers always end up in correct state\n    this.outputModelChangeSubject.next({\n      value: normalisedModelChange.value,\n      highValue: normalisedModelChange.highValue,\n      forceChange: normalisationChange,\n      userEventInitiated: false\n    });\n  }\n\n  // Publish model change to output event emitters and registered callbacks\n  private publishOutputModelChange(modelChange: OutputModelChange): void {\n    const emitOutputs: () => void = (): void => {\n      this.valueChange.emit(modelChange.value);\n      if (this.range) {\n        this.highValueChange.emit(modelChange.highValue);\n      }\n\n      if (!ValueHelper.isNullOrUndefined(this.onChangeCallback)) {\n        if (this.range) {\n          this.onChangeCallback!([modelChange.value, modelChange.highValue]);\n        } else {\n          this.onChangeCallback!(modelChange.value);\n        }\n      }\n      if (!ValueHelper.isNullOrUndefined(this.onTouchedCallback)) {\n        if (this.range) {\n          this.onTouchedCallback!([modelChange.value, modelChange.highValue]);\n        } else {\n          this.onTouchedCallback!(modelChange.value);\n        }\n      }\n    };\n\n    if (modelChange.userEventInitiated) {\n      // If this change was initiated by a user event, we can emit outputs in the same tick\n      emitOutputs();\n      this.userChange.emit(this.getChangeContext());\n    } else {\n      // But, if the change was initated by something else like a change in input bindings,\n      // we need to wait until next tick to emit the outputs to keep Angular change detection happy\n      setTimeout(() => {\n        emitOutputs();\n      });\n    }\n  }\n\n  private normaliseModelValues(input: ModelValues): ModelValues {\n    const normalisedInput: ModelValues = new ModelValues();\n    normalisedInput.value = input.value;\n    normalisedInput.highValue = input.highValue;\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray)) {\n      // When using steps array, only round to nearest step in the array\n      // No other enforcement can be done, as the step array may be out of order, and that is perfectly fine\n      if (this.viewOptions.enforceStepsArray) {\n        const valueIndex: number = ValueHelper.findStepIndex(normalisedInput.value!, this.viewOptions.stepsArray!);\n        normalisedInput.value = this.viewOptions.stepsArray![valueIndex].value;\n\n        if (this.range) {\n          const highValueIndex: number = ValueHelper.findStepIndex(\n            normalisedInput.highValue!,\n            this.viewOptions.stepsArray!\n          );\n          normalisedInput.highValue = this.viewOptions.stepsArray![highValueIndex].value;\n        }\n      }\n\n      return normalisedInput;\n    }\n\n    if (this.viewOptions.enforceStep) {\n      normalisedInput.value = this.roundStep(normalisedInput.value!);\n      if (this.range) {\n        normalisedInput.highValue = this.roundStep(normalisedInput.highValue!);\n      }\n    }\n\n    if (this.viewOptions.enforceRange) {\n      normalisedInput.value = MathHelper.clampToRange(\n        normalisedInput.value!,\n        this.viewOptions.floor!,\n        this.viewOptions.ceil!\n      );\n\n      if (this.range) {\n        normalisedInput.highValue = MathHelper.clampToRange(\n          normalisedInput.highValue!,\n          this.viewOptions.floor!,\n          this.viewOptions.ceil!\n        );\n      }\n\n      // Make sure that range slider invariant (value <= highValue) is always satisfied\n      if (this.range && input.value! > input.highValue!) {\n        // We know that both values are now clamped correctly, they may just be in the wrong order\n        // So the easy solution is to swap them... except swapping is sometimes disabled in options, so we make the two values the same\n        if (this.viewOptions.noSwitching) {\n          normalisedInput.value = normalisedInput.highValue;\n        } else {\n          const tempValue = input.value;\n          normalisedInput.value = input.highValue;\n          normalisedInput.highValue = tempValue;\n        }\n      }\n    }\n\n    return normalisedInput;\n  }\n\n  private renormaliseModelValues(): void {\n    const previousModelValues: ModelValues = {\n      value: this.value,\n      highValue: this.highValue\n    };\n    const normalisedModelValues: ModelValues = this.normaliseModelValues(previousModelValues);\n    if (!ModelValues.compare(normalisedModelValues, previousModelValues)) {\n      this.value = normalisedModelValues.value;\n      this.highValue = normalisedModelValues.highValue;\n\n      this.outputModelChangeSubject.next({\n        value: this.value,\n        highValue: this.highValue,\n        forceChange: true,\n        userEventInitiated: false\n      });\n    }\n  }\n\n  private onChangeOptions(): void {\n    if (!this.initHasRun) {\n      return;\n    }\n\n    const previousOptionsInfluencingEventBindings: boolean[] = this.getOptionsInfluencingEventBindings(\n      this.viewOptions\n    );\n\n    this.applyOptions();\n\n    const newOptionsInfluencingEventBindings: boolean[] = this.getOptionsInfluencingEventBindings(this.viewOptions);\n    // Avoid re-binding events in case nothing changes that can influence it\n    // It makes it possible to change options while dragging the slider\n    const rebindEvents: boolean = !ValueHelper.areArraysEqual(\n      previousOptionsInfluencingEventBindings,\n      newOptionsInfluencingEventBindings\n    );\n\n    // With new options, we need to re-normalise model values if necessary\n    this.renormaliseModelValues();\n\n    this.viewLowValue = this.modelValueToViewValue(this.value!);\n    if (this.range) {\n      this.viewHighValue = this.modelValueToViewValue(this.highValue!);\n    } else {\n      this.viewHighValue = undefined;\n    }\n\n    this.resetSlider(rebindEvents);\n  }\n\n  // Read the user options and apply them to the slider model\n  private applyOptions(): void {\n    this.viewOptions = new Options();\n    Object.assign(this.viewOptions, this.options);\n\n    this.viewOptions.draggableRange = this.range && this.viewOptions.draggableRange;\n    this.viewOptions.draggableRangeOnly = this.range && this.viewOptions.draggableRangeOnly;\n    if (this.viewOptions.draggableRangeOnly) {\n      this.viewOptions.draggableRange = true;\n    }\n\n    this.viewOptions.showTicks =\n      this.viewOptions.showTicks ||\n      this.viewOptions.showTicksValues ||\n      !ValueHelper.isNullOrUndefined(this.viewOptions.ticksArray);\n    if (\n      this.viewOptions.showTicks &&\n      (!ValueHelper.isNullOrUndefined(this.viewOptions.tickStep) ||\n        !ValueHelper.isNullOrUndefined(this.viewOptions.ticksArray))\n    ) {\n      this.intermediateTicks = true;\n    }\n\n    this.viewOptions.showSelectionBar =\n      this.viewOptions.showSelectionBar ||\n      this.viewOptions.showSelectionBarEnd ||\n      !ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue);\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray)) {\n      this.applyStepsArrayOptions();\n    } else {\n      this.applyFloorCeilOptions();\n    }\n\n    if (ValueHelper.isNullOrUndefined(this.viewOptions.combineLabels)) {\n      this.viewOptions.combineLabels = (minValue: string, maxValue: string): string => {\n        return minValue + ' - ' + maxValue;\n      };\n    }\n\n    if (this.viewOptions.logScale && this.viewOptions.floor === 0) {\n      throw Error(\"Can't use floor=0 with logarithmic scale\");\n    }\n  }\n\n  private applyStepsArrayOptions(): void {\n    this.viewOptions.floor = 0;\n    this.viewOptions.ceil = this.viewOptions.stepsArray!.length - 1;\n    this.viewOptions.step = 1;\n\n    if (ValueHelper.isNullOrUndefined(this.viewOptions.translate)) {\n      this.viewOptions.translate = (modelValue: number): string => {\n        if (this.viewOptions.bindIndexForStepsArray) {\n          return String(this.getStepValue(modelValue));\n        }\n        return String(modelValue);\n      };\n    }\n  }\n\n  private applyFloorCeilOptions(): void {\n    if (ValueHelper.isNullOrUndefined(this.viewOptions.step)) {\n      this.viewOptions.step = 1;\n    } else {\n      this.viewOptions.step = +this.viewOptions.step!;\n      if (this.viewOptions.step <= 0) {\n        this.viewOptions.step = 1;\n      }\n    }\n\n    if (ValueHelper.isNullOrUndefined(this.viewOptions.ceil) || ValueHelper.isNullOrUndefined(this.viewOptions.floor)) {\n      throw Error('floor and ceil options must be supplied');\n    }\n    this.viewOptions.ceil = +this.viewOptions.ceil!;\n    this.viewOptions.floor = +this.viewOptions.floor!;\n\n    if (ValueHelper.isNullOrUndefined(this.viewOptions.translate)) {\n      this.viewOptions.translate = (value: number): string => String(value);\n    }\n  }\n\n  // Resets slider\n  private resetSlider(rebindEvents: boolean = true): void {\n    this.manageElementsStyle();\n    this.addAccessibility();\n    this.updateCeilLabel();\n    this.updateFloorLabel();\n    if (rebindEvents) {\n      this.unbindEvents();\n      this.manageEventsBindings();\n    }\n    this.updateDisabledState();\n    this.updateAriaLabel();\n    this.calculateViewDimensions();\n    this.refocusPointerIfNeeded();\n  }\n\n  // Sets focus on the specified pointer\n  private focusPointer(pointerType: PointerType): void {\n    // If not supplied, use min pointer as default\n    if (pointerType !== PointerType.Min && pointerType !== PointerType.Max) {\n      pointerType = PointerType.Min;\n    }\n\n    if (pointerType === PointerType.Min) {\n      this.minHandleElement?.focus();\n    } else if (this.range && pointerType === PointerType.Max) {\n      this.maxHandleElement?.focus();\n    }\n  }\n\n  private refocusPointerIfNeeded(): void {\n    if (!ValueHelper.isNullOrUndefined(this.currentFocusPointer)) {\n      this.onPointerFocus(this.currentFocusPointer!);\n      const element = this.getPointerElement(this.currentFocusPointer!);\n      element?.focus();\n    }\n  }\n\n  // Update each elements style based on options\n  private manageElementsStyle(): void {\n    this.updateScale();\n    this.floorLabelElement?.setAlwaysHide(this.viewOptions.showTicksValues! || this.viewOptions.hideLimitLabels!);\n    this.ceilLabelElement?.setAlwaysHide(this.viewOptions.showTicksValues! || this.viewOptions.hideLimitLabels!);\n\n    const hideLabelsForTicks: boolean = this.viewOptions.showTicksValues! && !this.intermediateTicks!;\n    this.minHandleLabelElement?.setAlwaysHide(hideLabelsForTicks || this.viewOptions.hidePointerLabels!);\n    this.maxHandleLabelElement?.setAlwaysHide(hideLabelsForTicks || !this.range || this.viewOptions.hidePointerLabels!);\n    this.combinedLabelElement?.setAlwaysHide(hideLabelsForTicks || !this.range || this.viewOptions.hidePointerLabels!);\n    this.selectionBarElement?.setAlwaysHide(!this.range && !this.viewOptions.showSelectionBar);\n    this.leftOuterSelectionBarElement?.setAlwaysHide(!this.range || !this.viewOptions.showOuterSelectionBars);\n    this.rightOuterSelectionBarElement?.setAlwaysHide(!this.range || !this.viewOptions.showOuterSelectionBars);\n\n    this.fullBarTransparentClass = this.range && this.viewOptions.showOuterSelectionBars!;\n    this.selectionBarDraggableClass = this.viewOptions.draggableRange! && !this.viewOptions.onlyBindHandles!;\n    this.ticksUnderValuesClass = this.intermediateTicks && this.options.showTicksValues!;\n\n    if (this.sliderElementVerticalClass !== this.viewOptions.vertical) {\n      this.updateVerticalState();\n      // The above change in host component class will not be applied until the end of this cycle\n      // However, functions calculating the slider position expect the slider to be already styled as vertical\n      // So as a workaround, we need to reset the slider once again to compute the correct values\n      setTimeout((): void => {\n        this.resetSlider();\n      });\n    }\n\n    // Changing animate class may interfere with slider reset/initialisation, so we should set it separately,\n    // after all is properly set up\n    if (this.sliderElementAnimateClass !== this.viewOptions.animate) {\n      setTimeout((): void => {\n        this.sliderElementAnimateClass = this.viewOptions.animate!;\n      });\n    }\n    this.updateRotate();\n  }\n\n  // Manage the events bindings based on readOnly and disabled options\n  private manageEventsBindings(): void {\n    if (this.viewOptions.disabled || this.viewOptions.readOnly) {\n      this.unbindEvents();\n    } else {\n      this.bindEvents();\n    }\n  }\n\n  // Set the disabled state based on disabled option\n  private updateDisabledState(): void {\n    this.sliderElementDisabledAttr = this.viewOptions.disabled ? 'disabled' : undefined;\n  }\n\n  // Set the aria-label state based on ariaLabel option\n  private updateAriaLabel(): void {\n    this.sliderElementAriaLabel = this.viewOptions.ariaLabel || 'nxg-slider';\n  }\n\n  // Set vertical state based on vertical option\n  private updateVerticalState(): void {\n    this.sliderElementVerticalClass = this.viewOptions.vertical!;\n    for (const element of this.getAllSliderElements()) {\n      // This is also called before ngAfterInit, so need to check that view child bindings work\n      if (!ValueHelper.isNullOrUndefined(element)) {\n        element.setVertical(this.viewOptions.vertical!);\n      }\n    }\n  }\n\n  private updateScale(): void {\n    for (const element of this.getAllSliderElements()) {\n      element.setScale(this.viewOptions.scale!);\n    }\n  }\n\n  private updateRotate(): void {\n    for (const element of this.getAllSliderElements()) {\n      element.setRotate(this.viewOptions.rotate!);\n    }\n  }\n\n  private getAllSliderElements(): SliderElementDirective[] {\n    return [\n      this.leftOuterSelectionBarElement!,\n      this.rightOuterSelectionBarElement!,\n      this.fullBarElement!,\n      this.selectionBarElement!,\n      this.minHandleElement!,\n      this.maxHandleElement!,\n      this.floorLabelElement!,\n      this.ceilLabelElement!,\n      this.minHandleLabelElement!,\n      this.maxHandleLabelElement!,\n      this.combinedLabelElement!,\n      this.ticksElement!\n    ];\n  }\n\n  // Initialize slider handles positions and labels\n  // Run only once during initialization and every time view port changes size\n  private initHandles(): void {\n    this.updateLowHandle(this.valueToPosition(this.viewLowValue!));\n\n    /*\n   the order here is important since the selection bar should be\n   updated after the high handle but before the combined label\n   */\n    if (this.range) {\n      this.updateHighHandle(this.valueToPosition(this.viewHighValue!));\n    }\n\n    this.updateSelectionBar();\n\n    if (this.range) {\n      this.updateCombinedLabel();\n    }\n\n    this.updateTicksScale();\n  }\n\n  // Adds accessibility attributes, run only once during initialization\n  private addAccessibility(): void {\n    this.updateAriaAttributes();\n\n    this.minHandleElement!.role = 'slider';\n\n    if (this.viewOptions.keyboardSupport && !(this.viewOptions.readOnly || this.viewOptions.disabled)) {\n      this.minHandleElement!.tabindex = '0';\n    } else {\n      this.minHandleElement!.tabindex = '';\n    }\n\n    this.minHandleElement!.ariaOrientation =\n      this.viewOptions.vertical || this.viewOptions.rotate !== 0 ? 'vertical' : 'horizontal';\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabel)) {\n      this.minHandleElement!.ariaLabel = this.viewOptions.ariaLabel!;\n    } else if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabelledBy)) {\n      this.minHandleElement!.ariaLabelledBy = this.viewOptions.ariaLabelledBy!;\n    }\n\n    if (this.range) {\n      this.maxHandleElement!.role = 'slider';\n\n      if (this.viewOptions.keyboardSupport && !(this.viewOptions.readOnly || this.viewOptions.disabled)) {\n        this.maxHandleElement!.tabindex = '0';\n      } else {\n        this.maxHandleElement!.tabindex = '';\n      }\n\n      this.maxHandleElement!.ariaOrientation =\n        this.viewOptions.vertical || this.viewOptions.rotate !== 0 ? 'vertical' : 'horizontal';\n\n      if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabelHigh)) {\n        this.maxHandleElement!.ariaLabel = this.viewOptions.ariaLabelHigh!;\n      } else if (!ValueHelper.isNullOrUndefined(this.viewOptions.ariaLabelledByHigh)) {\n        this.maxHandleElement!.ariaLabelledBy = this.viewOptions.ariaLabelledByHigh!;\n      }\n    }\n  }\n\n  // Updates aria attributes according to current values\n  private updateAriaAttributes(): void {\n    this.minHandleElement!.ariaValueNow = (+this.value!).toString();\n    this.minHandleElement!.ariaValueText = this.viewOptions.translate!(+this.value!, LabelType.Low);\n    this.minHandleElement!.ariaValueMin = this.viewOptions.floor!.toString();\n    this.minHandleElement!.ariaValueMax = this.viewOptions.ceil!.toString();\n\n    if (this.range) {\n      this.maxHandleElement!.ariaValueNow = (+this.highValue!).toString();\n      this.maxHandleElement!.ariaValueText = this.viewOptions.translate!(+this.highValue!, LabelType.High);\n      this.maxHandleElement!.ariaValueMin = this.viewOptions.floor!.toString();\n      this.maxHandleElement!.ariaValueMax = this.viewOptions.ceil!.toString();\n    }\n  }\n\n  // Calculate dimensions that are dependent on view port size\n  // Run once during initialization and every time view port changes size.\n  private calculateViewDimensions(): void {\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.handleDimension)) {\n      this.minHandleElement!.setDimension(this.viewOptions.handleDimension!);\n    } else {\n      this.minHandleElement!.calculateDimension();\n    }\n\n    const handleWidth = this.minHandleElement!.dimension;\n\n    this.handleHalfDimension = handleWidth / 2;\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.barDimension)) {\n      this.fullBarElement!.setDimension(this.viewOptions.barDimension!);\n    } else {\n      this.fullBarElement!.calculateDimension();\n    }\n\n    this.maxHandlePosition = this.fullBarElement!.dimension - handleWidth;\n\n    if (this.initHasRun) {\n      this.updateFloorLabel();\n      this.updateCeilLabel();\n      this.initHandles();\n    }\n  }\n\n  private calculateViewDimensionsAndDetectChanges(): void {\n    this.calculateViewDimensions();\n    if (!this.isRefDestroyed()) {\n      this.changeDetectionRef.detectChanges();\n    }\n  }\n\n  /**\n   * If the slider reference is already destroyed\n   * @returns boolean - true if ref is destroyed\n   */\n  private isRefDestroyed(): boolean {\n    return (this.changeDetectionRef as any)['destroyed'];\n  }\n\n  // Update the ticks position\n  private updateTicksScale(): void {\n    if (!this.viewOptions.showTicks) {\n      setTimeout(() => {\n        this.sliderElementWithLegendClass = false;\n      });\n      return;\n    }\n\n    const ticksArray = !ValueHelper.isNullOrUndefined(this.viewOptions.ticksArray)\n      ? this.viewOptions.ticksArray\n      : this.getTicksArray();\n    const translate: string = this.viewOptions.vertical ? 'translateY' : 'translateX';\n\n    if (this.viewOptions.rightToLeft) {\n      ticksArray!.reverse();\n    }\n\n    const tickValueStep = !ValueHelper.isNullOrUndefined(this.viewOptions.tickValueStep)\n      ? this.viewOptions.tickValueStep\n      : !ValueHelper.isNullOrUndefined(this.viewOptions.tickStep)\n        ? this.viewOptions.tickStep\n        : this.viewOptions.step;\n\n    let hasAtLeastOneLegend: boolean = false;\n\n    const newTicks: Tick[] = ticksArray!.map((value: number): Tick => {\n      let position: number = this.valueToPosition(value);\n\n      if (this.viewOptions.vertical) {\n        position = this.maxHandlePosition - position;\n      }\n\n      const translation: string = translate + '(' + Math.round(position) + 'px)';\n      const tick: Tick = new Tick();\n      tick.selected = this.isTickSelected(value);\n      tick.style = {\n        '-webkit-transform': translation,\n        '-moz-transform': translation,\n        '-o-transform': translation,\n        '-ms-transform': translation,\n        transform: translation\n      };\n      if (tick.selected && !ValueHelper.isNullOrUndefined(this.viewOptions.getSelectionBarColor)) {\n        tick.style['background-color'] = this.getSelectionBarColor();\n      }\n      if (!tick.selected && !ValueHelper.isNullOrUndefined(this.viewOptions.getTickColor)) {\n        tick.style['background-color'] = this.getTickColor(value);\n      }\n      if (!ValueHelper.isNullOrUndefined(this.viewOptions.ticksTooltip)) {\n        tick.tooltip = this.viewOptions.ticksTooltip!(value);\n        tick.tooltipPlacement = this.viewOptions.vertical ? 'right' : 'top';\n      }\n      if (\n        this.viewOptions.showTicksValues &&\n        !ValueHelper.isNullOrUndefined(tickValueStep) &&\n        MathHelper.isModuloWithinPrecisionLimit(value, tickValueStep!, this.viewOptions.precisionLimit!)\n      ) {\n        tick.value = this.getDisplayValue(value, LabelType.TickValue);\n        if (!ValueHelper.isNullOrUndefined(this.viewOptions.ticksValuesTooltip)) {\n          tick.valueTooltip = this.viewOptions.ticksValuesTooltip!(value);\n          tick.valueTooltipPlacement = this.viewOptions.vertical ? 'right' : 'top';\n        }\n      }\n\n      let legend: string;\n      if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray)) {\n        const step: CustomStepDefinition = this.viewOptions.stepsArray![value];\n        if (!ValueHelper.isNullOrUndefined(this.viewOptions.getStepLegend)) {\n          legend = this.viewOptions.getStepLegend!(step);\n        } else if (!ValueHelper.isNullOrUndefined(step)) {\n          legend = step.legend!;\n        }\n      } else if (!ValueHelper.isNullOrUndefined(this.viewOptions.getLegend)) {\n        legend = this.viewOptions.getLegend!(value);\n      }\n      if (!ValueHelper.isNullOrUndefined(legend!)) {\n        tick.legend = legend!;\n        hasAtLeastOneLegend = true;\n      }\n\n      return tick;\n    });\n\n    setTimeout(() => {\n      this.sliderElementWithLegendClass = hasAtLeastOneLegend;\n    });\n\n    // We should avoid re-creating the ticks array if possible\n    // This both improves performance and makes CSS animations work correctly\n    if (!ValueHelper.isNullOrUndefined(this.ticks) && this.ticks.length === newTicks.length) {\n      for (let i: number = 0; i < newTicks.length; ++i) {\n        Object.assign(this.ticks[i], newTicks[i]);\n      }\n    } else {\n      this.ticks = newTicks;\n    }\n\n    if (!this.isRefDestroyed()) {\n      this.changeDetectionRef.detectChanges();\n    }\n  }\n\n  private getTicksArray(): number[] {\n    const step = !ValueHelper.isNullOrUndefined(this.viewOptions.tickStep)\n      ? this.viewOptions.tickStep\n      : this.viewOptions.step;\n    const ticksArray: number[] = [];\n\n    const numberOfValues: number =\n      1 +\n      Math.floor(\n        MathHelper.roundToPrecisionLimit(\n          Math.abs(this.viewOptions.ceil! - this.viewOptions.floor!) / step!,\n          this.viewOptions.precisionLimit!\n        )\n      );\n    for (let index: number = 0; index < numberOfValues; ++index) {\n      ticksArray.push(\n        MathHelper.roundToPrecisionLimit(this.viewOptions.floor! + step! * index, this.viewOptions.precisionLimit!)\n      );\n    }\n\n    return ticksArray;\n  }\n\n  private isTickSelected(value: number): boolean {\n    if (!this.range) {\n      if (!ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue)) {\n        const center = this.viewOptions.showSelectionBarFromValue;\n        if (this.viewLowValue! > center! && value >= center! && value <= this.viewLowValue!) {\n          return true;\n        } else if (this.viewLowValue! < center! && value <= center! && value >= this.viewLowValue!) {\n          return true;\n        }\n      } else if (this.viewOptions.showSelectionBarEnd) {\n        if (value >= this.viewLowValue!) {\n          return true;\n        }\n      } else if (this.viewOptions.showSelectionBar && value <= this.viewLowValue!) {\n        return true;\n      }\n    }\n\n    if (this.range && value >= this.viewLowValue! && value <= this.viewHighValue!) {\n      return true;\n    }\n\n    return false;\n  }\n\n  // Update position of the floor label\n  private updateFloorLabel(): void {\n    if (!this.floorLabelElement!.alwaysHide) {\n      this.floorLabelElement!.setValue(this.getDisplayValue(this.viewOptions.floor!, LabelType.Floor));\n      this.floorLabelElement!.calculateDimension();\n      const position: number = this.viewOptions.rightToLeft\n        ? this.fullBarElement!.dimension - this.floorLabelElement!.dimension\n        : 0;\n      this.floorLabelElement!.setPosition(position);\n    }\n  }\n\n  // Update position of the ceiling label\n  private updateCeilLabel(): void {\n    if (!this.ceilLabelElement!.alwaysHide) {\n      this.ceilLabelElement!.setValue(this.getDisplayValue(this.viewOptions.ceil!, LabelType.Ceil));\n      this.ceilLabelElement!.calculateDimension();\n      const position: number = this.viewOptions.rightToLeft\n        ? 0\n        : this.fullBarElement!.dimension - this.ceilLabelElement!.dimension;\n      this.ceilLabelElement!.setPosition(position);\n    }\n  }\n\n  // Update slider handles and label positions\n  private updateHandles(which: PointerType, newPos: number): void {\n    if (which === PointerType.Min) {\n      this.updateLowHandle(newPos);\n    } else if (which === PointerType.Max) {\n      this.updateHighHandle(newPos);\n    }\n\n    this.updateSelectionBar();\n    this.updateTicksScale();\n    if (this.range) {\n      this.updateCombinedLabel();\n    }\n  }\n\n  // Helper function to work out the position for handle labels depending on RTL or not\n  private getHandleLabelPos(labelType: PointerType, newPos: number): number {\n    const labelDimension: number =\n      labelType === PointerType.Min ? this.minHandleLabelElement!.dimension : this.maxHandleLabelElement!.dimension;\n    const nearHandlePos: number = newPos - labelDimension / 2 + this.handleHalfDimension;\n    const endOfBarPos: number = this.fullBarElement!.dimension - labelDimension;\n\n    if (!this.viewOptions.boundPointerLabels) {\n      return nearHandlePos;\n    }\n\n    if (\n      (this.viewOptions.rightToLeft && labelType === PointerType.Min) ||\n      (!this.viewOptions.rightToLeft && labelType === PointerType.Max)\n    ) {\n      return Math.min(nearHandlePos, endOfBarPos);\n    } else {\n      return Math.min(Math.max(nearHandlePos, 0), endOfBarPos);\n    }\n  }\n\n  // Update low slider handle position and label\n  private updateLowHandle(newPos: number): void {\n    this.minHandleElement!.setPosition(newPos);\n    this.minHandleLabelElement!.setValue(this.getDisplayValue(this.viewLowValue!, LabelType.Low));\n    this.minHandleLabelElement!.setPosition(this.getHandleLabelPos(PointerType.Min, newPos));\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.getPointerColor)) {\n      this.minPointerStyle = {\n        backgroundColor: this.getPointerColor(PointerType.Min)\n      };\n    }\n\n    if (this.viewOptions.autoHideLimitLabels) {\n      this.updateFloorAndCeilLabelsVisibility();\n    }\n  }\n\n  // Update high slider handle position and label\n  private updateHighHandle(newPos: number): void {\n    this.maxHandleElement!.setPosition(newPos);\n    this.maxHandleLabelElement!.setValue(this.getDisplayValue(this.viewHighValue!, LabelType.High));\n    this.maxHandleLabelElement!.setPosition(this.getHandleLabelPos(PointerType.Max, newPos));\n\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.getPointerColor)) {\n      this.maxPointerStyle = {\n        backgroundColor: this.getPointerColor(PointerType.Max)\n      };\n    }\n    if (this.viewOptions.autoHideLimitLabels) {\n      this.updateFloorAndCeilLabelsVisibility();\n    }\n  }\n\n  // Show/hide floor/ceiling label\n  private updateFloorAndCeilLabelsVisibility(): void {\n    // Show based only on hideLimitLabels if pointer labels are hidden\n    if (this.viewOptions.hidePointerLabels) {\n      return;\n    }\n    let floorLabelHidden: boolean = false;\n    let ceilLabelHidden: boolean = false;\n    const isMinLabelAtFloor: boolean = this.isLabelBelowFloorLabel(this.minHandleLabelElement!);\n    const isMinLabelAtCeil: boolean = this.isLabelAboveCeilLabel(this.minHandleLabelElement!);\n    const isMaxLabelAtCeil: boolean = this.isLabelAboveCeilLabel(this.maxHandleLabelElement!);\n    const isCombinedLabelAtFloor: boolean = this.isLabelBelowFloorLabel(this.combinedLabelElement!);\n    const isCombinedLabelAtCeil: boolean = this.isLabelAboveCeilLabel(this.combinedLabelElement!);\n\n    if (isMinLabelAtFloor) {\n      floorLabelHidden = true;\n      this.floorLabelElement!.hide();\n    } else {\n      floorLabelHidden = false;\n      this.floorLabelElement!.show();\n    }\n\n    if (isMinLabelAtCeil) {\n      ceilLabelHidden = true;\n      this.ceilLabelElement!.hide();\n    } else {\n      ceilLabelHidden = false;\n      this.ceilLabelElement!.show();\n    }\n\n    if (this.range) {\n      const hideCeil: boolean = this.combinedLabelElement!.isVisible() ? isCombinedLabelAtCeil : isMaxLabelAtCeil;\n      const hideFloor: boolean = this.combinedLabelElement!.isVisible() ? isCombinedLabelAtFloor : isMinLabelAtFloor;\n\n      if (hideCeil) {\n        this.ceilLabelElement!.hide();\n      } else if (!ceilLabelHidden) {\n        this.ceilLabelElement!.show();\n      }\n\n      // Hide or show floor label\n      if (hideFloor) {\n        this.floorLabelElement!.hide();\n      } else if (!floorLabelHidden) {\n        this.floorLabelElement!.show();\n      }\n    }\n  }\n\n  private isLabelBelowFloorLabel(label: SliderLabelDirective): boolean {\n    const pos: number = label.position;\n    const dim: number = label.dimension;\n    const floorPos: number = this.floorLabelElement!.position;\n    const floorDim: number = this.floorLabelElement!.dimension;\n    return this.viewOptions.rightToLeft ? pos + dim >= floorPos - 2 : pos <= floorPos + floorDim + 2;\n  }\n\n  private isLabelAboveCeilLabel(label: SliderLabelDirective): boolean {\n    const pos: number = label.position;\n    const dim: number = label.dimension;\n    const ceilPos: number = this.ceilLabelElement!.position;\n    const ceilDim: number = this.ceilLabelElement!.dimension;\n    return this.viewOptions.rightToLeft ? pos <= ceilPos + ceilDim + 2 : pos + dim >= ceilPos - 2;\n  }\n\n  // Update slider selection bar, combined label and range label\n  private updateSelectionBar(): void {\n    let position: number = 0;\n    let dimension: number = 0;\n    const isSelectionBarFromRight: boolean = this.viewOptions.rightToLeft\n      ? !this.viewOptions.showSelectionBarEnd!\n      : this.viewOptions.showSelectionBarEnd!;\n    const positionForRange: number = this.viewOptions.rightToLeft\n      ? this.maxHandleElement!.position + this.handleHalfDimension\n      : this.minHandleElement!.position + this.handleHalfDimension;\n\n    if (this.range) {\n      dimension = Math.abs(this.maxHandleElement!.position - this.minHandleElement!.position);\n      position = positionForRange;\n    } else {\n      if (!ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue)) {\n        const center = this.viewOptions.showSelectionBarFromValue;\n        const centerPosition: number = this.valueToPosition(center!);\n        const isModelGreaterThanCenter: boolean = this.viewOptions.rightToLeft\n          ? this.viewLowValue! <= center!\n          : this.viewLowValue! > center!;\n        if (isModelGreaterThanCenter) {\n          dimension = this.minHandleElement!.position - centerPosition;\n          position = centerPosition + this.handleHalfDimension;\n        } else {\n          dimension = centerPosition - this.minHandleElement!.position;\n          position = this.minHandleElement!.position + this.handleHalfDimension;\n        }\n      } else if (isSelectionBarFromRight) {\n        dimension = Math.ceil(\n          Math.abs(this.maxHandlePosition - this.minHandleElement!.position) + this.handleHalfDimension\n        );\n        position = Math.floor(this.minHandleElement!.position + this.handleHalfDimension);\n      } else {\n        dimension = this.minHandleElement!.position + this.handleHalfDimension;\n        position = 0;\n      }\n    }\n    this.selectionBarElement!.setDimension(dimension);\n    this.selectionBarElement!.setPosition(position);\n    if (this.range && this.viewOptions.showOuterSelectionBars) {\n      if (this.viewOptions.rightToLeft) {\n        this.rightOuterSelectionBarElement!.setDimension(position);\n        this.rightOuterSelectionBarElement!.setPosition(0);\n        this.fullBarElement!.calculateDimension();\n        this.leftOuterSelectionBarElement!.setDimension(this.fullBarElement!.dimension - (position + dimension));\n        this.leftOuterSelectionBarElement!.setPosition(position + dimension);\n      } else {\n        this.leftOuterSelectionBarElement!.setDimension(position);\n        this.leftOuterSelectionBarElement!.setPosition(0);\n        this.fullBarElement!.calculateDimension();\n        this.rightOuterSelectionBarElement!.setDimension(this.fullBarElement!.dimension - (position + dimension));\n        this.rightOuterSelectionBarElement!.setPosition(position + dimension);\n      }\n    }\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.getSelectionBarColor)) {\n      const color: string = this.getSelectionBarColor();\n      this.barStyle = {\n        backgroundColor: color\n      };\n    } else if (!ValueHelper.isNullOrUndefined(this.viewOptions.selectionBarGradient)) {\n      const offset: number = !ValueHelper.isNullOrUndefined(this.viewOptions.showSelectionBarFromValue)\n        ? this.valueToPosition(this.viewOptions.showSelectionBarFromValue!)\n        : 0;\n      const reversed: boolean =\n        (offset - position > 0 && !isSelectionBarFromRight) || (offset - position <= 0 && isSelectionBarFromRight);\n      const direction: string = this.viewOptions.vertical ? (reversed ? 'bottom' : 'top') : reversed ? 'left' : 'right';\n      this.barStyle = {\n        backgroundImage:\n          'linear-gradient(to ' +\n          direction +\n          ', ' +\n          this.viewOptions.selectionBarGradient!.from +\n          ' 0%,' +\n          this.viewOptions.selectionBarGradient!.to +\n          ' 100%)'\n      };\n      if (this.viewOptions.vertical) {\n        this.barStyle.backgroundPosition =\n          'center ' + (offset + dimension + position + (reversed ? -this.handleHalfDimension : 0)) + 'px';\n        this.barStyle.backgroundSize = '100% ' + (this.fullBarElement!.dimension - this.handleHalfDimension) + 'px';\n      } else {\n        this.barStyle.backgroundPosition = offset - position + (reversed ? this.handleHalfDimension : 0) + 'px center';\n        this.barStyle.backgroundSize = this.fullBarElement!.dimension - this.handleHalfDimension + 'px 100%';\n      }\n    }\n  }\n\n  // Wrapper around the getSelectionBarColor of the user to pass to correct parameters\n  private getSelectionBarColor(): string {\n    if (this.range) {\n      return this.viewOptions.getSelectionBarColor!(this.value!, this.highValue);\n    }\n    return this.viewOptions.getSelectionBarColor!(this.value!);\n  }\n\n  // Wrapper around the getPointerColor of the user to pass to  correct parameters\n  private getPointerColor(pointerType: PointerType): string {\n    if (pointerType === PointerType.Max) {\n      return this.viewOptions.getPointerColor!(this.highValue!, pointerType);\n    }\n    return this.viewOptions.getPointerColor!(this.value!, pointerType);\n  }\n\n  // Wrapper around the getTickColor of the user to pass to correct parameters\n  private getTickColor(value: number): string {\n    return this.viewOptions.getTickColor!(value);\n  }\n\n  // Update combined label position and value\n  private updateCombinedLabel(): void {\n    let isLabelOverlap = false;\n    if (this.viewOptions.rightToLeft) {\n      isLabelOverlap =\n        this.minHandleLabelElement!.position - this.minHandleLabelElement!.dimension - 10 <=\n        this.maxHandleLabelElement!.position;\n    } else {\n      isLabelOverlap =\n        this.minHandleLabelElement!.position + this.minHandleLabelElement!.dimension + 10 >=\n        this.maxHandleLabelElement!.position;\n    }\n\n    if (isLabelOverlap) {\n      const lowDisplayValue: string = this.getDisplayValue(this.viewLowValue!, LabelType.Low);\n      const highDisplayValue: string = this.getDisplayValue(this.viewHighValue!, LabelType.High);\n      const combinedLabelValue: string = this.viewOptions.rightToLeft\n        ? this.viewOptions.combineLabels!(highDisplayValue, lowDisplayValue)\n        : this.viewOptions.combineLabels!(lowDisplayValue, highDisplayValue);\n\n      this.combinedLabelElement!.setValue(combinedLabelValue);\n      const pos: number = this.viewOptions.boundPointerLabels\n        ? Math.min(\n            Math.max(\n              this.selectionBarElement!.position +\n                this.selectionBarElement!.dimension / 2 -\n                this.combinedLabelElement!.dimension / 2,\n              0\n            ),\n            this.fullBarElement!.dimension - this.combinedLabelElement!.dimension\n          )\n        : this.selectionBarElement!.position +\n          this.selectionBarElement!.dimension / 2 -\n          this.combinedLabelElement!.dimension / 2;\n\n      this.combinedLabelElement!.setPosition(pos);\n      this.minHandleLabelElement!.hide();\n      this.maxHandleLabelElement!.hide();\n      this.combinedLabelElement!.show();\n    } else {\n      this.updateHighHandle(this.valueToPosition(this.viewHighValue!));\n      this.updateLowHandle(this.valueToPosition(this.viewLowValue!));\n      this.maxHandleLabelElement!.show();\n      this.minHandleLabelElement!.show();\n      this.combinedLabelElement!.hide();\n    }\n    if (this.viewOptions.autoHideLimitLabels) {\n      this.updateFloorAndCeilLabelsVisibility();\n    }\n  }\n\n  // Return the translated value if a translate function is provided else the original value\n  private getDisplayValue(value: number, which: LabelType): string {\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.stepsArray) && !this.viewOptions.bindIndexForStepsArray) {\n      value = this.getStepValue(value);\n    }\n    return this.viewOptions.translate!(value, which);\n  }\n\n  // Round value to step and precision based on minValue\n  private roundStep(value: number, customStep?: number): number {\n    const step = !ValueHelper.isNullOrUndefined(customStep) ? customStep : this.viewOptions.step;\n    let steppedDifference: number = MathHelper.roundToPrecisionLimit(\n      (value - this.viewOptions.floor!) / step!,\n      this.viewOptions.precisionLimit!\n    );\n    steppedDifference = Math.round(steppedDifference) * step!;\n    return MathHelper.roundToPrecisionLimit(\n      this.viewOptions.floor! + steppedDifference,\n      this.viewOptions.precisionLimit!\n    );\n  }\n\n  // Translate value to pixel position\n  private valueToPosition(val: number): number {\n    let fn: ValueToPositionFunction = ValueHelper.linearValueToPosition;\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.customValueToPosition)) {\n      fn = this.viewOptions.customValueToPosition!;\n    } else if (this.viewOptions.logScale) {\n      fn = ValueHelper.logValueToPosition;\n    }\n\n    val = MathHelper.clampToRange(val, this.viewOptions.floor!, this.viewOptions.ceil!);\n    let percent: number = fn(val, this.viewOptions.floor!, this.viewOptions.ceil!);\n    if (ValueHelper.isNullOrUndefined(percent)) {\n      percent = 0;\n    }\n    if (this.viewOptions.rightToLeft) {\n      percent = 1 - percent;\n    }\n    return percent * this.maxHandlePosition;\n  }\n\n  // Translate position to model value\n  private positionToValue(position: number): number {\n    let percent: number = position / this.maxHandlePosition;\n    if (this.viewOptions.rightToLeft) {\n      percent = 1 - percent;\n    }\n    let fn: PositionToValueFunction = ValueHelper.linearPositionToValue;\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.customPositionToValue)) {\n      fn = this.viewOptions.customPositionToValue!;\n    } else if (this.viewOptions.logScale) {\n      fn = ValueHelper.logPositionToValue;\n    }\n    const value: number = fn(percent, this.viewOptions.floor!, this.viewOptions.ceil!);\n    return !ValueHelper.isNullOrUndefined(value) ? value : 0;\n  }\n\n  // Get the X-coordinate or Y-coordinate of an event\n  private getEventXY(event: MouseEvent | TouchEvent, targetTouchId?: number): number {\n    if (event instanceof MouseEvent) {\n      return this.viewOptions.vertical || this.viewOptions.rotate !== 0 ? event.clientY : event.clientX;\n    }\n\n    let touchIndex: number = 0;\n    const touches: TouchList = event.touches;\n    if (!ValueHelper.isNullOrUndefined(targetTouchId)) {\n      for (let i: number = 0; i < touches.length; i++) {\n        if (touches[i].identifier === targetTouchId) {\n          touchIndex = i;\n          break;\n        }\n      }\n    }\n\n    // Return the target touch or if the target touch was not found in the event\n    // returns the coordinates of the first touch\n    return this.viewOptions.vertical || this.viewOptions.rotate !== 0\n      ? touches[touchIndex].clientY\n      : touches[touchIndex].clientX;\n  }\n\n  // Compute the event position depending on whether the slider is horizontal or vertical\n  private getEventPosition(event: MouseEvent | TouchEvent, targetTouchId?: number): number {\n    const sliderElementBoundingRect: ClientRect = this.elementRef.nativeElement.getBoundingClientRect();\n\n    const sliderPos: number =\n      this.viewOptions.vertical || this.viewOptions.rotate !== 0\n        ? sliderElementBoundingRect.bottom\n        : sliderElementBoundingRect.left;\n    let eventPos: number = 0;\n\n    if (this.viewOptions.vertical || this.viewOptions.rotate !== 0) {\n      eventPos = -this.getEventXY(event, targetTouchId) + sliderPos;\n    } else {\n      eventPos = this.getEventXY(event, targetTouchId) - sliderPos;\n    }\n\n    return eventPos * this.viewOptions.scale! - this.handleHalfDimension;\n  }\n\n  // Get the handle closest to an event\n  private getNearestHandle(event: MouseEvent | TouchEvent): PointerType {\n    if (!this.range) {\n      return PointerType.Min;\n    }\n\n    const position: number = this.getEventPosition(event);\n    const distanceMin: number = Math.abs(position - this.minHandleElement!.position);\n    const distanceMax: number = Math.abs(position - this.maxHandleElement!.position);\n\n    if (distanceMin < distanceMax) {\n      return PointerType.Min;\n    } else if (distanceMin > distanceMax) {\n      return PointerType.Max;\n    } else if (!this.viewOptions.rightToLeft) {\n      // if event is at the same distance from min/max then if it's at left of minH, we return minH else maxH\n      return position < this.minHandleElement!.position ? PointerType.Min : PointerType.Max;\n    }\n    // reverse in rtl\n    return position > this.minHandleElement!.position ? PointerType.Min : PointerType.Max;\n  }\n\n  // Bind mouse and touch events to slider handles\n  private bindEvents(): void {\n    const draggableRange: boolean = this.viewOptions.draggableRange!;\n\n    if (!this.viewOptions.onlyBindHandles) {\n      this.selectionBarElement!.on('mousedown', (event: MouseEvent): void =>\n        this.onBarStart(draggableRange, event, true, true, undefined, true)\n      );\n    }\n\n    if (this.viewOptions.draggableRangeOnly) {\n      this.minHandleElement!.on('mousedown', (event: MouseEvent): void =>\n        this.onBarStart(draggableRange, event, true, true, PointerType.Min)\n      );\n      this.maxHandleElement!.on('mousedown', (event: MouseEvent): void =>\n        this.onBarStart(draggableRange, event, true, true, PointerType.Max)\n      );\n    } else {\n      this.minHandleElement!.on('mousedown', (event: MouseEvent): void =>\n        this.onStart(event, true, true, PointerType.Min)\n      );\n\n      if (this.range) {\n        this.maxHandleElement!.on('mousedown', (event: MouseEvent): void =>\n          this.onStart(event, true, true, PointerType.Max)\n        );\n      }\n      if (!this.viewOptions.onlyBindHandles) {\n        this.fullBarElement!.on('mousedown', (event: MouseEvent): void =>\n          this.onStart(event, true, true, undefined, true)\n        );\n        this.ticksElement!.on('mousedown', (event: MouseEvent): void =>\n          this.onStart(event, true, true, undefined, true, true)\n        );\n      }\n    }\n\n    if (!this.viewOptions.onlyBindHandles) {\n      this.selectionBarElement!.onPassive('touchstart', (event: TouchEvent): void =>\n        this.onBarStart(draggableRange, event, true, true, undefined, true)\n      );\n    }\n    if (this.viewOptions.draggableRangeOnly) {\n      this.minHandleElement!.onPassive('touchstart', (event: TouchEvent): void =>\n        this.onBarStart(draggableRange, event, true, true, PointerType.Min)\n      );\n      this.maxHandleElement!.onPassive('touchstart', (event: TouchEvent): void =>\n        this.onBarStart(draggableRange, event, true, true, PointerType.Max)\n      );\n    } else {\n      this.minHandleElement!.onPassive('touchstart', (event: TouchEvent): void =>\n        this.onStart(event, true, true, PointerType.Min)\n      );\n      if (this.range) {\n        this.maxHandleElement!.onPassive('touchstart', (event: TouchEvent): void =>\n          this.onStart(event, true, true, PointerType.Max)\n        );\n      }\n      if (!this.viewOptions.onlyBindHandles) {\n        this.fullBarElement!.onPassive('touchstart', (event: TouchEvent): void =>\n          this.onStart(event, true, true, undefined, true)\n        );\n        this.ticksElement!.onPassive('touchstart', (event: TouchEvent): void =>\n          this.onStart(event, false, false, undefined, true, true)\n        );\n      }\n    }\n\n    if (this.viewOptions.keyboardSupport) {\n      this.minHandleElement!.on('focus', (): void => this.onPointerFocus(PointerType.Min));\n      if (this.range) {\n        this.maxHandleElement!.on('focus', (): void => this.onPointerFocus(PointerType.Max));\n      }\n    }\n  }\n\n  private getOptionsInfluencingEventBindings(options: Options): boolean[] {\n    return [\n      options.disabled!,\n      options.readOnly!,\n      options.draggableRange!,\n      options.draggableRangeOnly!,\n      options.onlyBindHandles!,\n      options.keyboardSupport!\n    ];\n  }\n\n  // Unbind mouse and touch events to slider handles\n  private unbindEvents(): void {\n    this.unsubscribeOnMove();\n    this.unsubscribeOnEnd();\n\n    for (const element of this.getAllSliderElements()) {\n      if (!ValueHelper.isNullOrUndefined(element)) {\n        element.off();\n      }\n    }\n  }\n\n  private onBarStart(\n    draggableRange: boolean,\n    event: MouseEvent | TouchEvent,\n    bindMove: boolean,\n    bindEnd: boolean,\n    pointerType?: PointerType,\n    simulateImmediateMove?: boolean,\n    simulateImmediateEnd?: boolean\n  ): void {\n    if (draggableRange) {\n      this.onDragStart(event, bindMove, bindEnd, pointerType);\n    } else {\n      this.onStart(event, bindMove, bindEnd, pointerType, simulateImmediateMove, simulateImmediateEnd);\n    }\n  }\n\n  // onStart event handler\n  private onStart(\n    event: MouseEvent | TouchEvent,\n    bindMove: boolean,\n    bindEnd: boolean,\n    pointerType?: PointerType,\n    simulateImmediateMove?: boolean,\n    simulateImmediateEnd?: boolean\n  ): void {\n    event.stopPropagation();\n    // Only call preventDefault() when handling non-passive events (passive events don't need it)\n    if (!CompatibilityHelper.isTouchEvent(event) && !supportsPassiveEvents) {\n      event.preventDefault();\n    }\n\n    this.moving = false;\n\n    // We have to do this in case the HTML where the sliders are on\n    // have been animated into view.\n    this.calculateViewDimensions();\n\n    if (ValueHelper.isNullOrUndefined(pointerType)) {\n      pointerType = this.getNearestHandle(event);\n    }\n\n    this.currentTrackingPointer = pointerType;\n\n    const pointerElement: SliderHandleDirective = this.getPointerElement(pointerType!)!;\n    pointerElement.active = true;\n\n    if (this.viewOptions.keyboardSupport) {\n      pointerElement.focus();\n    }\n\n    if (bindMove) {\n      this.unsubscribeOnMove();\n\n      const onMoveCallback: (e: MouseEvent | TouchEvent) => void = (e: MouseEvent | TouchEvent): void =>\n        this.dragging.active ? this.onDragMove(e) : this.onMove(e);\n\n      if (CompatibilityHelper.isTouchEvent(event)) {\n        this.onMoveEventListener = this.eventListenerHelper!.attachPassiveEventListener(\n          document,\n          'touchmove',\n          onMoveCallback\n        );\n      } else {\n        this.onMoveEventListener = this.eventListenerHelper!.attachEventListener(document, 'mousemove', onMoveCallback);\n      }\n    }\n\n    if (bindEnd) {\n      this.unsubscribeOnEnd();\n\n      const onEndCallback: (e: MouseEvent | TouchEvent) => void = (e: MouseEvent | TouchEvent): void => this.onEnd(e);\n\n      if (CompatibilityHelper.isTouchEvent(event)) {\n        this.onEndEventListener = this.eventListenerHelper!.attachPassiveEventListener(\n          document,\n          'touchend',\n          onEndCallback\n        );\n      } else {\n        this.onEndEventListener = this.eventListenerHelper!.attachEventListener(document, 'mouseup', onEndCallback);\n      }\n    }\n\n    this.userChangeStart.emit(this.getChangeContext());\n\n    if (\n      CompatibilityHelper.isTouchEvent(event) &&\n      !ValueHelper.isNullOrUndefined((event as TouchEvent).changedTouches)\n    ) {\n      // Store the touch identifier\n      if (ValueHelper.isNullOrUndefined(this.touchId)) {\n        this.touchId = (event as TouchEvent).changedTouches[0].identifier;\n      }\n    }\n\n    // Click events, either with mouse or touch gesture are weird. Sometimes they result in full\n    // start, move, end sequence, and sometimes, they don't - they only invoke mousedown\n    // As a workaround, we simulate the first move event and the end event if it's necessary\n    if (simulateImmediateMove) {\n      this.onMove(event, true);\n    }\n\n    if (simulateImmediateEnd) {\n      this.onEnd(event);\n    }\n  }\n\n  // onMove event handler\n  private onMove(event: MouseEvent | TouchEvent, fromTick?: boolean): void {\n    let touchForThisSlider: Touch;\n\n    if (CompatibilityHelper.isTouchEvent(event)) {\n      const changedTouches: TouchList = (event as TouchEvent).changedTouches;\n      for (let i: number = 0; i < changedTouches.length; i++) {\n        if (changedTouches[i].identifier === this.touchId) {\n          touchForThisSlider = changedTouches[i];\n          break;\n        }\n      }\n\n      if (ValueHelper.isNullOrUndefined(touchForThisSlider!)) {\n        return;\n      }\n    }\n\n    if (this.viewOptions.animate && !this.viewOptions.animateOnMove) {\n      if (this.moving) {\n        this.sliderElementAnimateClass = false;\n      }\n    }\n\n    this.moving = true;\n\n    const newPos: number = !ValueHelper.isNullOrUndefined(touchForThisSlider!)\n      ? this.getEventPosition(event, touchForThisSlider!.identifier)\n      : this.getEventPosition(event);\n    let newValue: number;\n    const ceilValue: number = this.viewOptions.rightToLeft ? this.viewOptions.floor! : this.viewOptions.ceil!;\n    const floorValue: number = this.viewOptions.rightToLeft ? this.viewOptions.ceil! : this.viewOptions.floor!;\n\n    if (newPos <= 0) {\n      newValue = floorValue;\n    } else if (newPos >= this.maxHandlePosition) {\n      newValue = ceilValue;\n    } else {\n      newValue = this.positionToValue(newPos);\n      if (fromTick && !ValueHelper.isNullOrUndefined(this.viewOptions.tickStep)) {\n        newValue = this.roundStep(newValue, this.viewOptions.tickStep);\n      } else {\n        newValue = this.roundStep(newValue);\n      }\n    }\n    this.positionTrackingHandle(newValue);\n  }\n\n  private onEnd(event: MouseEvent | TouchEvent): void {\n    if (CompatibilityHelper.isTouchEvent(event)) {\n      const changedTouches: TouchList = (event as TouchEvent).changedTouches;\n      if (changedTouches[0].identifier !== this.touchId) {\n        return;\n      }\n    }\n\n    this.moving = false;\n    if (this.viewOptions.animate) {\n      this.sliderElementAnimateClass = true;\n    }\n\n    this.touchId = undefined;\n\n    if (!this.viewOptions.keyboardSupport) {\n      this.minHandleElement!.active = false;\n      this.maxHandleElement!.active = false;\n      this.currentTrackingPointer = undefined;\n    }\n    this.dragging.active = false;\n\n    this.unsubscribeOnMove();\n    this.unsubscribeOnEnd();\n\n    this.userChangeEnd.emit(this.getChangeContext());\n  }\n\n  private onPointerFocus(pointerType: PointerType): void {\n    const pointerElement: SliderHandleDirective = this.getPointerElement(pointerType)!;\n    pointerElement.on('blur', (): void => this.onPointerBlur(pointerElement));\n    pointerElement.on('keydown', (event: KeyboardEvent): void => this.onKeyboardEvent(event));\n    pointerElement.on('keyup', (): void => this.onKeyUp());\n    pointerElement.active = true;\n\n    this.currentTrackingPointer = pointerType;\n    this.currentFocusPointer = pointerType;\n    this.firstKeyDown = true;\n  }\n\n  private onKeyUp(): void {\n    this.firstKeyDown = true;\n    this.userChangeEnd.emit(this.getChangeContext());\n  }\n\n  private onPointerBlur(pointer: SliderHandleDirective): void {\n    pointer.off('blur');\n    pointer.off('keydown');\n    pointer.off('keyup');\n    pointer.active = false;\n    if (ValueHelper.isNullOrUndefined(this.touchId)) {\n      this.currentTrackingPointer = undefined;\n      this.currentFocusPointer = undefined;\n    }\n  }\n\n  private getKeyActions(currentValue: number): { [key: string]: number } {\n    const valueRange: number = this.viewOptions.ceil! - this.viewOptions.floor!;\n\n    let increaseStep: number = currentValue + this.viewOptions.step!;\n    let decreaseStep: number = currentValue - this.viewOptions.step!;\n    let increasePage: number = currentValue + valueRange / 10;\n    let decreasePage: number = currentValue - valueRange / 10;\n\n    if (this.viewOptions.reversedControls) {\n      increaseStep = currentValue - this.viewOptions.step!;\n      decreaseStep = currentValue + this.viewOptions.step!;\n      increasePage = currentValue - valueRange / 10;\n      decreasePage = currentValue + valueRange / 10;\n    }\n\n    // Left to right default actions\n    const actions: { [key: string]: number } = {\n      UP: increaseStep,\n      DOWN: decreaseStep,\n      LEFT: decreaseStep,\n      RIGHT: increaseStep,\n      PAGEUP: increasePage,\n      PAGEDOWN: decreasePage,\n      HOME: this.viewOptions.reversedControls ? this.viewOptions.ceil! : this.viewOptions.floor!,\n      END: this.viewOptions.reversedControls ? this.viewOptions.floor! : this.viewOptions.ceil!\n    };\n    // right to left means swapping right and left arrows\n    if (this.viewOptions.rightToLeft) {\n      actions['LEFT'] = increaseStep;\n      actions['RIGHT'] = decreaseStep;\n      // right to left and vertical means we also swap up and down\n      if (this.viewOptions.vertical || this.viewOptions.rotate !== 0) {\n        actions['UP'] = decreaseStep;\n        actions['DOWN'] = increaseStep;\n      }\n    }\n    return actions;\n  }\n\n  private onKeyboardEvent(event: KeyboardEvent): void {\n    const currentValue = this.getCurrentTrackingValue()!;\n    const keyCode = !ValueHelper.isNullOrUndefined(event.keyCode) ? event.keyCode : event.which;\n    const keys: { [keyCode: number]: string } = {\n      38: 'UP',\n      40: 'DOWN',\n      37: 'LEFT',\n      39: 'RIGHT',\n      33: 'PAGEUP',\n      34: 'PAGEDOWN',\n      36: 'HOME',\n      35: 'END'\n    };\n    const actions: { [key: string]: number } = this.getKeyActions(currentValue);\n    const key: string = keys[keyCode];\n    const action: number = actions[key];\n\n    if (ValueHelper.isNullOrUndefined(action) || ValueHelper.isNullOrUndefined(this.currentTrackingPointer)) {\n      return;\n    }\n    event.preventDefault();\n\n    if (this.firstKeyDown) {\n      this.firstKeyDown = false;\n      this.userChangeStart.emit(this.getChangeContext());\n    }\n\n    const actionValue: number = MathHelper.clampToRange(action, this.viewOptions.floor!, this.viewOptions.ceil!);\n    const newValue: number = this.roundStep(actionValue);\n    if (!this.viewOptions.draggableRangeOnly) {\n      this.positionTrackingHandle(newValue);\n    } else {\n      const difference = this.viewHighValue! - this.viewLowValue!;\n      let newMinValue: number;\n      let newMaxValue: number;\n\n      if (this.currentTrackingPointer === PointerType.Min) {\n        newMinValue = newValue;\n        newMaxValue = newValue + difference;\n        if (newMaxValue > this.viewOptions.ceil!) {\n          newMaxValue = this.viewOptions.ceil!;\n          newMinValue = newMaxValue - difference;\n        }\n      } else if (this.currentTrackingPointer === PointerType.Max) {\n        newMaxValue = newValue;\n        newMinValue = newValue - difference;\n        if (newMinValue < this.viewOptions.floor!) {\n          newMinValue = this.viewOptions.floor!;\n          newMaxValue = newMinValue + difference;\n        }\n      }\n      this.positionTrackingBar(newMinValue!, newMaxValue!);\n    }\n  }\n\n  // onDragStart event handler, handles dragging of the middle bar\n  private onDragStart(\n    event: MouseEvent | TouchEvent,\n    bindMove: boolean,\n    bindEnd: boolean,\n    pointerType?: PointerType\n  ): void {\n    const position: number = this.getEventPosition(event);\n\n    this.dragging = new Dragging();\n    this.dragging.active = true;\n    this.dragging.value = this.positionToValue(position);\n    this.dragging.difference = this.viewHighValue! - this.viewLowValue!;\n    this.dragging.lowLimit = this.viewOptions.rightToLeft\n      ? this.minHandleElement!.position - position\n      : position - this.minHandleElement!.position;\n    this.dragging.highLimit = this.viewOptions.rightToLeft\n      ? position - this.maxHandleElement!.position\n      : this.maxHandleElement!.position - position;\n\n    this.onStart(event, bindMove, bindEnd, pointerType);\n  }\n\n  /** Get min value depending on whether the newPos is outOfBounds above or below the bar and rightToLeft */\n  private getMinValue(newPos: number, outOfBounds: boolean, isAbove: boolean): number {\n    const isRTL = this.viewOptions.rightToLeft!;\n    let value: number;\n\n    if (outOfBounds) {\n      if (isAbove) {\n        value = isRTL ? this.viewOptions.floor! : this.viewOptions.ceil! - this.dragging.difference;\n      } else {\n        value = isRTL ? this.viewOptions.ceil! - this.dragging.difference : this.viewOptions.floor!;\n      }\n    } else {\n      value = isRTL\n        ? this.positionToValue(newPos + this.dragging.lowLimit)\n        : this.positionToValue(newPos - this.dragging.lowLimit);\n    }\n    return this.roundStep(value);\n  }\n\n  /** Get max value depending on whether the newPos is outOfBounds above or below the bar and rightToLeft */\n  private getMaxValue(newPos: number, outOfBounds: boolean, isAbove: boolean): number {\n    const isRTL = this.viewOptions.rightToLeft!;\n    let value: number;\n\n    if (outOfBounds) {\n      if (isAbove) {\n        value = isRTL ? this.viewOptions.floor! + this.dragging.difference : this.viewOptions.ceil!;\n      } else {\n        value = isRTL ? this.viewOptions.ceil! : this.viewOptions.floor! + this.dragging.difference;\n      }\n    } else {\n      if (isRTL) {\n        value = this.positionToValue(newPos + this.dragging.lowLimit) + this.dragging.difference;\n      } else {\n        value = this.positionToValue(newPos - this.dragging.lowLimit) + this.dragging.difference;\n      }\n    }\n\n    return this.roundStep(value);\n  }\n\n  private onDragMove(event?: MouseEvent | TouchEvent): void {\n    const newPos: number = this.getEventPosition(event!);\n\n    if (this.viewOptions.animate && !this.viewOptions.animateOnMove) {\n      if (this.moving) {\n        this.sliderElementAnimateClass = false;\n      }\n    }\n\n    this.moving = true;\n\n    let ceilLimit: number,\n      floorLimit: number,\n      floorHandleElement: SliderHandleDirective,\n      ceilHandleElement: SliderHandleDirective;\n    if (this.viewOptions.rightToLeft) {\n      ceilLimit = this.dragging.lowLimit;\n      floorLimit = this.dragging.highLimit;\n      floorHandleElement = this.maxHandleElement!;\n      ceilHandleElement = this.minHandleElement!;\n    } else {\n      ceilLimit = this.dragging.highLimit;\n      floorLimit = this.dragging.lowLimit;\n      floorHandleElement = this.minHandleElement!;\n      ceilHandleElement = this.maxHandleElement!;\n    }\n\n    const isUnderFloorLimit: boolean = newPos <= floorLimit;\n    const isOverCeilLimit: boolean = newPos >= this.maxHandlePosition - ceilLimit;\n\n    let newMinValue: number;\n    let newMaxValue: number;\n    if (isUnderFloorLimit) {\n      if (floorHandleElement.position === 0) {\n        return;\n      }\n      newMinValue = this.getMinValue(newPos, true, false);\n      newMaxValue = this.getMaxValue(newPos, true, false);\n    } else if (isOverCeilLimit) {\n      if (ceilHandleElement.position === this.maxHandlePosition) {\n        return;\n      }\n      newMaxValue = this.getMaxValue(newPos, true, true);\n      newMinValue = this.getMinValue(newPos, true, true);\n    } else {\n      newMinValue = this.getMinValue(newPos, false, false);\n      newMaxValue = this.getMaxValue(newPos, false, false);\n    }\n\n    this.positionTrackingBar(newMinValue, newMaxValue);\n  }\n\n  // Set the new value and position for the entire bar\n  private positionTrackingBar(newMinValue: number, newMaxValue: number): void {\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.minLimit) && newMinValue < this.viewOptions.minLimit!) {\n      newMinValue = this.viewOptions.minLimit!;\n      newMaxValue = MathHelper.roundToPrecisionLimit(\n        newMinValue + this.dragging.difference,\n        this.viewOptions.precisionLimit!\n      );\n    }\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.maxLimit) && newMaxValue > this.viewOptions.maxLimit!) {\n      newMaxValue = this.viewOptions.maxLimit!;\n      newMinValue = MathHelper.roundToPrecisionLimit(\n        newMaxValue - this.dragging.difference,\n        this.viewOptions.precisionLimit!\n      );\n    }\n\n    this.viewLowValue = newMinValue;\n    this.viewHighValue = newMaxValue;\n    this.applyViewChange();\n    this.updateHandles(PointerType.Min, this.valueToPosition(newMinValue));\n    this.updateHandles(PointerType.Max, this.valueToPosition(newMaxValue));\n  }\n\n  // Set the new value and position to the current tracking handle\n  private positionTrackingHandle(newValue: number): void {\n    newValue = this.applyMinMaxLimit(newValue);\n    if (this.range) {\n      if (this.viewOptions.pushRange) {\n        newValue = this.applyPushRange(newValue);\n      } else {\n        if (this.viewOptions.noSwitching) {\n          if (this.currentTrackingPointer === PointerType.Min && newValue > this.viewHighValue!) {\n            newValue = this.applyMinMaxRange(this.viewHighValue!);\n          } else if (this.currentTrackingPointer === PointerType.Max && newValue < this.viewLowValue!) {\n            newValue = this.applyMinMaxRange(this.viewLowValue!);\n          }\n        }\n        newValue = this.applyMinMaxRange(newValue);\n        /* This is to check if we need to switch the min and max handles */\n        if (this.currentTrackingPointer === PointerType.Min && newValue > this.viewHighValue!) {\n          this.viewLowValue = this.viewHighValue;\n          this.applyViewChange();\n          this.updateHandles(PointerType.Min, this.maxHandleElement!.position);\n          this.updateAriaAttributes();\n          this.currentTrackingPointer = PointerType.Max;\n          this.minHandleElement!.active = false;\n          this.maxHandleElement!.active = true;\n          if (this.viewOptions.keyboardSupport) {\n            this.maxHandleElement!.focus();\n          }\n        } else if (this.currentTrackingPointer === PointerType.Max && newValue < this.viewLowValue!) {\n          this.viewHighValue = this.viewLowValue;\n          this.applyViewChange();\n          this.updateHandles(PointerType.Max, this.minHandleElement!.position);\n          this.updateAriaAttributes();\n          this.currentTrackingPointer = PointerType.Min;\n          this.maxHandleElement!.active = false;\n          this.minHandleElement!.active = true;\n          if (this.viewOptions.keyboardSupport) {\n            this.minHandleElement!.focus();\n          }\n        }\n      }\n    }\n\n    if (this.getCurrentTrackingValue() !== newValue) {\n      if (this.currentTrackingPointer === PointerType.Min) {\n        this.viewLowValue = newValue;\n        this.applyViewChange();\n      } else if (this.currentTrackingPointer === PointerType.Max) {\n        this.viewHighValue = newValue;\n        this.applyViewChange();\n      }\n      this.updateHandles(this.currentTrackingPointer!, this.valueToPosition(newValue));\n      this.updateAriaAttributes();\n    }\n  }\n\n  private applyMinMaxLimit(newValue: number): number {\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.minLimit) && newValue < this.viewOptions.minLimit!) {\n      return this.viewOptions.minLimit!;\n    }\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.maxLimit) && newValue > this.viewOptions.maxLimit!) {\n      return this.viewOptions.maxLimit!;\n    }\n    return newValue;\n  }\n\n  private applyMinMaxRange(newValue: number): number {\n    const oppositeValue = this.currentTrackingPointer === PointerType.Min ? this.viewHighValue : this.viewLowValue;\n    const difference: number = Math.abs(newValue - oppositeValue!);\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.minRange)) {\n      if (difference < this.viewOptions.minRange!) {\n        if (this.currentTrackingPointer === PointerType.Min) {\n          return MathHelper.roundToPrecisionLimit(\n            this.viewHighValue! - this.viewOptions.minRange!,\n            this.viewOptions.precisionLimit!\n          );\n        } else if (this.currentTrackingPointer === PointerType.Max) {\n          return MathHelper.roundToPrecisionLimit(\n            this.viewLowValue! + this.viewOptions.minRange!,\n            this.viewOptions.precisionLimit!\n          );\n        }\n      }\n    }\n    if (!ValueHelper.isNullOrUndefined(this.viewOptions.maxRange)) {\n      if (difference > this.viewOptions.maxRange!) {\n        if (this.currentTrackingPointer === PointerType.Min) {\n          return MathHelper.roundToPrecisionLimit(\n            this.viewHighValue! - this.viewOptions.maxRange!,\n            this.viewOptions.precisionLimit!\n          );\n        } else if (this.currentTrackingPointer === PointerType.Max) {\n          return MathHelper.roundToPrecisionLimit(\n            this.viewLowValue! + this.viewOptions.maxRange!,\n            this.viewOptions.precisionLimit!\n          );\n        }\n      }\n    }\n    return newValue;\n  }\n\n  private applyPushRange(newValue: number): number {\n    const difference: number =\n      this.currentTrackingPointer === PointerType.Min ? this.viewHighValue! - newValue : newValue - this.viewLowValue!;\n    const minRange = !ValueHelper.isNullOrUndefined(this.viewOptions.minRange)\n      ? this.viewOptions.minRange!\n      : this.viewOptions.step!;\n    const maxRange = this.viewOptions.maxRange!;\n    // if smaller than minRange\n    if (difference < minRange) {\n      if (this.currentTrackingPointer === PointerType.Min) {\n        this.viewHighValue = MathHelper.roundToPrecisionLimit(\n          Math.min(newValue + minRange, this.viewOptions.ceil!),\n          this.viewOptions.precisionLimit!\n        );\n        newValue = MathHelper.roundToPrecisionLimit(this.viewHighValue - minRange, this.viewOptions.precisionLimit!);\n        this.applyViewChange();\n        this.updateHandles(PointerType.Max, this.valueToPosition(this.viewHighValue));\n      } else if (this.currentTrackingPointer === PointerType.Max) {\n        this.viewLowValue = MathHelper.roundToPrecisionLimit(\n          Math.max(newValue - minRange, this.viewOptions.floor!),\n          this.viewOptions.precisionLimit!\n        );\n        newValue = MathHelper.roundToPrecisionLimit(this.viewLowValue + minRange, this.viewOptions.precisionLimit!);\n        this.applyViewChange();\n        this.updateHandles(PointerType.Min, this.valueToPosition(this.viewLowValue));\n      }\n      this.updateAriaAttributes();\n    } else if (!ValueHelper.isNullOrUndefined(maxRange) && difference > maxRange) {\n      // if greater than maxRange\n      if (this.currentTrackingPointer === PointerType.Min) {\n        this.viewHighValue = MathHelper.roundToPrecisionLimit(newValue + maxRange, this.viewOptions.precisionLimit!);\n        this.applyViewChange();\n        this.updateHandles(PointerType.Max, this.valueToPosition(this.viewHighValue));\n      } else if (this.currentTrackingPointer === PointerType.Max) {\n        this.viewLowValue = MathHelper.roundToPrecisionLimit(newValue - maxRange, this.viewOptions.precisionLimit!);\n        this.applyViewChange();\n        this.updateHandles(PointerType.Min, this.valueToPosition(this.viewLowValue));\n      }\n      this.updateAriaAttributes();\n    }\n    return newValue;\n  }\n\n  private getChangeContext(): ChangeContext {\n    const changeContext: ChangeContext = new ChangeContext();\n    changeContext.pointerType = this.currentTrackingPointer;\n    changeContext.value = +this.value!;\n    if (this.range) {\n      changeContext.highValue = +this.highValue!;\n    }\n    return changeContext;\n  }\n}\n","<!-- // 0 Left selection bar outside two handles -->\n<span\n  ngxSliderElement\n  #leftOuterSelectionBar\n  class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-left-out-selection\"\n>\n  <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 1 Right selection bar outside two handles -->\n<span\n  ngxSliderElement\n  #rightOuterSelectionBar\n  class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-right-out-selection\"\n>\n  <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 2 The whole slider bar -->\n<span\n  ngxSliderElement\n  #fullBar\n  [class.ngx-slider-transparent]=\"fullBarTransparentClass\"\n  class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-full-bar\"\n>\n  <span class=\"ngx-slider-span ngx-slider-bar\"></span>\n</span>\n<!-- // 3 Selection bar between two handles -->\n<span\n  ngxSliderElement\n  #selectionBar\n  [class.ngx-slider-draggable]=\"selectionBarDraggableClass\"\n  class=\"ngx-slider-span ngx-slider-bar-wrapper ngx-slider-selection-bar\"\n>\n  <span class=\"ngx-slider-span ngx-slider-bar ngx-slider-selection\" [ngStyle]=\"barStyle\"></span>\n</span>\n<!-- // 4 Low slider handle -->\n<span\n  ngxSliderHandle\n  #minHandle\n  class=\"ngx-slider-span ngx-slider-pointer ngx-slider-pointer-min\"\n  [ngStyle]=\"minPointerStyle\"\n></span>\n<!-- // 5 High slider handle -->\n<span\n  ngxSliderHandle\n  #maxHandle\n  [style.display]=\"range ? 'inherit' : 'none'\"\n  class=\"ngx-slider-span ngx-slider-pointer ngx-slider-pointer-max\"\n  [ngStyle]=\"maxPointerStyle\"\n></span>\n<!-- // 6 Floor label -->\n<span ngxSliderLabel #floorLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-limit ngx-slider-floor\"></span>\n<!-- // 7 Ceiling label -->\n<span ngxSliderLabel #ceilLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-limit ngx-slider-ceil\"></span>\n<!-- // 8 Label above the low slider handle -->\n<span ngxSliderLabel #minHandleLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-model-value\"></span>\n<!-- // 9 Label above the high slider handle -->\n<span ngxSliderLabel #maxHandleLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-model-high\"></span>\n<!-- // 10 Combined range label when the slider handles are close ex. 15 - 17 -->\n<span ngxSliderLabel #combinedLabel class=\"ngx-slider-span ngx-slider-bubble ngx-slider-combined\"></span>\n<!-- // 11 The ticks -->\n<span\n  ngxSliderElement\n  #ticksElement\n  [hidden]=\"!showTicks\"\n  [class.ngx-slider-ticks-values-under]=\"ticksUnderValuesClass\"\n  class=\"ngx-slider-ticks\"\n>\n  @for (t of ticks; track t) {\n    <span class=\"ngx-slider-tick\" [ngClass]=\"{ 'ngx-slider-selected': t.selected }\" [ngStyle]=\"t.style\">\n      <ngx-slider-tooltip-wrapper\n        [template]=\"tooltipTemplate\"\n        [tooltip]=\"t.tooltip\"\n        [placement]=\"t.tooltipPlacement\"\n      ></ngx-slider-tooltip-wrapper>\n      @if (t.value !== null) {\n        <ngx-slider-tooltip-wrapper\n          class=\"ngx-slider-span ngx-slider-tick-value\"\n          [template]=\"tooltipTemplate\"\n          [tooltip]=\"t.valueTooltip\"\n          [placement]=\"t.valueTooltipPlacement\"\n          [content]=\"t.value\"\n        ></ngx-slider-tooltip-wrapper>\n      }\n      @if (t.legend !== null) {\n        <span class=\"ngx-slider-span ngx-slider-tick-legend\" [innerHTML]=\"t.legend\"></span>\n      }\n    </span>\n  }\n</span>\n"]}
|