Skip to content

Commit 92bcb25

Browse files
committed
Tabs: Fixed back-compat for selected option. Fixes #7135 - Tabs: Rename selected option to active.
1 parent 45c727d commit 92bcb25

File tree

2 files changed

+51
-47
lines changed

2 files changed

+51
-47
lines changed

tests/unit/tabs/tabs_deprecated.js

Lines changed: 43 additions & 35 deletions
Original file line numberDiff line numberDiff line change
@@ -107,49 +107,57 @@ test('spinner', function() {
107107
});
108108
});
109109

110-
test('selected', function() {
111-
expect(10);
110+
test( "selected", function() {
111+
expect( 19 );
112112

113-
el = $('#tabs1').tabs();
114-
equals(el.tabs('option', 'selected'), 0, 'should be 0 by default');
113+
var element = $( "#tabs1" ).tabs();
114+
equals( element.tabs( "option", "selected" ), 0, "should be 0 by default" );
115+
tabs_state( element, 1, 0, 0 );
116+
element.tabs( "destroy" );
115117

116-
el.tabs('destroy');
117-
//set a hash in the url
118-
location.hash = '#fragment-2';
119-
//selection of tab with divs ordered differently than list
120-
el = $('#tabs1').tabs();
121-
equals(el.tabs('option', 'selected'), 1, 'second tab should be selected');
118+
location.hash = "#fragment-3";
119+
element = $( "#tabs1" ).tabs();
120+
equals( element.tabs( "option", "selected" ), 2, "should be 2 based on URL" );
121+
tabs_state( element, 0, 0, 1 );
122+
element.tabs( "destroy" );
122123

123-
el.tabs('destroy');
124-
//set a hash in the url
125-
location.hash = '#tabs7-2';
126-
//selection of tab with divs ordered differently than list
127-
el = $('#tabs7').tabs();
128-
equals(el.tabs('option', 'selected'), 1, 'second tab should be selected');
124+
el = $('#tabs1').tabs({
125+
selected: -1,
126+
collapsible: true
127+
});
128+
tabs_state( element, 0, 0, 0 );
129+
equal( element.find( ".ui-tabs-nav .ui-state-active" ).size(), 0, "no tabs selected" );
130+
strictEqual( element.tabs( "option", "selected" ), -1 );
129131

130-
el.tabs('destroy');
131-
el = $('#tabs1').tabs({ selected: -1 });
132-
equals(el.tabs('option', 'selected'), -1, 'should be -1 for all tabs unselected');
133-
equals( $('li.ui-tabs-active', el).length, 0, 'no tab should be selected' );
134-
equals( $('div:hidden', '#tabs1').length, 3, 'all panels should be hidden' );
132+
element.tabs( "option", "collapsible", false );
133+
tabs_state( element, 1, 0, 0 );
134+
equal( element.tabs( "option", "selected" ), 0 );
135+
element.tabs( "destroy" );
135136

136-
el.tabs('destroy');
137-
el.tabs({ selected: 1 });
138-
equals(el.tabs('option', 'selected'), 1, 'should be specified tab');
137+
element.tabs({
138+
selected: -1
139+
});
140+
tabs_state( element, 1, 0, 0 );
141+
strictEqual( element.tabs( "option", "selected" ), 0 );
142+
element.tabs( "destroy" );
139143

140-
el.tabs('destroy');
141-
el.tabs({ selected: 99 });
142-
equals(el.tabs('option', 'selected'), 0, 'selected should default to zero if given value is out of index');
144+
element.tabs({ selected: 2 });
145+
equals( element.tabs( "option", "selected" ), 2 );
146+
tabs_state( element, 0, 0, 1 );
143147

144-
el.tabs('destroy');
145-
el.tabs({ collapsible: true });
146-
el.tabs('option', 'selected', 0);
147-
equals(el.tabs('option', 'selected'), 0, 'should not collapse tab if value is same as selected');
148+
element.tabs( "option", "selected", 0 );
149+
equals( element.tabs( "option", "selected" ), 0 );
150+
tabs_state( element, 1, 0, 0 );
148151

149-
el.tabs('destroy');
150-
el = $('#tabs1').tabs();
151-
el.tabs('select', 1);
152-
equals(el.tabs('option', 'selected'), 1, 'should select tab');
152+
element.find( ".ui-tabs-nav a" ).eq( 1 ).click();
153+
equals( element.tabs( "option", "selected" ), 1 );
154+
tabs_state( element, 0, 1, 0 );
155+
156+
element.tabs( "option", "selected", 10 );
157+
equals( element.tabs( "option", "selected" ), 1 );
158+
tabs_state( element, 0, 1, 0 );
159+
160+
location.hash = "#";
153161
});
154162

155163
module( "tabs (deprecated): events" );

ui/jquery.ui.tabs.js

Lines changed: 8 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -948,19 +948,15 @@ if ( $.uiBackCompat !== false ) {
948948
};
949949

950950
prototype._setOption = function( key, value ) {
951-
var options = this.options;
952-
if ( key === "selected" ) {
953-
key = "active";
951+
if ( key !== "selected" ) {
952+
return _setOption.apply( this, arguments );
954953
}
955-
_setOption.apply( this, arguments );
956-
if ( key === "active" ) {
957-
if ( key === - 1 ) {
958-
key = false;
959-
}
960-
options.selected = options.active;
961-
if ( options.selected === false ) {
962-
options.selected = -1;
963-
}
954+
955+
var options = this.options;
956+
_setOption.call( this, "active", value === -1 ? false : value );
957+
options.selected = options.active;
958+
if ( options.selected === false ) {
959+
options.selected = -1;
964960
}
965961
};
966962

0 commit comments

Comments
 (0)