aboutsummaryrefslogtreecommitdiffstats
path: root/ui/ui.tabs.js
diff options
context:
space:
mode:
authorKlaus Hartl <klaus.hartl@googlemail.com>2009-02-13 23:05:16 +0000
committerKlaus Hartl <klaus.hartl@googlemail.com>2009-02-13 23:05:16 +0000
commitf3feb25712092f455b24476b2f0528c2901f357f (patch)
tree00171f0d0f0c2ff0cf2fb73835f3b87d818d72a7 /ui/ui.tabs.js
parent82d7c67bd345fe5e47ff9e9f28656daab7acf776 (diff)
downloadjquery-ui-f3feb25712092f455b24476b2f0528c2901f357f.tar.gz
jquery-ui-f3feb25712092f455b24476b2f0528c2901f357f.zip
Tabs: mouseover/focus handling for added tabs, plus test, fixes #4097 as well as focus/blur handling when using keyboard
Diffstat (limited to 'ui/ui.tabs.js')
-rw-r--r--ui/ui.tabs.js36
1 files changed, 19 insertions, 17 deletions
diff --git a/ui/ui.tabs.js b/ui/ui.tabs.js
index 0938a9204..51a818b43 100644
--- a/ui/ui.tabs.js
+++ b/ui/ui.tabs.js
@@ -172,20 +172,6 @@ $.widget("ui.tabs", {
else onShow();
}
- // states
- if (o.event != 'mouseover') {
- var handleState = function(state, el) {
- if (el.is(':not(.ui-state-disabled)')) el.toggleClass('ui-state-' + state);
- };
- this.$lis.bind('mouseover.tabs mouseout.tabs', function() {
- handleState('hover', $(this));
- });
- // TODO focus/blur don't seem to work with namespace
- this.$tabs.bind('focus.tabs blur.tabs', function() {
- handleState('focus', $(this).parents('li:first'));
- });
- }
-
// clean up to avoid memory leaks in certain versions of IE 6
$(window).bind('unload', function() {
self.$lis.add(self.$tabs).unbind('.tabs');
@@ -194,9 +180,10 @@ $.widget("ui.tabs", {
}
// update selected after add/remove
- else
+ else {
o.selected = this.$lis.index(this.$lis.filter('.ui-tabs-selected'));
-
+ }
+
// update collapsible
this.element[o.collapsible ? 'addClass' : 'removeClass']('ui-tabs-collapsible');
@@ -210,6 +197,21 @@ $.widget("ui.tabs", {
// reset cache if switching from cached to not cached
if (o.cache === false) this.$tabs.removeData('cache.tabs');
+ // remove all handlers before, tabify may run on existing tabs after add or option change
+ this.$lis.add(this.$tabs).unbind('.tabs');
+
+ if (o.event != 'mouseover') {
+ var handleState = function(state, el) {
+ if (el.is(':not(.ui-state-disabled)')) el.toggleClass('ui-state-' + state);
+ };
+ this.$lis.bind('mouseover.tabs mouseout.tabs', function() {
+ handleState('hover', $(this));
+ });
+ this.$tabs.bind('focus.tabs blur.tabs', function() {
+ handleState('focus', $(this).parents('li:first'));
+ });
+ }
+
// set up animations
var hideFx, showFx;
if (o.fx) {
@@ -264,7 +266,7 @@ $.widget("ui.tabs", {
}
// attach tab event handler, unbind to avoid duplicates from former tabifying...
- this.$tabs.unbind('.tabs').bind(o.event + '.tabs', function() {
+ this.$tabs.bind(o.event + '.tabs', function() {
var $li = $(this).parents('li:eq(0)'),
$hide = self.$panels.filter(':visible'),
$show = $(self._sanitizeSelector(this.hash));