aboutsummaryrefslogtreecommitdiffstats
path: root/ui/jquery.ui.tabs.js
diff options
context:
space:
mode:
authorScott González <scott.gonzalez@gmail.com>2011-04-04 15:28:33 -0400
committerScott González <scott.gonzalez@gmail.com>2011-04-04 15:28:33 -0400
commit1fc91f90d0dea2bbc6c84bfa994e21d120391782 (patch)
tree8f36fc73aba527e2b88153070fa83ee94fc3a96f /ui/jquery.ui.tabs.js
parent316d0af8fb05180c72aeb489ab99fdfa6f2f127e (diff)
downloadjquery-ui-1fc91f90d0dea2bbc6c84bfa994e21d120391782.tar.gz
jquery-ui-1fc91f90d0dea2bbc6c84bfa994e21d120391782.zip
Tabs: Pass appropriate data for activate event. Fixes #7137 - Tabs: Rename show event to activate.
Diffstat (limited to 'ui/jquery.ui.tabs.js')
-rwxr-xr-xui/jquery.ui.tabs.js68
1 files changed, 39 insertions, 29 deletions
diff --git a/ui/jquery.ui.tabs.js b/ui/jquery.ui.tabs.js
index 99c561607..7544d0302 100755
--- a/ui/jquery.ui.tabs.js
+++ b/ui/jquery.ui.tabs.js
@@ -98,6 +98,7 @@ $.widget( "ui.tabs", {
this.lis.eq( o.active ).addClass( "ui-tabs-active ui-state-active" );
+ // TODO: we need to remove this or add it to accordion
// seems to be expected behavior that the activate callback is fired
self.element.queue( "tabs", function() {
self._trigger( "activate", null, self._ui( self.active[ 0 ], panel[ 0 ] ) );
@@ -278,40 +279,49 @@ $.widget( "ui.tabs", {
}
},
- _showTab: function( clicked, show, event ) {
- var self = this;
+ _showTab: function( event, eventData ) {
+ var that = this;
- $( clicked ).closest( "li" ).addClass( "ui-tabs-active ui-state-active" );
+ $( eventData.newTab ).closest( "li" ).addClass( "ui-tabs-active ui-state-active" );
- if ( this.showFx ) {
- self.running = true;
- show.hide()
- .animate( showFx, showFx.duration || "normal", function() {
- self._resetStyle( show, showFx );
- self.running = false;
- self._trigger( "activate", event, self._ui( clicked, show[ 0 ] ) );
+ if ( that.showFx ) {
+ that.running = true;
+ eventData.newPanel
+ // TODO: why are we hiding? old code?
+ .hide()
+ .animate( that.showFx, that.showFx.duration || "normal", function() {
+ that._resetStyle( $( this ), that.showFx );
+ that.running = false;
+ that._trigger( "activate", event, eventData );
});
} else {
- show.show();
- self._trigger( "activate", event, self._ui( clicked, show[ 0 ] ) );
+ eventData.newPanel.show();
+ that._trigger( "activate", event, eventData );
}
},
- _hideTab: function( clicked, $hide ) {
- var self = this;
-
- if ( this.hideFx ) {
- self.running = true;
- $hide.animate( hideFx, hideFx.duration || "normal", function() {
- self.running = false;
- self.lis.removeClass( "ui-tabs-active ui-state-active" );
- self._resetStyle( $hide, hideFx );
- self.element.dequeue( "tabs" );
+ // TODO: combine with _showTab()
+ _hideTab: function( event, eventData ) {
+ var that = this;
+
+ if ( that.hideFx ) {
+ that.running = true;
+ eventData.oldPanel.animate( that.hideFx, that.hideFx.duration || "normal", function() {
+ that.running = false;
+ eventData.oldTab.closest( "li" ).removeClass( "ui-tabs-active ui-state-active" );
+ that._resetStyle( $( this ), that.hideFx );
+ that.element.dequeue( "tabs" );
+ if ( !eventData.newPanel.length ) {
+ that._trigger( "activate", event, eventData );
+ }
});
} else {
- self.lis.removeClass( "ui-tabs-active ui-state-active" );
- $hide.hide();
- self.element.dequeue( "tabs" );
+ eventData.oldTab.closest( "li" ).removeClass( "ui-tabs-active ui-state-active" );
+ eventData.oldPanel.hide();
+ that.element.dequeue( "tabs" );
+ if ( !eventData.newPanel.length ) {
+ that._trigger( "activate", event, eventData );
+ }
}
},
@@ -375,14 +385,14 @@ $.widget( "ui.tabs", {
options.active = false;
that.element.queue( "tabs", function() {
- that._hideTab( clicked, toHide );
+ that._hideTab( event, eventData );
}).dequeue( "tabs" );
clicked[ 0 ].blur();
return;
} else if ( !toHide.length ) {
that.element.queue( "tabs", function() {
- that._showTab( clicked, toShow, event );
+ that._showTab( event, eventData );
});
// TODO make passing in node possible, see also http://dev.jqueryui.com/ticket/3171
@@ -397,11 +407,11 @@ $.widget( "ui.tabs", {
if ( toShow.length ) {
if ( toHide.length ) {
that.element.queue( "tabs", function() {
- that._hideTab( clicked, toHide );
+ that._hideTab( event, eventData );
});
}
that.element.queue( "tabs", function() {
- that._showTab( clicked, toShow, event );
+ that._showTab( event, eventData );
});
that.load( that.anchors.index( clicked ) );