mirror of
https://github.com/jquery/jquery-ui.git
synced 2024-11-21 11:04:24 +00:00
277 lines
9.3 KiB
JavaScript
277 lines
9.3 KiB
JavaScript
(function( $ ) {
|
|
|
|
module( "tabs: events" );
|
|
|
|
test( "beforeActivate", function() {
|
|
expect( 38 );
|
|
|
|
var element = $( "#tabs1" ).tabs({
|
|
active: false,
|
|
collapsible: true
|
|
}),
|
|
tabs = element.find( ".ui-tabs-nav a" ),
|
|
panels = element.find( ".ui-tabs-panel" );
|
|
|
|
// from collapsed
|
|
element.one( "tabsbeforeactivate", function( event, ui ) {
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.oldTab.size(), 0, "oldTab size" );
|
|
equals( ui.oldPanel.size(), 0, "oldPanel size" );
|
|
equals( ui.newTab.size(), 1, "newTab size" );
|
|
strictEqual( ui.newTab[ 0 ], tabs[ 0 ], "newTab" );
|
|
equals( ui.newPanel.size(), 1, "newPanel size" );
|
|
strictEqual( ui.newPanel[ 0 ], panels[ 0 ], "newPanel" );
|
|
tabs_state( element, 0, 0, 0 );
|
|
});
|
|
element.tabs( "option", "active", 0 );
|
|
tabs_state( element, 1, 0, 0 );
|
|
|
|
// switching tabs
|
|
element.one( "tabsbeforeactivate", function( event, ui ) {
|
|
equals( event.originalEvent.type, "click", "originalEvent" );
|
|
equals( ui.oldTab.size(), 1, "oldTab size" );
|
|
strictEqual( ui.oldTab[ 0 ], tabs[ 0 ], "oldTab" );
|
|
equals( ui.oldPanel.size(), 1, "oldPanel size" );
|
|
strictEqual( ui.oldPanel[ 0 ], panels[ 0 ], "oldPanel" );
|
|
equals( ui.newTab.size(), 1, "newTab size" );
|
|
strictEqual( ui.newTab[ 0 ], tabs[ 1 ], "newTab" );
|
|
equals( ui.newPanel.size(), 1, "newPanel size" );
|
|
strictEqual( ui.newPanel[ 0 ], panels[ 1 ], "newPanel" );
|
|
tabs_state( element, 1, 0, 0 );
|
|
});
|
|
tabs.eq( 1 ).click();
|
|
tabs_state( element, 0, 1, 0 );
|
|
|
|
// collapsing
|
|
element.one( "tabsbeforeactivate", function( event, ui ) {
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.oldTab.size(), 1, "oldTab size" );
|
|
strictEqual( ui.oldTab[ 0 ], tabs[ 1 ], "oldTab" );
|
|
equals( ui.oldPanel.size(), 1, "oldPanel size" );
|
|
strictEqual( ui.oldPanel[ 0 ], panels[ 1 ], "oldPanel" );
|
|
equals( ui.newTab.size(), 0, "newTab size" );
|
|
equals( ui.newPanel.size(), 0, "newPanel size" );
|
|
tabs_state( element, 0, 1, 0 );
|
|
});
|
|
element.tabs( "option", "active", false );
|
|
tabs_state( element, 0, 0, 0 );
|
|
|
|
// prevent activation
|
|
element.one( "tabsbeforeactivate", function( event, ui ) {
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.oldTab.size(), 0, "oldTab size" );
|
|
equals( ui.oldPanel.size(), 0, "oldTab" );
|
|
equals( ui.newTab.size(), 1, "newTab size" );
|
|
strictEqual( ui.newTab[ 0 ], tabs[ 1 ], "newTab" );
|
|
equals( ui.newPanel.size(), 1, "newPanel size" );
|
|
strictEqual( ui.newPanel[ 0 ], panels[ 1 ], "newPanel" );
|
|
event.preventDefault();
|
|
tabs_state( element, 0, 0, 0 );
|
|
});
|
|
element.tabs( "option", "active", 1 );
|
|
tabs_state( element, 0, 0, 0 );
|
|
});
|
|
|
|
test( "activate", function() {
|
|
expect( 30 );
|
|
|
|
var element = $( "#tabs1" ).tabs({
|
|
active: false,
|
|
collapsible: true
|
|
}),
|
|
tabs = element.find( ".ui-tabs-nav a" ),
|
|
panels = element.find( ".ui-tabs-panel" );
|
|
|
|
// from collapsed
|
|
element.one( "tabsactivate", function( event, ui ) {
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.oldTab.size(), 0, "oldTab size" );
|
|
equals( ui.oldPanel.size(), 0, "oldPanel size" );
|
|
equals( ui.newTab.size(), 1, "newTab size" );
|
|
strictEqual( ui.newTab[ 0 ], tabs[ 0 ], "newTab" );
|
|
equals( ui.newPanel.size(), 1, "newPanel size" );
|
|
strictEqual( ui.newPanel[ 0 ], panels[ 0 ], "newPanel" );
|
|
tabs_state( element, 1, 0, 0 );
|
|
});
|
|
element.tabs( "option", "active", 0 );
|
|
tabs_state( element, 1, 0, 0 );
|
|
|
|
// switching tabs
|
|
element.one( "tabsactivate", function( event, ui ) {
|
|
equals( event.originalEvent.type, "click", "originalEvent" );
|
|
equals( ui.oldTab.size(), 1, "oldTab size" );
|
|
strictEqual( ui.oldTab[ 0 ], tabs[ 0 ], "oldTab" );
|
|
equals( ui.oldPanel.size(), 1, "oldPanel size" );
|
|
strictEqual( ui.oldPanel[ 0 ], panels[ 0 ], "oldPanel" );
|
|
equals( ui.newTab.size(), 1, "newTab size" );
|
|
strictEqual( ui.newTab[ 0 ], tabs[ 1 ], "newTab" );
|
|
equals( ui.newPanel.size(), 1, "newPanel size" );
|
|
strictEqual( ui.newPanel[ 0 ], panels[ 1 ], "newPanel" );
|
|
tabs_state( element, 0, 1, 0 );
|
|
});
|
|
tabs.eq( 1 ).click();
|
|
tabs_state( element, 0, 1, 0 );
|
|
|
|
// collapsing
|
|
element.one( "tabsactivate", function( event, ui ) {
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.oldTab.size(), 1, "oldTab size" );
|
|
strictEqual( ui.oldTab[ 0 ], tabs[ 1 ], "oldTab" );
|
|
equals( ui.oldPanel.size(), 1, "oldPanel size" );
|
|
strictEqual( ui.oldPanel[ 0 ], panels[ 1 ], "oldPanel" );
|
|
equals( ui.newTab.size(), 0, "newTab size" );
|
|
equals( ui.newPanel.size(), 0, "newPanel size" );
|
|
tabs_state( element, 0, 0, 0 );
|
|
});
|
|
element.tabs( "option", "active", false );
|
|
tabs_state( element, 0, 0, 0 );
|
|
|
|
// prevent activation
|
|
element.one( "tabsbeforeactivate", function( event ) {
|
|
ok( true, "tabsbeforeactivate" );
|
|
event.preventDefault();
|
|
});
|
|
element.one( "tabsactivate", function() {
|
|
ok( false, "tabsactivate" );
|
|
});
|
|
element.tabs( "option", "active", 1 );
|
|
});
|
|
|
|
test( "beforeLoad", function() {
|
|
expect( 32 );
|
|
|
|
var tab, panelId, panel,
|
|
element = $( "#tabs2" );
|
|
|
|
// init
|
|
element.one( "tabsbeforeload", function( event, ui ) {
|
|
tab = element.find( ".ui-tabs-nav a" ).eq( 2 );
|
|
panelId = tab.attr( "aria-controls" );
|
|
panel = $( "#" + panelId );
|
|
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
ok( "abort" in ui.jqXHR, "jqXHR" );
|
|
ok( ui.ajaxSettings.url, "data/test.html", "ajaxSettings.url" );
|
|
equals( ui.tab.size(), 1, "tab size" );
|
|
strictEqual( ui.tab[ 0 ], tab[ 0 ], "tab" );
|
|
equals( ui.panel.size(), 1, "panel size" );
|
|
strictEqual( ui.panel[ 0 ], panel[ 0 ], "panel" );
|
|
equals( ui.panel.html(), "", "panel html" );
|
|
event.preventDefault();
|
|
tabs_state( element, 0, 0, 1, 0, 0 );
|
|
});
|
|
element.tabs({ active: 2 });
|
|
tabs_state( element, 0, 0, 1, 0, 0 );
|
|
equals( panel.html(), "", "panel html after" );
|
|
element.tabs( "destroy" );
|
|
|
|
// .option()
|
|
element.one( "tabsbeforeload", function( event, ui ) {
|
|
tab = element.find( ".ui-tabs-nav a" ).eq( 2 );
|
|
panelId = tab.attr( "aria-controls" );
|
|
panel = $( "#" + panelId );
|
|
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
ok( "abort" in ui.jqXHR, "jqXHR" );
|
|
ok( ui.ajaxSettings.url, "data/test.html", "ajaxSettings.url" );
|
|
equals( ui.tab.size(), 1, "tab size" );
|
|
strictEqual( ui.tab[ 0 ], tab[ 0 ], "tab" );
|
|
equals( ui.panel.size(), 1, "panel size" );
|
|
strictEqual( ui.panel[ 0 ], panel[ 0 ], "panel" );
|
|
equals( ui.panel.html(), "", "panel html" );
|
|
event.preventDefault();
|
|
tabs_state( element, 1, 0, 0, 0, 0 );
|
|
});
|
|
element.tabs();
|
|
element.tabs( "option", "active", 2 );
|
|
tabs_state( element, 0, 0, 1, 0, 0 );
|
|
equals( panel.html(), "", "panel html after" );
|
|
|
|
// click, change panel content
|
|
element.one( "tabsbeforeload", function( event, ui ) {
|
|
tab = element.find( ".ui-tabs-nav a" ).eq( 3 );
|
|
panelId = tab.attr( "aria-controls" );
|
|
panel = $( "#" + panelId );
|
|
|
|
equals( event.originalEvent.type, "click", "originalEvent" );
|
|
ok( "abort" in ui.jqXHR, "jqXHR" );
|
|
ok( ui.ajaxSettings.url, "data/test.html", "ajaxSettings.url" );
|
|
equals( ui.tab.size(), 1, "tab size" );
|
|
strictEqual( ui.tab[ 0 ], tab[ 0 ], "tab" );
|
|
equals( ui.panel.size(), 1, "panel size" );
|
|
strictEqual( ui.panel[ 0 ], panel[ 0 ], "panel" );
|
|
ui.panel.html( "<p>testing</p>" );
|
|
event.preventDefault();
|
|
tabs_state( element, 0, 0, 1, 0, 0 );
|
|
});
|
|
element.find( ".ui-tabs-nav a" ).eq( 3 ).click();
|
|
tabs_state( element, 0, 0, 0, 1, 0 );
|
|
equals( panel.html(), "<p>testing</p>", "panel html after" );
|
|
});
|
|
|
|
if ( $.uiBackCompat === false ) {
|
|
asyncTest( "load", function() {
|
|
expect( 21 );
|
|
|
|
var tab, panelId, panel,
|
|
element = $( "#tabs2" );
|
|
|
|
// init
|
|
element.one( "tabsload", function( event, ui ) {
|
|
tab = element.find( ".ui-tabs-nav a" ).eq( 2 );
|
|
panelId = tab.attr( "aria-controls" );
|
|
panel = $( "#" + panelId );
|
|
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.tab.size(), 1, "tab size" );
|
|
strictEqual( ui.tab[ 0 ], tab[ 0 ], "tab" );
|
|
equals( ui.panel.size(), 1, "panel size" );
|
|
strictEqual( ui.panel[ 0 ], panel[ 0 ], "panel" );
|
|
equals( ui.panel.find( "p" ).length, 1, "panel html" );
|
|
tabs_state( element, 0, 0, 1, 0, 0 );
|
|
tabsload1();
|
|
});
|
|
element.tabs({ active: 2 });
|
|
|
|
function tabsload1() {
|
|
// .option()
|
|
element.one( "tabsload", function( event, ui ) {
|
|
tab = element.find( ".ui-tabs-nav a" ).eq( 3 );
|
|
panelId = tab.attr( "aria-controls" );
|
|
panel = $( "#" + panelId );
|
|
|
|
ok( !( "originalEvent" in event ), "originalEvent" );
|
|
equals( ui.tab.size(), 1, "tab size" );
|
|
strictEqual( ui.tab[ 0 ], tab[ 0 ], "tab" );
|
|
equals( ui.panel.size(), 1, "panel size" );
|
|
strictEqual( ui.panel[ 0 ], panel[ 0 ], "panel" );
|
|
equals( ui.panel.find( "p" ).length, 1, "panel html" );
|
|
tabs_state( element, 0, 0, 0, 1, 0 );
|
|
tabsload2();
|
|
});
|
|
element.tabs( "option", "active", 3 );
|
|
}
|
|
|
|
function tabsload2() {
|
|
// click, change panel content
|
|
element.one( "tabsload", function( event, ui ) {
|
|
tab = element.find( ".ui-tabs-nav a" ).eq( 4 );
|
|
panelId = tab.attr( "aria-controls" );
|
|
panel = $( "#" + panelId );
|
|
|
|
equals( event.originalEvent.type, "click", "originalEvent" );
|
|
equals( ui.tab.size(), 1, "tab size" );
|
|
strictEqual( ui.tab[ 0 ], tab[ 0 ], "tab" );
|
|
equals( ui.panel.size(), 1, "panel size" );
|
|
strictEqual( ui.panel[ 0 ], panel[ 0 ], "panel" );
|
|
equals( ui.panel.find( "p" ).length, 1, "panel html" );
|
|
tabs_state( element, 0, 0, 0, 0, 1 );
|
|
start();
|
|
});
|
|
element.find( ".ui-tabs-nav a" ).eq( 4 ).click();
|
|
}
|
|
});
|
|
}
|
|
|
|
}( jQuery ) );
|