Don't update the size of the floating tab bar by "resize" event from another floating box.

This the compatibility issue with Unified Sidebar.
See: https://github.com/piroor/unifiedsidebar/issues/3
This commit is contained in:
YUKI Hiroshi 2014-05-01 15:44:06 +09:00
parent 44fa7b4079
commit 9436957452

View File

@ -4738,6 +4738,27 @@ TreeStyleTabBrowser.prototype = inherit(TreeStyleTabWindow.prototype, {
var isContentResize = resizedTopFrame == this.mTabBrowser.contentWindow; var isContentResize = resizedTopFrame == this.mTabBrowser.contentWindow;
var isChromeResize = resizedTopFrame == this.window; var isChromeResize = resizedTopFrame == this.window;
if (isChromeResize && aEvent.originalTarget != resizedTopFrame) {
// ignore resizing of sub frames in "position:fixed" box
let target = aEvent.target;
try {
let node = target.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsIWebNavigation)
.QueryInterface(Ci.nsIDocShell)
.chromeEventHandler;
let root = node.ownerDocument.documentElement;
while (node && node != root) {
if (node.boxObject && !node.boxObject.parentBox) {
isChromeResize = false;
break;
}
node = node.parentNode;
}
}
catch(e) {
}
}
// Ignore events when a background tab raises to the foreground. // Ignore events when a background tab raises to the foreground.
if (isContentResize && this._lastTabbarPlaceholderSize) { if (isContentResize && this._lastTabbarPlaceholderSize) {
let newSize = this.getTabbarPlaceholderSize(); let newSize = this.getTabbarPlaceholderSize();