-
Notifications
You must be signed in to change notification settings - Fork 18
Slider Widget v7
- status : complete
- version : 7.x
The slider widget as a real-effort task (type=volume).
The Slider widget creates a customizable slider.
- mainText: a text to be displayed above the slider.
- hint: an extra informative text, after the main text.
- type: the type of slider: "flat", "volume" (default).
- min: the minimum (left-most) value of the slider. Default: 0.
- max: the maximum (tight-most) value of the slider. Default: 100.
- initialValue: the initial position of the slider, or "random" for a random position. Default: 50.
- correctValue: if set, this value is used to determined whether the final position of the slider is correct. Default: null
- displayValue: if TRUE, the current numeric value of the slider is displayed. Default: TRUE.
- displayNoChange: if TRUE, a checkbox for "no change" is added; when pressed the slider is reset to the initial value. Default: TRUE.
- required: if TRUE, it is marked as a required choice.
- onmove: a callback function executed at every move. See usecase for details.
- className: the className of the widget (string or array), or false to have none.
- required: If TRUE, slider movement is required, and the correct value ( if set) must match the current value.
- currentValue: Formats the display of the current value. Default:
function(widget, value) {
return 'Value: ' + value;
}
- nochange: The label for the noChange checkbox. Default: 'No change'.
{
value: 69,
noChange: true,
initialValue: 10,
isCorrect: true, // if correctValue is set value must match it
totalMove: 245, // the amount of moves in absolute value,
time: 3000 // since beginning of step.
}
Even when custom min and max options are set, the return value is always between 0 and 100. In this example:
{
name: 'Slider',
id: 'confidence',
mainText: 'How confident are you in your answer?',
min: 50,
max: 100,
step: 5,
initialValue: 50,
}
the slider has in total 10 units: (100-50)/5. As the slider goes always from 0 to 100, each unit is valued 10.
When the slider is completely to the left, the display is 50, and the value is 0. If the slider moves one unit to the right, the display is 55, and the return value is 10, the next displayed value is 60, and the next returned value is 20, and so on.
var root = document.body;
var slider = node.widgets.append('Slider', root, {
id: 'myslider',
initialValue: 25,
correctValue 89,
displayValue: false,
mainText: 'Move the slider to position 89',
hint: 'Be precise!',
required: true,
onmove: function(value, diff) {
console.log('Slider moved to ' + value + ' from ' + (value - diff));
}
});
// Replacing the default texts: numeric value is replaced with a label.
var slider2 = node.widgets.append('Slider', root, {
id: 'myslider2',
min: 1,
max 7,
mainText: 'How do you feel?',
texts: {
currentValue: function(widget, value) {
let mood = [
'Terrible!', 'Bad', 'Could be better',
'Normal',
'Not bad', 'Good', 'Great!'
];
return mood[(value-1)];
}
}
});
Go back to the wiki Home.
Copyright (C) 2021 Stefano Balietti
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.