|
1 | | -document.addEventListener('DOMContentLoaded', function() { |
2 | | - Array.from(document.getElementsByClassName('admin-numeric-filter-slider')).forEach(function(slider) { |
3 | | - if (Array.from(slider.classList).includes("noUi-target")) { |
4 | | - return; |
5 | | - } |
| 1 | +document.addEventListener("DOMContentLoaded", function () { |
| 2 | + Array.from( |
| 3 | + document.getElementsByClassName("admin-numeric-filter-slider") |
| 4 | + ).forEach(function (slider) { |
| 5 | + if (Array.from(slider.classList).includes("noUi-target")) { |
| 6 | + return; |
| 7 | + } |
6 | 8 |
|
7 | | - var from = parseFloat(slider.closest('.admin-numeric-filter-wrapper').querySelectorAll('.admin-numeric-filter-wrapper-group input')[0].value); |
8 | | - var to = parseFloat(slider.closest('.admin-numeric-filter-wrapper').querySelectorAll('.admin-numeric-filter-wrapper-group input')[1].value); |
| 9 | + const fromInput = slider |
| 10 | + .closest(".admin-numeric-filter-wrapper") |
| 11 | + .querySelectorAll(".admin-numeric-filter-wrapper-group input")[0]; |
9 | 12 |
|
10 | | - noUiSlider.create(slider, { |
11 | | - start: [from, to], |
12 | | - step: parseFloat(slider.getAttribute('data-step')), |
13 | | - connect: true, |
14 | | - format: wNumb({ |
15 | | - decimals: parseFloat(slider.getAttribute('data-decimals')) |
16 | | - }), |
17 | | - range: { |
18 | | - 'min': parseFloat(slider.getAttribute('data-min')), |
19 | | - 'max': parseFloat(slider.getAttribute('data-max')) |
20 | | - } |
21 | | - }); |
| 13 | + const toInput = slider |
| 14 | + .closest(".admin-numeric-filter-wrapper") |
| 15 | + .querySelectorAll(".admin-numeric-filter-wrapper-group input")[1]; |
22 | 16 |
|
23 | | - slider.noUiSlider.on('update', function(values, handle) { |
24 | | - var parent = this.target.closest('.admin-numeric-filter-wrapper'); |
25 | | - var from = parent.querySelectorAll('.admin-numeric-filter-wrapper-group input')[0]; |
26 | | - var to = parent.querySelectorAll('.admin-numeric-filter-wrapper-group input')[1]; |
| 17 | + noUiSlider.create(slider, { |
| 18 | + start: [parseFloat(fromInput.value), parseFloat(toInput.value)], |
| 19 | + step: parseFloat(slider.getAttribute("data-step")), |
| 20 | + connect: true, |
| 21 | + format: wNumb({ |
| 22 | + decimals: parseFloat(slider.getAttribute("data-decimals")), |
| 23 | + }), |
| 24 | + range: { |
| 25 | + min: parseFloat(slider.getAttribute("data-min")), |
| 26 | + max: parseFloat(slider.getAttribute("data-max")), |
| 27 | + }, |
| 28 | + }); |
| 29 | + |
| 30 | + /************************************************************* |
| 31 | + * Update slider when input values change |
| 32 | + *************************************************************/ |
| 33 | + fromInput.addEventListener("keyup", function () { |
| 34 | + clearTimeout(this._sliderUpdateTimeout); |
| 35 | + this._sliderUpdateTimeout = setTimeout(() => { |
| 36 | + slider.noUiSlider.set([ |
| 37 | + parseFloat(this.value), |
| 38 | + parseFloat(toInput.value), |
| 39 | + ]); |
| 40 | + }, 500); |
| 41 | + }); |
| 42 | + |
| 43 | + toInput.addEventListener("keyup", function () { |
| 44 | + clearTimeout(this._sliderUpdateTimeout); |
| 45 | + this._sliderUpdateTimeout = setTimeout(() => { |
| 46 | + slider.noUiSlider.set([ |
| 47 | + parseFloat(fromInput.value), |
| 48 | + parseFloat(this.value), |
| 49 | + ]); |
| 50 | + }, 500); |
| 51 | + }); |
27 | 52 |
|
28 | | - parent.querySelectorAll('.admin-numeric-filter-slider-tooltip-from')[0].innerHTML = values[0]; |
29 | | - parent.querySelectorAll('.admin-numeric-filter-slider-tooltip-to')[0].innerHTML = values[1]; |
| 53 | + /************************************************************* |
| 54 | + * Updated inputs when slider is moved |
| 55 | + *************************************************************/ |
| 56 | + slider.noUiSlider.on("update", function (values, handle) { |
| 57 | + const parent = this.target.closest(".admin-numeric-filter-wrapper"); |
| 58 | + const from = parent.querySelectorAll( |
| 59 | + ".admin-numeric-filter-wrapper-group input" |
| 60 | + )[0]; |
| 61 | + const to = parent.querySelectorAll( |
| 62 | + ".admin-numeric-filter-wrapper-group input" |
| 63 | + )[1]; |
30 | 64 |
|
31 | | - from.value = values[0]; |
32 | | - to.value = values[1]; |
33 | | - }); |
| 65 | + from.value = values[0]; |
| 66 | + to.value = values[1]; |
34 | 67 | }); |
| 68 | + }); |
35 | 69 | }); |
0 commit comments