From bc6a28ee03ed2eb391ec839a05ced94a84debefe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Scott=20Gonz=C3=A1lez?= Date: Tue, 5 Apr 2011 21:39:02 -0400 Subject: [PATCH] Tabs: Cleaned up _tabId() implementation. --- tests/unit/tabs/tabs_deprecated.js | 41 +++++++++++++++++++----------- ui/jquery.ui.tabs.js | 9 +++---- 2 files changed, 30 insertions(+), 20 deletions(-) diff --git a/tests/unit/tabs/tabs_deprecated.js b/tests/unit/tabs/tabs_deprecated.js index 77bf645a6..c6549fd50 100644 --- a/tests/unit/tabs/tabs_deprecated.js +++ b/tests/unit/tabs/tabs_deprecated.js @@ -2,16 +2,22 @@ module("tabs (deprecated): core"); -test( "#4581 - title attribute for remote tabs does not support foreign languages", function() { - expect( 1 ); +test( "panel ids", function() { + expect( 2 ); - $( "#tabs2" ).tabs({ - selected: 3, - beforeLoad: function( event, ui ) { - event.preventDefault(); - equal( ui.panel.attr( "id" ), "∫ßáö_Սե", "proper title" ); - } + var element = $( "#tabs2" ).tabs(); + + element.one( "tabsbeforeload", function( event, ui ) { + equal( ui.panel.attr( "id" ), "∫ßáö_Սե", "from title attribute" ); + event.preventDefault(); }); + element.tabs( "option", "active", 3 ); + + element.one( "tabsbeforeload", function( event, ui ) { + ok( /^ui-tabs-\d+$/.test( ui.panel.attr( "id" ) ), "generated id" ); + event.preventDefault(); + }); + element.tabs( "option", "active", 2 ); }); module("tabs (deprecated): options"); @@ -326,14 +332,19 @@ test( "length", function() { equals( $( "#tabs2" ).tabs().tabs( "length" ), 4, "ajax tabs with missing panels" ); }); -test('url', function() { - el = $('#tabs2').tabs(); - var tab = el.find('a:eq(3)'), - url = tab.attr('href'); +test( "url", function() { + expect( 2 ); - el.tabs('url', 3, "data/test2.html"); - equals(tab.attr('href'), 'data/test2.html', 'Url was updated'); - tab.attr('href', url ); + var element = $( "#tabs2" ).tabs(), + tab = element.find( "a" ).eq( 3 ); + + element.tabs( "url", 3, "data/test2.html" ); + equals( tab.attr( "href" ), "data/test2.html", "href was updated" ); + element.one( "tabsbeforeload", function( event, ui ) { + equals( ui.ajaxSettings.url, "data/test2.html", "ajaxSettings.url" ); + event.preventDefault(); + }); + element.tabs( "option", "active", 3 ); }); }( jQuery ) ); diff --git a/ui/jquery.ui.tabs.js b/ui/jquery.ui.tabs.js index c16fe94c0..646854f49 100755 --- a/ui/jquery.ui.tabs.js +++ b/ui/jquery.ui.tabs.js @@ -128,8 +128,7 @@ $.widget( "ui.tabs", { }, _tabId: function( a ) { - return ( $( a ).attr( "aria-controls" ) || "" ) || - "ui-tabs-" + getNextTabId(); + return $( a ).attr( "aria-controls" ) || "ui-tabs-" + getNextTabId(); }, _sanitizeSelector: function( hash ) { @@ -860,7 +859,7 @@ if ( $.uiBackCompat !== false ) { }; }( jQuery, jQuery.ui.tabs.prototype ) ); - // _tabId method + // panel ids (idPrefix option + title attribute) (function( $, prototype ) { $.extend( prototype.options, { idPrefix: "ui-tabs-" @@ -868,13 +867,13 @@ if ( $.uiBackCompat !== false ) { var _tabId = prototype._tabId; prototype._tabId = function( a ) { - return ( $( a ).attr( "aria-controls" ) || "" ) || + return $( a ).attr( "aria-controls" ) || a.title && a.title.replace( /\s/g, "_" ).replace( /[^\w\u00c0-\uFFFF-]/g, "" ) || this.options.idPrefix + getNextTabId(); }; }( jQuery, jQuery.ui.tabs.prototype ) ); - // _tabId method + // _createPanel method (function( $, prototype ) { $.extend( prototype.options, { panelTemplate: "
"