Merge pull request #3494 from dnadesign/tabForceActive

fixing issue where 'ss-tabs-force-active' wasn't actually working
This commit is contained in:
Damian Mooyman 2016-03-21 16:53:49 +13:00
commit 94b0f61957

View File

@ -816,26 +816,36 @@ jQuery.noConflict();
sessionStates = sessionData ? JSON.parse(sessionData) : false; sessionStates = sessionData ? JSON.parse(sessionData) : false;
this.find('.cms-tabset, .ss-tabset').each(function() { this.find('.cms-tabset, .ss-tabset').each(function() {
var index, tabset = $(this), tabsetId = tabset.attr('id'), tab, var index,
forcedTab = tabset.find('.ss-tabs-force-active'); tabset = $(this),
tabsetId = tabset.attr('id'),
tab,
forcedTab = tabset.children('ul').children('li.ss-tabs-force-active');
if(!tabset.data('tabs')) return; // don't act on uninit'ed controls if(!tabset.data('tabs')) return; // don't act on uninit'ed controls
// The tabs may have changed, notify the widget that it should update its internal state. // The tabs may have changed, notify the widget that it should update its internal state.
tabset.tabs('refresh'); tabset.tabs('refresh');
// Make sure the intended tab is selected. // Make sure the intended tab is selected. Only force the tab on the correct tabset though
if(forcedTab.length) { if(forcedTab.length) {
index = forcedTab.index(); index = forcedTab.first().index();
} else if(overrideStates && overrideStates[tabsetId]) { } else if(overrideStates && overrideStates[tabsetId]) {
tab = tabset.find(overrideStates[tabsetId].tabSelector); tab = tabset.find(overrideStates[tabsetId].tabSelector);
if(tab.length) index = tab.index(); if(tab.length) index = tab.index();
} else if(sessionStates) { } else if(sessionStates) {
$.each(sessionStates, function(i, sessionState) { $.each(sessionStates, function(i, state) {
if(tabset.is('#' + sessionState.id)) index = sessionState.selected; if(tabsetId == state.id) {
}); tabset.tabs('select', state.selected);
} }
if(index !== null) tabset.tabs('select', index); });
index = null;
}
if(index !== null) {
tabset.tabs('select', index);
}
}); });
}, },