318 lines
6.7 KiB
JavaScript
318 lines
6.7 KiB
JavaScript
|
|
/*********************
|
|
basic example
|
|
**********************/
|
|
|
|
var slider = document.getElementById('slider');
|
|
|
|
noUiSlider.create(slider, {
|
|
start: [20, 80],
|
|
connect: true,
|
|
range: {
|
|
'min': 0,
|
|
'max': 100
|
|
}
|
|
});
|
|
|
|
|
|
|
|
/*********************
|
|
Colorpicker
|
|
**********************/
|
|
|
|
var resultElement = document.getElementById('result');
|
|
var sliders = document.getElementsByClassName('sliders');
|
|
var colors = [0, 0, 0];
|
|
|
|
[].slice.call(sliders).forEach(function (slider, index) {
|
|
|
|
noUiSlider.create(slider, {
|
|
start: 127,
|
|
connect: [true, false],
|
|
orientation: "vertical",
|
|
range: {
|
|
'min': 0,
|
|
'max': 255
|
|
},
|
|
format: wNumb({
|
|
decimals: 0
|
|
})
|
|
});
|
|
|
|
// Bind the color changing function to the update event.
|
|
slider.noUiSlider.on('update', function () {
|
|
|
|
colors[index] = slider.noUiSlider.get();
|
|
|
|
var color = 'rgb(' + colors.join(',') + ')';
|
|
|
|
resultElement.style.background = color;
|
|
resultElement.style.color = color;
|
|
});
|
|
});
|
|
|
|
|
|
/*********************
|
|
Using HTML5 input elements
|
|
**********************/
|
|
|
|
var select = document.getElementById('input-select');
|
|
|
|
// Append the option elements
|
|
for (var i = -20; i <= 40; i++) {
|
|
|
|
var option = document.createElement("option");
|
|
option.text = i;
|
|
option.value = i;
|
|
|
|
select.appendChild(option);
|
|
}
|
|
|
|
var html5Slider = document.getElementById('html5');
|
|
|
|
noUiSlider.create(html5Slider, {
|
|
start: [10, 30],
|
|
connect: true,
|
|
range: {
|
|
'min': -20,
|
|
'max': 40
|
|
}
|
|
});
|
|
|
|
var inputNumber = document.getElementById('input-number');
|
|
|
|
html5Slider.noUiSlider.on('update', function (values, handle) {
|
|
|
|
var value = values[handle];
|
|
|
|
if (handle) {
|
|
inputNumber.value = value;
|
|
} else {
|
|
select.value = Math.round(value);
|
|
}
|
|
});
|
|
|
|
select.addEventListener('change', function () {
|
|
html5Slider.noUiSlider.set([this.value, null]);
|
|
});
|
|
|
|
inputNumber.addEventListener('change', function () {
|
|
html5Slider.noUiSlider.set([null, this.value]);
|
|
});
|
|
|
|
|
|
/*********************
|
|
Non linear slider
|
|
**********************/
|
|
|
|
var nonLinearSlider = document.getElementById('nonlinear');
|
|
|
|
noUiSlider.create(nonLinearSlider, {
|
|
connect: true,
|
|
behaviour: 'tap',
|
|
start: [500, 4000],
|
|
range: {
|
|
// Starting at 500, step the value by 500,
|
|
// until 4000 is reached. From there, step by 1000.
|
|
'min': [0],
|
|
'10%': [500, 500],
|
|
'50%': [4000, 1000],
|
|
'max': [10000]
|
|
}
|
|
});
|
|
|
|
var nodes = [
|
|
document.getElementById('lower-value'), // 0
|
|
document.getElementById('upper-value') // 1
|
|
];
|
|
|
|
// Display the slider value and how far the handle moved
|
|
// from the left edge of the slider.
|
|
nonLinearSlider.noUiSlider.on('update', function (values, handle, unencoded, isTap, positions) {
|
|
nodes[handle].innerHTML = values[handle] + ', ' + positions[handle].toFixed(2) + '%';
|
|
});
|
|
|
|
|
|
/*********************
|
|
Locking sliders together
|
|
**********************/
|
|
|
|
var lockedState = false;
|
|
var lockedSlider = false;
|
|
var lockedValues = [60, 80];
|
|
|
|
var slider1 = document.getElementById('slider1');
|
|
var slider2 = document.getElementById('slider2');
|
|
|
|
var lockButton = document.getElementById('lockbutton');
|
|
var slider1Value = document.getElementById('slider1-span');
|
|
var slider2Value = document.getElementById('slider2-span');
|
|
|
|
// When the button is clicked, the locked state is inverted.
|
|
lockButton.addEventListener('click', function () {
|
|
lockedState = !lockedState;
|
|
this.textContent = lockedState ? 'Unlock' : 'lock';
|
|
});
|
|
|
|
|
|
function crossUpdate(value, slider) {
|
|
|
|
// If the sliders aren't interlocked, don't
|
|
// cross-update.
|
|
if (!lockedState) return;
|
|
|
|
// Select whether to increase or decrease
|
|
// the other slider value.
|
|
var a = slider1 === slider ? 0 : 1;
|
|
|
|
// Invert a
|
|
var b = a ? 0 : 1;
|
|
|
|
// Offset the slider value.
|
|
value -= lockedValues[b] - lockedValues[a];
|
|
|
|
// Set the value
|
|
slider.noUiSlider.set(value);
|
|
}
|
|
|
|
|
|
noUiSlider.create(slider1, {
|
|
start: 60,
|
|
|
|
// Disable animation on value-setting,
|
|
// so the sliders respond immediately.
|
|
animate: false,
|
|
range: {
|
|
min: 50,
|
|
max: 100
|
|
}
|
|
});
|
|
|
|
noUiSlider.create(slider2, {
|
|
start: 80,
|
|
animate: false,
|
|
range: {
|
|
min: 50,
|
|
max: 100
|
|
}
|
|
});
|
|
|
|
slider1.noUiSlider.on('update', function (values, handle) {
|
|
slider1Value.innerHTML = values[handle];
|
|
});
|
|
|
|
slider2.noUiSlider.on('update', function (values, handle) {
|
|
slider2Value.innerHTML = values[handle];
|
|
});
|
|
|
|
|
|
function setLockedValues() {
|
|
lockedValues = [
|
|
Number(slider1.noUiSlider.get()),
|
|
Number(slider2.noUiSlider.get())
|
|
];
|
|
}
|
|
|
|
slider1.noUiSlider.on('change', setLockedValues);
|
|
slider2.noUiSlider.on('change', setLockedValues);
|
|
|
|
slider1.noUiSlider.on('slide', function (values, handle) {
|
|
crossUpdate(values[handle], slider2);
|
|
});
|
|
|
|
slider2.noUiSlider.on('slide', function (values, handle) {
|
|
crossUpdate(values[handle], slider1);
|
|
});
|
|
|
|
|
|
/*********************
|
|
tooltip
|
|
**********************/
|
|
|
|
var hidingTooltipSlider = document.getElementById('slider-hide');
|
|
|
|
noUiSlider.create(hidingTooltipSlider, {
|
|
range: {
|
|
min: 0,
|
|
max: 100
|
|
},
|
|
start: [20, 80],
|
|
tooltips: true
|
|
});
|
|
|
|
|
|
/*********************
|
|
Colored Connect Elements
|
|
**********************/
|
|
|
|
var slider = document.getElementById('slider-color');
|
|
|
|
noUiSlider.create(slider, {
|
|
start: [4000, 8000, 12000, 16000],
|
|
connect: [false, true, true, true, true],
|
|
range: {
|
|
'min': [2000],
|
|
'max': [20000]
|
|
}
|
|
});
|
|
|
|
var connect = slider.querySelectorAll('.noUi-connect');
|
|
var classes = ['c-1-color', 'c-2-color', 'c-3-color', 'c-4-color', 'c-5-color'];
|
|
|
|
for (var i = 0; i < connect.length; i++) {
|
|
connect[i].classList.add(classes[i]);
|
|
}
|
|
|
|
/*********************
|
|
toggle slider
|
|
**********************/
|
|
|
|
var toggleSlider = document.getElementById('slider-toggle');
|
|
|
|
noUiSlider.create(toggleSlider, {
|
|
orientation: "vertical",
|
|
start: 0,
|
|
range: {
|
|
'min': [0, 1],
|
|
'max': 1
|
|
},
|
|
format: wNumb({
|
|
decimals: 0
|
|
})
|
|
});
|
|
|
|
toggleSlider.noUiSlider.on('update', function (values, handle) {
|
|
if (values[handle] === '1') {
|
|
toggleSlider.classList.add('off');
|
|
} else {
|
|
toggleSlider.classList.remove('off');
|
|
}
|
|
});
|
|
|
|
|
|
/*********************
|
|
Soft limits
|
|
**********************/
|
|
|
|
var softSlider = document.getElementById('soft');
|
|
|
|
noUiSlider.create(softSlider, {
|
|
start: 50,
|
|
range: {
|
|
min: 0,
|
|
max: 100
|
|
},
|
|
pips: {
|
|
mode: 'values',
|
|
values: [20, 80],
|
|
density: 4
|
|
}
|
|
});
|
|
|
|
softSlider.noUiSlider.on('change', function (values, handle) {
|
|
if (values[handle] < 20) {
|
|
softSlider.noUiSlider.set(20);
|
|
} else if (values[handle] > 80) {
|
|
softSlider.noUiSlider.set(80);
|
|
}
|
|
}); |