タブバーの位置をウィンドウごとに変えられるようにした
git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@6665 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
parent
aa93d5e250
commit
c2a9430084
@ -208,7 +208,7 @@ TreeStyleTabService.overrideExtensionsPreInit = function TSTService_overrideExte
|
||||
if (!(aFunc in window)) return;
|
||||
eval('window.'+aFunc+' = '+window[aFunc].toSource().replace(
|
||||
/FS_data.mTabs.(removeAttribute\("moz-collapsed"\)|setAttribute\("moz-collapsed", "true"\));/g,
|
||||
'if (gBrowser.getAttribute(TreeStyleTabService.kTABBAR_POSITION) == "top") { $& }'
|
||||
'if (gBrowser.treeStyleTab.currentTabbarPosition == "top") { $& }'
|
||||
));
|
||||
}, this);
|
||||
}
|
||||
@ -879,7 +879,7 @@ TreeStyleTabService.overrideExtensionsOnInitAfter = function TSTService_override
|
||||
if (!aEvent.shown) {
|
||||
if (
|
||||
autoHIDE.statBar &&
|
||||
gBrowser.getAttribute(gBrowser.treeStyleTab.kTABBAR_POSITION) == 'bottom' &&
|
||||
gBrowser.treeStyleTab.currentTabbarPosition == 'bottom' &&
|
||||
!gBrowser.treeStyleTab.getPref('extensions.autohide.bars.statBar.always') &&
|
||||
gBrowser.treeStyleTab.getPref('extensions.autohide.bars.statBar')
|
||||
) {
|
||||
@ -890,7 +890,7 @@ TreeStyleTabService.overrideExtensionsOnInitAfter = function TSTService_override
|
||||
TreeStyleTabService.getTabStrip(gBrowser).removeAttribute('ahHIDE');
|
||||
if (
|
||||
autoHIDE.statBar &&
|
||||
aTabBrowser.getAttribute(gBrowser.treeStyleTab.kTABBAR_POSITION) == 'bottom' &&
|
||||
aTabBrowser.treeStyleTab.currentTabbarPosition == 'bottom' &&
|
||||
!aTabBrowser.treeStyleTab.getPref('extensions.autohide.bars.statBar.always') &&
|
||||
aTabBrowser.treeStyleTab.getPref('extensions.autohide.bars.statBar')
|
||||
) {
|
||||
@ -901,7 +901,7 @@ TreeStyleTabService.overrideExtensionsOnInitAfter = function TSTService_override
|
||||
|
||||
case 'fullscreen':
|
||||
var treeStyleTab = gBrowser.treeStyleTab;
|
||||
if (gBrowser.getAttribute(treeStyleTab.kTABBAR_POSITION) != 'top') {
|
||||
if (gBrowser.treeStyleTab.currentTabbarPosition != 'top') {
|
||||
if (window.fullScreen)
|
||||
treeStyleTab.autoHide.endForFullScreen();
|
||||
else
|
||||
|
@ -9,7 +9,8 @@ var TreeStyleTabService = {
|
||||
|
||||
get currentTabbarPosition() /* PUBLIC API */
|
||||
{
|
||||
return this.utils.currentTabbarPosition;
|
||||
return this.browser.getAttribute(this.kTABBAR_POSITION) ||
|
||||
this.utils.currentTabbarPosition;
|
||||
},
|
||||
set currentTabbarPosition(aValue)
|
||||
{
|
||||
@ -61,6 +62,12 @@ var TreeStyleTabService = {
|
||||
return this.utils.useTMPSessionAPI = aValue;
|
||||
},
|
||||
|
||||
get browser()
|
||||
{
|
||||
return 'SplitBrowser' in window ? window.SplitBrowser.activeBrowser :
|
||||
window.gBrowser ;
|
||||
},
|
||||
|
||||
/* backward compatibility */
|
||||
getTempTreeStyleTab : function TSTService_getTempTreeStyleTab(aTabBrowser)
|
||||
{
|
||||
@ -698,7 +705,7 @@ try{
|
||||
);
|
||||
var indicator = aTabBrowser.mTabDropIndicatorBar || aTabBrowser.tabContainer._tabDropIndicator;
|
||||
indicator.setAttribute('dragging', (info.position == this.kDROP_ON) ? 'false' : 'true' );
|
||||
return (info.position == this.kDROP_ON || aTabBrowser.getAttribute(this.kTABBAR_POSITION) != 'top')
|
||||
return (info.position == this.kDROP_ON || aTabBrowser.treeStyleTab.currentTabbarPosition != 'top')
|
||||
}
|
||||
catch(e) {
|
||||
dump('TreeStyleTabService::onDragOver\n'+e+'\n');
|
||||
@ -1092,14 +1099,14 @@ catch(e) {
|
||||
eval('FullScreen._animateUp = '+
|
||||
FullScreen._animateUp.toSource().replace(
|
||||
/(gBrowser\.mStrip\.boxObject\.height)/,
|
||||
'((gBrowser.getAttribute(TreeStyleTabService.kTABBAR_POSITION) != "top") ? 0 : $1)'
|
||||
'((gBrowser.treeStyleTab.currentTabbarPosition != "top") ? 0 : $1)'
|
||||
)
|
||||
);
|
||||
eval('FullScreen.mouseoverToggle = '+
|
||||
FullScreen.mouseoverToggle.toSource().replace(
|
||||
// Firefox 3.7 or later
|
||||
'allFSToolbars[i].setAttribute("moz-collapsed", !aShow);',
|
||||
'if (allFSToolbars[i].id != "TabsToolbar" || gBrowser.getAttribute(TreeStyleTabService.kTABBAR_POSITION) == "top") { $& }'
|
||||
'if (allFSToolbars[i].id != "TabsToolbar" || gBrowser.treeStyleTab.currentTabbarPosition == "top") { $& }'
|
||||
).replace(
|
||||
// Firefox 3.7 or later
|
||||
'this._isChromeCollapsed = !aShow;',
|
||||
@ -1107,7 +1114,7 @@ catch(e) {
|
||||
).replace(
|
||||
// Firefox 3.6 or older
|
||||
'gBrowser.mStrip.setAttribute("moz-collapsed", !aShow);',
|
||||
'if (gBrowser.getAttribute(TreeStyleTabService.kTABBAR_POSITION) == "top") { $& }'
|
||||
'if (gBrowser.treeStyleTab.currentTabbarPosition == "top") { $& }'
|
||||
)
|
||||
);
|
||||
eval('FullScreen.toggle = '+
|
||||
@ -1115,7 +1122,7 @@ catch(e) {
|
||||
'{',
|
||||
<![CDATA[{
|
||||
var treeStyleTab = gBrowser.treeStyleTab;
|
||||
if (gBrowser.getAttribute(treeStyleTab.kTABBAR_POSITION) != 'top') {
|
||||
if (treeStyleTab.currentTabbarPosition != 'top') {
|
||||
if (window.fullScreen)
|
||||
treeStyleTab.autoHide.endForFullScreen();
|
||||
else
|
||||
|
@ -187,7 +187,7 @@ TreeStyleTabBrowser.prototype = {
|
||||
let position = this.currentTabbarPosition;
|
||||
this.fireTabbarPositionEvent('TreeStyleTabTabbarPositionChanging', 'top', position); /* PUBLIC API */
|
||||
|
||||
this.initTabbar(this.kTABBAR_TOP);
|
||||
this.initTabbar(null, this.kTABBAR_TOP);
|
||||
|
||||
var strip = this.tabStrip;
|
||||
b.mTabContainer.addEventListener('TabOpen', this, true);
|
||||
@ -632,7 +632,7 @@ TreeStyleTabBrowser.prototype = {
|
||||
/* To move up content area on the tab bar, switch tab.
|
||||
If we don't do it, a gray space appears on the content area
|
||||
by negative margin of it. */
|
||||
if (b.getAttribute(this.kTABBAR_POSITION) == 'left' &&
|
||||
if (this.currentTabbarPosition == 'left' &&
|
||||
b.getAttribute(this.kSCROLLBAR_INVERTED) == 'true') {
|
||||
b.removeTab(
|
||||
b.selectedTab = b.addTab('about:blank')
|
||||
@ -689,7 +689,7 @@ TreeStyleTabBrowser.prototype = {
|
||||
|
||||
initTabAttributes : function TSTBrowser_initTabAttributes(aTab)
|
||||
{
|
||||
var pos = this.mTabBrowser.getAttribute(this.kTABBAR_POSITION);
|
||||
var pos = this.currentTabbarPosition;
|
||||
if (pos == 'left' || pos == 'right') {
|
||||
aTab.setAttribute('align', 'stretch');
|
||||
aTab.removeAttribute('maxwidth');
|
||||
@ -823,13 +823,13 @@ TreeStyleTabBrowser.prototype = {
|
||||
}, 0, this);
|
||||
},
|
||||
|
||||
initTabbar : function TSTBrowser_initTabbar(aOldPosition)
|
||||
initTabbar : function TSTBrowser_initTabbar(aNewPosition, aOldPosition)
|
||||
{
|
||||
this.stopRendering();
|
||||
|
||||
var b = this.mTabBrowser;
|
||||
|
||||
var pos = this.getPositionFlag(this.currentTabbarPosition);
|
||||
var pos = aNewPosition || this.getPositionFlag(this.currentTabbarPosition);
|
||||
if (b.getAttribute('id') != 'content' &&
|
||||
!this.getTreePref('tabbar.position.subbrowser.enabled')) {
|
||||
pos = this.kTABBAR_TOP;
|
||||
@ -1408,9 +1408,10 @@ TreeStyleTabBrowser.prototype = {
|
||||
switch (aPrefName)
|
||||
{
|
||||
case 'extensions.treestyletab.tabbar.position':
|
||||
var oldPosition = b.getAttribute(this.kTABBAR_POSITION);
|
||||
if (window != this.topBrowserWindow) return;
|
||||
var oldPosition = this.currentTabbarPosition;
|
||||
this.fireTabbarPositionEvent('TreeStyleTabTabbarPositionChanging', oldPosition, value); /* PUBLIC API */
|
||||
this.initTabbar(this.getPositionFlag(oldPosition));
|
||||
this.initTabbar(this.getPositionFlag(value), this.getPositionFlag(oldPosition));
|
||||
tabs.forEach(function(aTab) {
|
||||
this.initTabAttributes(aTab);
|
||||
}, this);
|
||||
@ -1474,6 +1475,7 @@ TreeStyleTabBrowser.prototype = {
|
||||
|
||||
case 'extensions.treestyletab.tabbar.width':
|
||||
case 'extensions.treestyletab.tabbar.shrunkenWidth':
|
||||
if (window != this.topBrowserWindow) return;
|
||||
if (!this.autoHide.isResizing && this.isVertical) {
|
||||
this.removeTabStripAttribute('width');
|
||||
this.setTabStripAttribute('width', this.autoHide.widthFromMode);
|
||||
@ -1483,6 +1485,7 @@ TreeStyleTabBrowser.prototype = {
|
||||
break;
|
||||
|
||||
case 'extensions.treestyletab.tabbar.height':
|
||||
if (window != this.topBrowserWindow) return;
|
||||
this._horizontalTabMaxIndentBase = 0;
|
||||
this.checkTabsIndentOverflow();
|
||||
break;
|
||||
|
@ -81,7 +81,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
|
||||
case this.kMODE_HIDE:
|
||||
let offset = this.width + this.splitterWidth;
|
||||
if (sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION) == 'left') {
|
||||
if (sv.currentTabbarPosition == 'left') {
|
||||
offset -= this.togglerSize;
|
||||
}
|
||||
return offset;
|
||||
@ -103,7 +103,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
{
|
||||
var sv = this.mOwner;
|
||||
return (
|
||||
sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION) == 'left' &&
|
||||
sv.currentTabbarPosition == 'left' &&
|
||||
this.mode != this.kMODE_DISABLED &&
|
||||
this.expanded
|
||||
) ? this.XOffset : 0 ;
|
||||
@ -112,7 +112,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
{
|
||||
var sv = this.mOwner;
|
||||
return (
|
||||
sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION) == 'top' &&
|
||||
sv.currentTabbarPosition == 'top' &&
|
||||
this.mode != this.kMODE_DISABLED &&
|
||||
this.expanded
|
||||
) ? this.YOffset : 0 ;
|
||||
@ -238,7 +238,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
|
||||
var sv = this.mOwner;
|
||||
var b = sv.mTabBrowser;
|
||||
var pos = b.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
var box = b.mCurrentBrowser.boxObject;
|
||||
|
||||
var sensitiveArea = this.sensitiveArea;
|
||||
@ -441,7 +441,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
|
||||
var sv = this.mOwner;
|
||||
var b = sv.mTabBrowser;
|
||||
var pos = b.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
|
||||
if (this.expanded) { // to be hidden or shrunken
|
||||
this.onHiding();
|
||||
@ -484,7 +484,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
{
|
||||
var sv = this.mOwner;
|
||||
var b = sv.mTabBrowser;
|
||||
var pos = b.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
|
||||
switch (pos)
|
||||
{
|
||||
@ -523,7 +523,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
{
|
||||
var sv = this.mOwner;
|
||||
var b = sv.mTabBrowser;
|
||||
var pos = b.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
|
||||
var box = (sv.tabStripPlaceHolder || sv.tabStrip).boxObject;
|
||||
|
||||
@ -577,7 +577,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
redrawContentArea : function TSTAutoHide_redrawContentArea()
|
||||
{
|
||||
var sv = this.mOwner;
|
||||
var pos = sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
try {
|
||||
var v = sv.mTabBrowser.markupDocumentViewer;
|
||||
if (this.shouldRedraw) {
|
||||
@ -632,7 +632,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
this.tabbarCanvas.style.width = (this.tabbarCanvas.width = 1)+'px';
|
||||
this.tabbarCanvas.style.height = (this.tabbarCanvas.height = 1)+'px';
|
||||
|
||||
var pos = sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
|
||||
var frame = sv.mTabBrowser.contentWindow;
|
||||
var tabContainerBox = sv.mTabBrowser.mTabContainer.boxObject;
|
||||
@ -746,7 +746,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
sv.tabStrip :
|
||||
document.getAnonymousElementByAttribute(sv.mTabBrowser, 'class', sv.kSPLITTER) ;
|
||||
|
||||
var pos = sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
var prop = pos == 'left' ? 'right' :
|
||||
pos == 'right' ? 'left' :
|
||||
pos == 'top' ? 'bottom' :
|
||||
@ -792,7 +792,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
{
|
||||
var sv = this.mOwner;
|
||||
var b = sv.mTabBrowser;
|
||||
var pos = b.getAttribute(sv.kTABBAR_POSITION);
|
||||
var pos = sv.currentTabbarPosition;
|
||||
var style = this.kTRANSPARENT_STYLE[
|
||||
Math.max(
|
||||
this.kTRANSPARENT_NONE,
|
||||
@ -1068,7 +1068,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
||||
return;
|
||||
}
|
||||
var sv = this.mOwner;
|
||||
switch (sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION))
|
||||
switch (sv.currentTabbarPosition)
|
||||
{
|
||||
case 'left':
|
||||
sv.container.style.marginRight = '-'+this.XOffset+'px';
|
||||
|
@ -54,7 +54,7 @@ TreeStyleTabBrowserTabbarDNDObserver.prototype = {
|
||||
if (canDrag && !aEvent.shiftKey) {
|
||||
let insensitiveArea = sv.getTreePref('tabbar.fixed.insensitiveArea');
|
||||
let box = tabbar.boxObject;
|
||||
switch (sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION))
|
||||
switch (sv.currentTabbarPosition)
|
||||
{
|
||||
case 'right':
|
||||
if (aEvent.screenX < box.screenX + insensitiveArea)
|
||||
|
@ -19,7 +19,7 @@ TreeStyleTabBrowserTabpanelDNDObserver.prototype = {
|
||||
var sv = this.mOwner;
|
||||
var position = this.getDropPosition(aEvent);
|
||||
if (position != 'center' &&
|
||||
position != sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION))
|
||||
position != sv.currentTabbarPosition)
|
||||
sv.setTabbrowserAttribute(sv.kDROP_POSITION, position);
|
||||
},
|
||||
|
||||
@ -28,7 +28,7 @@ TreeStyleTabBrowserTabpanelDNDObserver.prototype = {
|
||||
var sv = this.mOwner;
|
||||
var position = this.getDropPosition(aEvent);
|
||||
if (position != 'center' &&
|
||||
position != sv.mTabBrowser.getAttribute(sv.kTABBAR_POSITION)) {
|
||||
position != sv.currentTabbarPosition) {
|
||||
if (sv.getTreePref('tabbar.fixed.autoCancelOnDrop') &&
|
||||
(!aXferData || aXferData.data != sv.kTABBAR_MOVE_FORCE)) {
|
||||
let orient = (position == 'left' || position == 'right') ? 'vertical' : 'horizontal' ;
|
||||
|
@ -316,10 +316,34 @@ var TreeStyleTabUtils = {
|
||||
},
|
||||
|
||||
get browserWindow()
|
||||
{
|
||||
return this.topBrowserWindow;
|
||||
},
|
||||
get topBrowserWindow()
|
||||
{
|
||||
return this.WindowMediator.getMostRecentWindow('navigator:browser');
|
||||
},
|
||||
|
||||
get browserWindows()
|
||||
{
|
||||
var windows = [];
|
||||
|
||||
var targets = this.WindowMediator.getZOrderDOMWindowEnumerator('navigator:browser', true);
|
||||
// By the bug 156333, we cannot find windows by their Z order on Linux.
|
||||
// https://bugzilla.mozilla.org/show_bug.cgi?id=156333
|
||||
if (!targets.hasMoreElements())
|
||||
targets = this.WindowMediator.getEnumerator('navigator:browser');
|
||||
|
||||
while (targets.hasMoreElements())
|
||||
{
|
||||
let target = targets.getNext()
|
||||
.QueryInterface(Ci.nsIDOMWindowInternal);
|
||||
windows.push(target);
|
||||
}
|
||||
|
||||
return windows;
|
||||
},
|
||||
|
||||
get browser()
|
||||
{
|
||||
var w = this.browserWindow;
|
||||
|
Loading…
x
Reference in New Issue
Block a user