When the system is too slow on TabOpen event (by Informational Tab or some addons), the tab bar failed to be scrolled to the newly opened tab.

This commit is contained in:
Piro / SHIMODA Hiroshi 2012-01-28 04:33:02 +09:00
parent 9608f76989
commit 43b22f1e22

View File

@ -2564,14 +2564,17 @@ TreeStyleTabBrowser.prototype = {
if (this.animationEnabled) {
this.updateTabCollapsed(tab, true, true);
this.updateTabCollapsed(tab, false, this.windowService.restoringTree);
let self = this;
this.updateTabCollapsed(tab, false, this.windowService.restoringTree, function() {
self.scrollToNewTab(tab);
});
}
else {
this.scrollToNewTab(tab);
}
this.updateInsertionPositionInfo(tab);
if (this.scrollToNewTabMode > 0)
this.scrollToTab(tab, this.scrollToNewTabMode < 2);
if (this.getPref('browser.tabs.autoHide'))
this.updateFloatingTabbar(this.kTABBAR_UPDATE_BY_SHOWHIDE_TABBAR);
@ -2599,6 +2602,12 @@ TreeStyleTabBrowser.prototype = {
_addedCountClearTimer : null,
_checkRestoringWindowTimerOnTabAdded : null,
scrollToNewTab : function TSTBrowser_scrollToNewTab(aTab)
{
if (this.scrollToNewTabMode > 0)
this.scrollToTab(aTab, this.scrollToNewTabMode < 2);
},
updateInsertionPositionInfo : function TSTBrowser_updateInsertionPositionInfo(aTab)
{
var prev = this.getPreviousSiblingTab(aTab);
@ -5283,7 +5292,7 @@ TreeStyleTabBrowser.prototype = {
}, this);
}
},
updateTabCollapsed : function TSTBrowser_updateTabCollapsed(aTab, aCollapsed, aJustNow)
updateTabCollapsed : function TSTBrowser_updateTabCollapsed(aTab, aCollapsed, aJustNow, aCallbackToRunOnStartAnimation)
{
this.stopTabCollapseAnimation(aTab);
@ -5358,6 +5367,9 @@ TreeStyleTabBrowser.prototype = {
aTab.style.removeProperty(this.collapseCSSProp);
aTab.style.removeProperty('opacity');
}
if (aCallbackToRunOnStartAnimation)
aCallbackToRunOnStartAnimation();
return;
}
@ -5376,10 +5388,14 @@ TreeStyleTabBrowser.prototype = {
var self = this;
var firstFrame = true;
aTab.__treestyletab__updateTabCollapsedTask = function(aTime, aBeginning, aChange, aDuration) {
if (firstFrame && CSSTransitionEnabled) {
if (firstFrame) {
if (aCallbackToRunOnStartAnimation)
aCallbackToRunOnStartAnimation();
if (CSSTransitionEnabled) {
aTab.style.setProperty(self.collapseCSSProp, endMargin ? '-'+endMargin+'px' : '', 'important');
aTab.style.setProperty('opacity', endOpacity == 1 ? '' : endOpacity, 'important');
}
}
firstFrame = false;
// If this is the last tab, negative scroll happens.
// Then, we shouldn't do animation.