diff options
author | Scott González <scott.gonzalez@gmail.com> | 2011-08-06 15:32:19 -0400 |
---|---|---|
committer | Scott González <scott.gonzalez@gmail.com> | 2011-08-06 15:32:19 -0400 |
commit | 2b22bbdd6a5ed5206f90c29ab4bfc9d9a84b6835 (patch) | |
tree | 8126365d7edd0f1fb4bbf6add51a0c921e849408 | |
parent | 08a7a11a1b02ca33cb27cdde7cef0491f3a5e641 (diff) | |
download | jquery-ui-2b22bbdd6a5ed5206f90c29ab4bfc9d9a84b6835.tar.gz jquery-ui-2b22bbdd6a5ed5206f90c29ab4bfc9d9a84b6835.zip |
Spinner: Only trigger change when the field has blurred and the value has changed.
-rw-r--r-- | tests/unit/spinner/spinner_events.js | 1 | ||||
-rw-r--r-- | ui/jquery.ui.spinner.js | 41 |
2 files changed, 15 insertions, 27 deletions
diff --git a/tests/unit/spinner/spinner_events.js b/tests/unit/spinner/spinner_events.js index c0771ca2f..0f64067d7 100644 --- a/tests/unit/spinner/spinner_events.js +++ b/tests/unit/spinner/spinner_events.js @@ -57,6 +57,7 @@ test("change", function() { });
simulateKeyDownUp(el, $.ui.keyCode.UP);
+ el.blur();
equals(change, 1, "Change triggered");
});
diff --git a/ui/jquery.ui.spinner.js b/ui/jquery.ui.spinner.js index da140308e..b090c6122 100644 --- a/ui/jquery.ui.spinner.js +++ b/ui/jquery.ui.spinner.js @@ -72,14 +72,10 @@ $.widget( "ui.spinner", { event.preventDefault(); } }, - keyup: function( event ) { - if ( this.spinning ) { - this._stop( event ); - this._change( event ); - } - }, + keyup: "_stop", focus: function() { uiSpinner.addClass( "ui-state-active" ); + this.previous = this.options.value; }, blur: function( event ) { // don't clear invalid values on blur @@ -90,6 +86,9 @@ $.widget( "ui.spinner", { this.element.val( value ); } uiSpinner.removeClass( "ui-state-active" ); + if ( this.previous !== this.options.value ) { + this._trigger( "change", event ); + } } }); @@ -112,13 +111,7 @@ $.widget( "ui.spinner", { this._repeat( null, $( event.currentTarget ).hasClass( "ui-spinner-up" ) ? 1 : -1, event ); }, - mouseup: function( event ) { - if ( this.spinning ) { - this._stop( event ); - // TODO: don't trigger change until the field is blurred - this._change( event ); - } - }, + mouseup: "_stop", mouseenter: function( event ) { // button will add ui-state-active if mouse was down while mouseleave and kept down if ( !$( event.currentTarget ).hasClass( "ui-state-active" ) ) { @@ -133,12 +126,7 @@ $.widget( "ui.spinner", { // TODO: do we really want to consider this a stop? // shouldn't we just stop the repeater and wait until mouseup before // we trigger the stop event? - mouseleave: function( event ) { - if ( this.spinning ) { - this._stop( event ); - this._change( event ); - } - } + mouseleave: "_stop" }); // disable spinner if element was already disabled @@ -186,12 +174,10 @@ $.widget( "ui.spinner", { } this._spin( (delta > 0 ? 1 : -1) * this.options.step, event ); - clearTimeout( this.timeout ); - this.timeout = setTimeout(function() { + clearTimeout( this.mousewheelTimer ); + this.mousewheelTimer = setTimeout(function() { if ( this.spinning ) { this._stop( event ); - // TODO: don't trigger change until the field is blurred - this._change( event ); } }, 100 ); event.preventDefault(); @@ -276,16 +262,17 @@ $.widget( "ui.spinner", { }, _stop: function( event ) { + if ( !this.spinning ) { + return; + } + clearTimeout( this.timer ); + clearTimeout( this.mousewheelTimer ); this.counter = 0; this.spinning = false; this._trigger( "stop", event ); }, - _change: function( event ) { - this._trigger( "change", event ); - }, - _setOption: function( key, value ) { if ( key === "value") { value = this._trimValue( this._parse(value) ); |