aboutsummaryrefslogtreecommitdiffstats
path: root/ui/jquery.ui.slider.js
diff options
context:
space:
mode:
authorRichard D. Worth <rdworth@gmail.com>2010-04-01 15:00:45 -0400
committerRichard D. Worth <rdworth@gmail.com>2010-04-01 15:00:45 -0400
commit5ffd3ab36a6c7d6c0aaad7d84c20b8d78c149a1f (patch)
tree2fa3e2a789298111e9bbfed778a58724dd3a56f9 /ui/jquery.ui.slider.js
parentab1f806293d3e5ba5f9660d64ae33ca15168c591 (diff)
downloadjquery-ui-5ffd3ab36a6c7d6c0aaad7d84c20b8d78c149a1f.tar.gz
jquery-ui-5ffd3ab36a6c7d6c0aaad7d84c20b8d78c149a1f.zip
Align slider value to step. Fixes #5471 - value not aligned to step when set programatically
Diffstat (limited to 'ui/jquery.ui.slider.js')
-rw-r--r--ui/jquery.ui.slider.js41
1 files changed, 22 insertions, 19 deletions
diff --git a/ui/jquery.ui.slider.js b/ui/jquery.ui.slider.js
index 185fe809c..dd79cb730 100644
--- a/ui/jquery.ui.slider.js
+++ b/ui/jquery.ui.slider.js
@@ -340,17 +340,9 @@ $.widget("ui.slider", $.ui.mouse, {
percentMouse = 1 - percentMouse;
var valueTotal = this._valueMax() - this._valueMin(),
- valueMouse = percentMouse * valueTotal,
- valueMouseModStep = valueMouse % this.options.step,
- normValue = this._valueMin() + valueMouse - valueMouseModStep;
-
- if (valueMouseModStep > (this.options.step / 2))
- normValue += this.options.step;
-
- // Since JavaScript has problems with large floats, round
- // the final value to 5 digits after the decimal point (see #4124)
- return parseFloat(normValue.toFixed(5));
+ valueMouse = percentMouse * valueTotal;
+ return this._trimAlignValue(valueMouse);
},
_start: function(event, index) {
@@ -440,7 +432,7 @@ $.widget("ui.slider", $.ui.mouse, {
value: function(newValue) {
if (arguments.length) {
- this.options.value = this._trimValue(newValue);
+ this.options.value = this._trimAlignValue(newValue);
this._refreshValue();
this._change(null, 0);
}
@@ -452,7 +444,7 @@ $.widget("ui.slider", $.ui.mouse, {
values: function(index, newValue) {
if (arguments.length > 1) {
- this.options.values[index] = this._trimValue(newValue);
+ this.options.values[index] = this._trimAlignValue(newValue);
this._refreshValue();
this._change(null, index);
}
@@ -461,7 +453,7 @@ $.widget("ui.slider", $.ui.mouse, {
if ($.isArray(arguments[0])) {
var vals = this.options.values, newValues = arguments[0];
for (var i = 0, l = vals.length; i < l; i++) {
- vals[i] = this._trimValue(newValues[i]);
+ vals[i] = this._trimAlignValue(newValues[i]);
this._change(null, i);
}
this._refreshValue();
@@ -528,9 +520,9 @@ $.widget("ui.slider", $.ui.mouse, {
_value: function() {
//internal value getter
- // _value() returns value trimmed by min and max
+ // _value() returns value trimmed by min and max, aligned by step
var val = this.options.value;
- val = this._trimValue(val);
+ val = this._trimAlignValue(val);
return val;
},
@@ -542,7 +534,7 @@ $.widget("ui.slider", $.ui.mouse, {
if (arguments.length) {
var val = this.options.values[index];
- val = this._trimValue(val);
+ val = this._trimAlignValue(val);
return val;
} else {
@@ -550,7 +542,7 @@ $.widget("ui.slider", $.ui.mouse, {
// this copy gets trimmed by min and max and then returned
var vals = this.options.values.slice();
for (var i = 0, l = vals.length; i < l; i++) {
- vals[i] = this._trimValue(vals[i]);
+ vals[i] = this._trimAlignValue(vals[i]);
}
return vals;
@@ -558,14 +550,25 @@ $.widget("ui.slider", $.ui.mouse, {
},
- _trimValue: function(val) {
+ // returns the step-aligned value that val is closest to, between (inclusive) min and max
+ _trimAlignValue: function(val) {
if (val < this._valueMin()) {
return this._valueMin();
}
if (val > this._valueMax()) {
return this._valueMax();
}
- return val;
+ var step = this.options.step,
+ valModStep = val % step,
+ alignValue = this._valueMin() + val - valModStep;
+
+ if (valModStep >= (step / 2)) {
+ alignValue += step;
+ }
+
+ // Since JavaScript has problems with large floats, round
+ // the final value to 5 digits after the decimal point (see #4124)
+ return parseFloat(alignValue.toFixed(5));
},
_valueMin: function() {