* 展開された状態でフローティング状態のタブバーの幅を変えられるように
* ポップアップが閉じられたことを検出できていない場合があった(タブバーを自動で隠す機能で、タブバーが隠れっぱなしになることがあった) git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@7172 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
parent
f138fb9096
commit
b938013e2b
@ -25,11 +25,12 @@
|
|||||||
.tabbrowser-strip[treestyletab-tabbar-autohide="hidden"]+splitter,
|
.tabbrowser-strip[treestyletab-tabbar-autohide="hidden"]+splitter,
|
||||||
tabbrowser:not([treestyletab-tabbar-autohide="hidden"]) .treestyletab-tabbar-toggler,
|
tabbrowser:not([treestyletab-tabbar-autohide="hidden"]) .treestyletab-tabbar-toggler,
|
||||||
#TabsToolbar[treestyletab-tabbar-autohide="hidden"] > *,
|
#TabsToolbar[treestyletab-tabbar-autohide="hidden"] > *,
|
||||||
#TabsToolbar:not([treestyletab-tabbar-autohide-state="expanded"]) #treestyletab-tabbar-resizer-box,
|
#TabsToolbar #treestyletab-tabbar-resizer-box,
|
||||||
#appcontent[ahFull="true"] .tabbrowser-strip[ahHIDE="true"]+splitter /* AutoHide */,
|
#appcontent[ahFull="true"] .tabbrowser-strip[ahHIDE="true"]+splitter /* AutoHide */,
|
||||||
.tabbrowser-strip[treestyletab-tabbar-fixed="true"]+splitter,
|
.tabbrowser-strip[treestyletab-tabbar-fixed="true"]+splitter,
|
||||||
.tabbrowser-strip[treestyletab-print-preview="true"],
|
.tabbrowser-strip[treestyletab-print-preview="true"],
|
||||||
.tabbrowser-strip[treestyletab-print-preview="true"]+splitter,
|
.tabbrowser-strip[treestyletab-print-preview="true"]+splitter,
|
||||||
|
#TabsToolbar .treestyletab-splitter,
|
||||||
#TabsToolbar[treestyletab-print-preview="true"],
|
#TabsToolbar[treestyletab-print-preview="true"],
|
||||||
window[chromehidden~="toolbar"] .tabbrowser-strip[treestyletab-tabbar-placeholder="true"],
|
window[chromehidden~="toolbar"] .tabbrowser-strip[treestyletab-tabbar-placeholder="true"],
|
||||||
window[chromehidden~="toolbar"] .tabbrowser-strip[treestyletab-tabbar-placeholder="true"]+splitter {
|
window[chromehidden~="toolbar"] .tabbrowser-strip[treestyletab-tabbar-placeholder="true"]+splitter {
|
||||||
@ -114,19 +115,31 @@ tabbrowser[treestyletab-mode="vertical"] .tabs-stack > *:first-child + * > hbox:
|
|||||||
overflow: hidden !important;
|
overflow: hidden !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#TabsToolbar[treestyletab-tabbar-autohide-state="expanded"] > *,
|
#TabsToolbar[treestyletab-mode="vertical"][treestyletab-tabbar-autohide][treestyletab-tabbar-autohide-state="expanded"]
|
||||||
.tabs-toolbar-inner-box[treestyletab-tabbar-autohide-state="expanded"] > * {
|
> *,
|
||||||
|
.tabs-toolbar-inner-box[treestyletab-tabbar-autohide][treestyletab-tabbar-autohide-state="expanded"]:not([treestyletab-tabbar-fixed="true"])
|
||||||
|
> * {
|
||||||
position: relative;
|
position: relative;
|
||||||
z-index: 2;
|
z-index: 2;
|
||||||
}
|
}
|
||||||
#TabsToolbar[treestyletab-tabbar-autohide-state="expanded"] #treestyletab-tabbar-resizer-box {
|
#TabsToolbar[treestyletab-mode="vertical"][treestyletab-tabbar-autohide][treestyletab-tabbar-autohide-state="expanded"]
|
||||||
|
#treestyletab-tabbar-resizer-box {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
top: 0;
|
top: 0;
|
||||||
z-index: 1;
|
z-index: 1;
|
||||||
|
line-height: 0; /* to avoid an useless space above the splitter */
|
||||||
|
font-size: 0; /* to avoid an useless space above the splitter */
|
||||||
}
|
}
|
||||||
|
#TabsToolbar[treestyletab-mode="vertical"][treestyletab-tabbar-autohide][treestyletab-tabbar-autohide-state="expanded"]
|
||||||
|
#treestyletab-tabbar-resizer-box,
|
||||||
|
#TabsToolbar[treestyletab-mode="vertical"][treestyletab-tabbar-autohide][treestyletab-tabbar-autohide-state="expanded"]:not([treestyletab-tabbar-fixed="true"])
|
||||||
|
.treestyletab-splitter {
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -333,7 +333,7 @@ var TreeStyleTabService = {
|
|||||||
window.removeEventListener('load', this, false);
|
window.removeEventListener('load', this, false);
|
||||||
window.addEventListener('unload', this, false);
|
window.addEventListener('unload', this, false);
|
||||||
document.addEventListener('popupshowing', this, false);
|
document.addEventListener('popupshowing', this, false);
|
||||||
document.addEventListener('popuphiding', this, false);
|
document.addEventListener('popuphiding', this, true);
|
||||||
document.addEventListener('TreeStyleTabCollapsedStateChange', this, false);
|
document.addEventListener('TreeStyleTabCollapsedStateChange', this, false);
|
||||||
document.addEventListener('TreeStyleTabTabbarPositionChanged', this, false);
|
document.addEventListener('TreeStyleTabTabbarPositionChanged', this, false);
|
||||||
document.addEventListener('TreeStyleTabTabbarStateChanged', this, false);
|
document.addEventListener('TreeStyleTabTabbarStateChanged', this, false);
|
||||||
@ -1358,7 +1358,7 @@ catch(e) {
|
|||||||
this.endListenKeyEventsFor(this.LISTEN_FOR_AUTOEXPAND_BY_FOCUSCHANGE);
|
this.endListenKeyEventsFor(this.LISTEN_FOR_AUTOEXPAND_BY_FOCUSCHANGE);
|
||||||
|
|
||||||
document.removeEventListener('popupshowing', this, false);
|
document.removeEventListener('popupshowing', this, false);
|
||||||
document.removeEventListener('popuphiding', this, false);
|
document.removeEventListener('popuphiding', this, true);
|
||||||
document.removeEventListener('TreeStyleTabCollapsedStateChange', this, false);
|
document.removeEventListener('TreeStyleTabCollapsedStateChange', this, false);
|
||||||
document.removeEventListener('TreeStyleTabTabbarPositionChanged', this, false);
|
document.removeEventListener('TreeStyleTabTabbarPositionChanged', this, false);
|
||||||
document.removeEventListener('TreeStyleTabTabbarStateChanged', this, false);
|
document.removeEventListener('TreeStyleTabTabbarStateChanged', this, false);
|
||||||
@ -1411,34 +1411,13 @@ catch(e) {
|
|||||||
return this.onTabRestored(aEvent);
|
return this.onTabRestored(aEvent);
|
||||||
|
|
||||||
case 'popupshowing':
|
case 'popupshowing':
|
||||||
if (aEvent.originalTarget.boxObject &&
|
this.onPopupShown(aEvent.originalTarget);
|
||||||
!this.evaluateXPath(
|
|
||||||
'local-name() = "tooltip" or local-name() ="panel" or '+
|
|
||||||
'parent::*/ancestor-or-self::*[local-name()="popup" or local-name()="menupopup"]',
|
|
||||||
aEvent.originalTarget,
|
|
||||||
XPathResult.BOOLEAN_TYPE
|
|
||||||
).booleanValue) {
|
|
||||||
this.popupMenuShown = true;
|
|
||||||
window.setTimeout(function(aSelf, aPopup) {
|
|
||||||
if (!aPopup.boxObject.width || !aPopup.boxObject.height)
|
|
||||||
aSelf.popupMenuShown = false;
|
|
||||||
}, 10, this, aEvent.originalTarget);
|
|
||||||
}
|
|
||||||
if ((aEvent.originalTarget.getAttribute('anonid') || aEvent.originalTarget.id) == 'alltabs-popup')
|
if ((aEvent.originalTarget.getAttribute('anonid') || aEvent.originalTarget.id) == 'alltabs-popup')
|
||||||
this.updateAllTabsPopup(aEvent);
|
this.updateAllTabsPopup(aEvent);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case 'popuphiding':
|
case 'popuphiding':
|
||||||
if (aEvent.originalTarget.boxObject &&
|
return this.onPopupHidden(aEvent.originalTarget);
|
||||||
!this.evaluateXPath(
|
|
||||||
'local-name() = "tooltip" or local-name() ="panel" or '+
|
|
||||||
'parent::*/ancestor-or-self::*[local-name()="popup" or local-name()="menupopup"]',
|
|
||||||
aEvent.originalTarget,
|
|
||||||
XPathResult.BOOLEAN_TYPE
|
|
||||||
).booleanValue) {
|
|
||||||
this.popupMenuShown = false;
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
|
|
||||||
case 'TreeStyleTabCollapsedStateChange':
|
case 'TreeStyleTabCollapsedStateChange':
|
||||||
return this.updateAeroPeekPreviews();
|
return this.updateAeroPeekPreviews();
|
||||||
@ -1618,24 +1597,29 @@ catch(e) {
|
|||||||
|
|
||||||
onTabbarResized : function TSTService_onTabbarResized(aEvent)
|
onTabbarResized : function TSTService_onTabbarResized(aEvent)
|
||||||
{
|
{
|
||||||
var b = this.getTabBrowserFromChild(aEvent.currentTarget);
|
var target = aEvent.currentTarget;
|
||||||
var box = (b.treeStyleTab.tabStripPlaceHolder || this.getTabStrip(b)).boxObject;
|
var b = this.getTabBrowserFromChild(target);
|
||||||
|
var strip = this.getTabStrip(b);
|
||||||
|
var box = (b.treeStyleTab.tabStripPlaceHolder || strip).boxObject;
|
||||||
window.setTimeout(function(aSelf) {
|
window.setTimeout(function(aSelf) {
|
||||||
if (!b.treeStyleTab.clickedOnTabbarResizerGrippy) {
|
if (!b.treeStyleTab.clickedOnTabbarResizerGrippy) {
|
||||||
if (!b.treeStyleTab.isVertical) {
|
if (!b.treeStyleTab.isVertical) {
|
||||||
aSelf.setTreePref('tabbar.height', aSelf.maxTabbarHeight(box.height, b));
|
let height = aSelf.maxTabbarHeight(box.height, b);
|
||||||
|
aSelf.setTreePref('tabbar.height', height);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
let width = aSelf.maxTabbarWidth(box.width, b);
|
||||||
if (!b.treeStyleTab.autoHide.expanded)
|
if (!b.treeStyleTab.autoHide.expanded)
|
||||||
aSelf.setTreePref('tabbar.shrunkenWidth', aSelf.maxTabbarWidth(box.width, b));
|
aSelf.setTreePref('tabbar.shrunkenWidth', width);
|
||||||
else
|
else
|
||||||
aSelf.setTreePref('tabbar.width', aSelf.maxTabbarWidth(box.width, b));
|
aSelf.setTreePref('tabbar.width', width);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
b.treeStyleTab.updateFloatingTabbar();
|
b.treeStyleTab.updateFloatingTabbar(true);
|
||||||
b.treeStyleTab.clickedOnTabbarResizerGrippy = false;
|
b.treeStyleTab.clickedOnTabbarResizerGrippy = false;
|
||||||
}, 10, this);
|
}, 10, this);
|
||||||
},
|
},
|
||||||
|
|
||||||
onTabbarResizerClick : function TSTService_onTabbarResizerClick(aEvent)
|
onTabbarResizerClick : function TSTService_onTabbarResizerClick(aEvent)
|
||||||
{
|
{
|
||||||
var b = this.getTabBrowserFromChild(aEvent.currentTarget);
|
var b = this.getTabBrowserFromChild(aEvent.currentTarget);
|
||||||
@ -1646,6 +1630,59 @@ catch(e) {
|
|||||||
).booleanValue;
|
).booleanValue;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onFloatingTabbarResizeStart : function TSTService_onFloatingTabbarResizeStart(aEvent)
|
||||||
|
{
|
||||||
|
aEvent.stopPropagation();
|
||||||
|
aEvent.target.setCapture(true);
|
||||||
|
this.floatingTabbarResizeResizing = true;
|
||||||
|
var b = this.getTabBrowserFromChild(aEvent.target);
|
||||||
|
var strip = this.getTabStrip(b);
|
||||||
|
this.floatingTabbarResizeStartWidth = strip.boxObject.width;
|
||||||
|
this.floatingTabbarResizeStartHeight = strip.boxObject.height;
|
||||||
|
this.floatingTabbarResizeStartX = aEvent.screenX;
|
||||||
|
this.floatingTabbarResizeStartY = aEvent.screenY;
|
||||||
|
},
|
||||||
|
onFloatingTabbarResizeEnd : function TSTService_onFloatingTabbarResizeEnd(aEvent)
|
||||||
|
{
|
||||||
|
aEvent.stopPropagation();
|
||||||
|
aEvent.target.releaseCapture();
|
||||||
|
this.floatingTabbarResizeResizing = false;
|
||||||
|
this.floatingTabbarResizeStartWidth = -1;
|
||||||
|
this.floatingTabbarResizeStartHeight = -1;
|
||||||
|
this.floatingTabbarResizeStartX = -1;
|
||||||
|
this.floatingTabbarResizeStartY = -1;
|
||||||
|
},
|
||||||
|
onFloatingTabbarResizing : function TSTService_onFloatingTabbarResizing(aEvent)
|
||||||
|
{
|
||||||
|
if (!this.floatingTabbarResizeResizing)
|
||||||
|
return;
|
||||||
|
|
||||||
|
aEvent.stopPropagation();
|
||||||
|
var b = this.getTabBrowserFromChild(aEvent.target);
|
||||||
|
var width = this.floatingTabbarResizeStartWidth;
|
||||||
|
var height = this.floatingTabbarResizeStartHeight;
|
||||||
|
var pos = b.treeStyleTab.currentTabbarPosition;
|
||||||
|
if (b.treeStyleTab.isVertical) {
|
||||||
|
let delta = aEvent.screenX - this.floatingTabbarResizeStartX;
|
||||||
|
width += (pos == 'left' ? delta : -delta );
|
||||||
|
this.setTreePref('tabbar.width', Math.max(0, width));
|
||||||
|
if (b.treeStyleTab.autoHide.mode == b.treeStyleTab.autoHide.kMODE_SHRINK &&
|
||||||
|
b.treeStyleTab._tabStripPlaceHolder)
|
||||||
|
b.treeStyleTab._tabStripPlaceHolder.setAttribute('width', this.getTreePref('tabbar.shrunkenWidth'));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
let delta = aEvent.screenY - this.floatingTabbarResizeStartY;
|
||||||
|
height += (pos == 'top' ? delta : -delta );
|
||||||
|
this.setTreePref('tabbar.height', Math.max(0, height));
|
||||||
|
}
|
||||||
|
b.treeStyleTab.updateFloatingTabbar(true);
|
||||||
|
},
|
||||||
|
floatingTabbarResizeResizing : false,
|
||||||
|
floatingTabbarResizeStartWidth : -1,
|
||||||
|
floatingTabbarResizeStartHeight : -1,
|
||||||
|
floatingTabbarResizeStartX : -1,
|
||||||
|
floatingTabbarResizeStartY : -1,
|
||||||
|
|
||||||
showHideSubtreeMenuItem : function TSTService_showHideSubtreeMenuItem(aMenuItem, aTabs)
|
showHideSubtreeMenuItem : function TSTService_showHideSubtreeMenuItem(aMenuItem, aTabs)
|
||||||
{
|
{
|
||||||
if (!aMenuItem ||
|
if (!aMenuItem ||
|
||||||
@ -1783,6 +1820,49 @@ catch(e) {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onPopupShown : function TSTService_onPopupShown(aPopup)
|
||||||
|
{
|
||||||
|
if (!aPopup.boxObject ||
|
||||||
|
this.evaluateXPath(
|
||||||
|
'local-name() = "tooltip" or local-name() ="panel" or '+
|
||||||
|
'parent::*/ancestor-or-self::*[local-name()="popup" or local-name()="menupopup"]',
|
||||||
|
aEvent.originalTarget,
|
||||||
|
XPathResult.BOOLEAN_TYPE
|
||||||
|
).booleanValue)
|
||||||
|
return;
|
||||||
|
|
||||||
|
window.setTimeout(function(aSelf) {
|
||||||
|
if (!aPopup.boxObject.width && !aPopup.boxObject.height)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var id = aPopup.id;
|
||||||
|
var item = document.getElementById(id) ? id : aPopup ;
|
||||||
|
var index = TreeStyleTabService._shownPopups.indexOf(item);
|
||||||
|
if (index < 0)
|
||||||
|
TreeStyleTabService._shownPopups.push(item);
|
||||||
|
}, 10, this);
|
||||||
|
},
|
||||||
|
|
||||||
|
onPopupHidden : function TSTService_onPopupHidden(aPopup)
|
||||||
|
{
|
||||||
|
var id = aPopup.id;
|
||||||
|
aPopup = document.getElementById(id) || aPopup;
|
||||||
|
var index = TreeStyleTabService._shownPopups.indexOf(aPopup);
|
||||||
|
if (index > -1)
|
||||||
|
TreeStyleTabService._shownPopups.splice(index, 1);
|
||||||
|
},
|
||||||
|
|
||||||
|
isPopupShown : function TSTService_isPopupShown()
|
||||||
|
{
|
||||||
|
TreeStyleTabService._shownPopups = TreeStyleTabService._shownPopups.filter(function(aItem) {
|
||||||
|
if (typeof aItem == 'string')
|
||||||
|
aItem = document.getElementById(aItem);
|
||||||
|
return aItem && aItem.boxObject && aItem.boxObject.width && aItem.boxObject.height;
|
||||||
|
});
|
||||||
|
return TreeStyleTabService._shownPopups.length > 0;
|
||||||
|
},
|
||||||
|
_shownPopups : [],
|
||||||
|
|
||||||
/* Tree Style Tabの初期化が行われる前に復元されたセッションについてツリー構造を復元 */
|
/* Tree Style Tabの初期化が行われる前に復元されたセッションについてツリー構造を復元 */
|
||||||
|
|
||||||
_restoringTabs : [],
|
_restoringTabs : [],
|
||||||
|
@ -148,8 +148,14 @@
|
|||||||
</popupset>
|
</popupset>
|
||||||
|
|
||||||
<toolbar id="TabsToolbar">
|
<toolbar id="TabsToolbar">
|
||||||
<hbox id="treestyletab-tabbar-resizer-box">
|
<box id="treestyletab-tabbar-resizer-box">
|
||||||
</hbox>
|
<splitter id="treestyletab-tabbar-resizer-splitter"
|
||||||
|
class="treestyletab-splitter"
|
||||||
|
onmousedown="TreeStyleTabService.onFloatingTabbarResizeStart(event);"
|
||||||
|
onmouseup="TreeStyleTabService.onFloatingTabbarResizeEnd(event);"
|
||||||
|
onmousemove="TreeStyleTabService.onFloatingTabbarResizing(event);"
|
||||||
|
dblclick="gBrowser.treeStyleTab.resetTabbarSize(); event.stopPropagation();"/>
|
||||||
|
</box>
|
||||||
</toolbar>
|
</toolbar>
|
||||||
|
|
||||||
</overlay>
|
</overlay>
|
||||||
|
@ -743,7 +743,7 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
|
|
||||||
this.autoHide;
|
this.autoHide;
|
||||||
|
|
||||||
this.fireTabbarPositionEvent('TreeStyleTabTabbarPositionChanged', 'top', position); /* PUBLIC API */
|
this.fireTabbarPositionEvent(false, 'top', position); /* PUBLIC API */
|
||||||
|
|
||||||
b = null;
|
b = null;
|
||||||
|
|
||||||
@ -1263,7 +1263,7 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
}, 0, this.mTabBrowser);
|
}, 0, this.mTabBrowser);
|
||||||
},
|
},
|
||||||
|
|
||||||
updateFloatingTabbar : function TSTBrowser_updateFloatingTabbar(aWidth, aHeight, aJustNow)
|
updateFloatingTabbar : function TSTBrowser_updateFloatingTabbar(aJustNow)
|
||||||
{
|
{
|
||||||
// this method is just for Firefox 4.0 or later
|
// this method is just for Firefox 4.0 or later
|
||||||
if (!this.isFloating) return;
|
if (!this.isFloating) return;
|
||||||
@ -1274,16 +1274,16 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (aJustNow) {
|
if (aJustNow) {
|
||||||
this.updateFloatingTabbarInternal(aWidth, aHeight);
|
this.updateFloatingTabbarInternal();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
this.updateFloatingTabbarTimer = window.setTimeout(function(aSelf) {
|
this.updateFloatingTabbarTimer = window.setTimeout(function(aSelf) {
|
||||||
aSelf.updateFloatingTabbarTimer = null;
|
aSelf.updateFloatingTabbarTimer = null;
|
||||||
aSelf.updateFloatingTabbarInternal(aWidth, aHeight)
|
aSelf.updateFloatingTabbarInternal()
|
||||||
}, 0, this);
|
}, 0, this);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
updateFloatingTabbarInternal : function TSTBrowser_updateFloatingTabbarInternal(aWidth, aHeight)
|
updateFloatingTabbarInternal : function TSTBrowser_updateFloatingTabbarInternal()
|
||||||
{
|
{
|
||||||
var strip = this.tabStrip;
|
var strip = this.tabStrip;
|
||||||
var tabContainerBox = this.getTabContainerBox(this.mTabBrowser);
|
var tabContainerBox = this.getTabContainerBox(this.mTabBrowser);
|
||||||
@ -1298,8 +1298,8 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
|
|
||||||
let realWidth = parseInt(this._tabStripPlaceHolder.getAttribute('width') || box.width);
|
let realWidth = parseInt(this._tabStripPlaceHolder.getAttribute('width') || box.width);
|
||||||
let realHeight = parseInt(this._tabStripPlaceHolder.getAttribute('height') || box.height);
|
let realHeight = parseInt(this._tabStripPlaceHolder.getAttribute('height') || box.height);
|
||||||
let width = aWidth || realWidth;
|
let width = (this.autoHide.expanded && this.isVertical ? this.maxTabbarWidth(this.getTreePref('tabbar.width')) : 0 ) || realWidth;
|
||||||
let height = aHeight || realHeight;
|
let height = (this.autoHide.expanded && !this.isVertical ? this.maxTabbarHeight(this.getTreePref('tabbar.height')) : 0 ) || realHeight;
|
||||||
let xOffset = pos == 'right' ? width - realWidth : 0 ;
|
let xOffset = pos == 'right' ? width - realWidth : 0 ;
|
||||||
let yOffset = pos == 'bottom' ? height - realHeight : 0 ;
|
let yOffset = pos == 'bottom' ? height - realHeight : 0 ;
|
||||||
|
|
||||||
@ -1309,11 +1309,12 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
strip.style.width = (tabContainerBox.width = width)+'px';
|
strip.style.width = (tabContainerBox.width = width)+'px';
|
||||||
strip.style.height = (tabContainerBox.height = height)+'px';
|
strip.style.height = (tabContainerBox.height = height)+'px';
|
||||||
|
|
||||||
let resizerStyle = this.floatingTabbarResizerBox.style;
|
this.updateFloatingTabbarResizer({
|
||||||
resizerStyle.top = pos == 'top' ? realHeight+'px' : '' ;
|
width : width,
|
||||||
resizerStyle.right = pos == 'right' ? realWidth+'px' : '' ;
|
realWidth : realWidth,
|
||||||
resizerStyle.left = pos == 'left' ? realWidth+'px' : '' ;
|
height : height,
|
||||||
resizerStyle.bottom = pos == 'bottom' ? realHeight+'px' : '' ;
|
realHeight : realHeight
|
||||||
|
});
|
||||||
|
|
||||||
tabContainerBox.collapsed = (this.splitter && this.splitter.getAttribute('state') == 'collapsed');
|
tabContainerBox.collapsed = (this.splitter && this.splitter.getAttribute('state') == 'collapsed');
|
||||||
|
|
||||||
@ -1366,9 +1367,52 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
if ('_positionPinnedTabs' in this.mTabBrowser.mTabContainer)
|
if ('_positionPinnedTabs' in this.mTabBrowser.mTabContainer)
|
||||||
this.mTabBrowser.mTabContainer._positionPinnedTabs();
|
this.mTabBrowser.mTabContainer._positionPinnedTabs();
|
||||||
},
|
},
|
||||||
get floatingTabbarResizerBox()
|
updateFloatingTabbarResizer : function TSTBrowser_updateFloatingTabbarResizer(aSize)
|
||||||
{
|
{
|
||||||
return document.getElementById('treestyletab-tabbar-resizer-box');
|
var width = aSize.width;
|
||||||
|
var realWidth = aSize.realWidth;
|
||||||
|
var height = aSize.height;
|
||||||
|
var realHeight = aSize.realHeight;
|
||||||
|
var pos = this.currentTabbarPosition;
|
||||||
|
var vertical = this.isVertical;
|
||||||
|
|
||||||
|
var splitter = document.getElementById('treestyletab-tabbar-resizer-splitter');
|
||||||
|
var box = splitter.parentNode;
|
||||||
|
|
||||||
|
box.orient = splitter.orient = vertical ? 'horizontal' : 'vertical' ;
|
||||||
|
box.width = (width - realWidth) || width;
|
||||||
|
box.height = (height - realHeight) || height;
|
||||||
|
|
||||||
|
var boxStyle = box.style;
|
||||||
|
boxStyle.top = pos == 'top' ? realHeight+'px' : '' ;
|
||||||
|
boxStyle.right = pos == 'right' ? realWidth+'px' : '' ;
|
||||||
|
boxStyle.left = pos == 'left' ? realWidth+'px' : '' ;
|
||||||
|
boxStyle.bottom = pos == 'bottom' ? realHeight+'px' : '' ;
|
||||||
|
|
||||||
|
if (vertical) {
|
||||||
|
splitter.removeAttribute('width');
|
||||||
|
splitter.setAttribute('height', height);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
splitter.setAttribute('width', width);
|
||||||
|
splitter.removeAttribute('height');
|
||||||
|
}
|
||||||
|
|
||||||
|
var splitterWidth = splitter.boxObject.width;
|
||||||
|
var splitterHeight = splitter.boxObject.height;
|
||||||
|
var splitterStyle = splitter.style;
|
||||||
|
splitterStyle.marginTop = pos == 'bottom' ? (-splitterHeight)+'px' :
|
||||||
|
vertical ? '0' :
|
||||||
|
box.height+'px' ;
|
||||||
|
splitterStyle.marginRight = pos == 'left' ? (-splitterWidth)+'px' :
|
||||||
|
!vertical ? '0' :
|
||||||
|
box.width+'px' ;
|
||||||
|
splitterStyle.marginLeft = pos == 'right' ? (-splitterWidth)+'px' :
|
||||||
|
!vertical ? '0' :
|
||||||
|
box.width+'px' ;
|
||||||
|
splitterStyle.marginBottom = pos == 'top' ? (-splitterHeight)+'px' :
|
||||||
|
vertical ? '0' :
|
||||||
|
box.height+'px' ;
|
||||||
},
|
},
|
||||||
|
|
||||||
resetTabbarSize : function TSTBrowser_resetTabbarSize()
|
resetTabbarSize : function TSTBrowser_resetTabbarSize()
|
||||||
|
@ -191,10 +191,13 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
this.clearBG();
|
this.clearBG();
|
||||||
this.updateTransparency();
|
this.updateTransparency();
|
||||||
|
|
||||||
|
if (!sv.isFloating)
|
||||||
sv.container.style.margin = 0;
|
sv.container.style.margin = 0;
|
||||||
sv.removeTabbrowserAttribute(this.kAUTOHIDE);
|
sv.removeTabbrowserAttribute(this.kAUTOHIDE);
|
||||||
sv.removeTabbrowserAttribute(this.kSTATE);
|
sv.removeTabbrowserAttribute(this.kSTATE);
|
||||||
sv.removeTabbrowserAttribute(this.kTRANSPARENT);
|
sv.removeTabbrowserAttribute(this.kTRANSPARENT);
|
||||||
|
|
||||||
|
sv.setTabStripAttribute('width', this.widthFromMode);
|
||||||
},
|
},
|
||||||
|
|
||||||
// fullscreen
|
// fullscreen
|
||||||
@ -540,7 +543,11 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
switch (this.mode)
|
switch (this.mode)
|
||||||
{
|
{
|
||||||
case this.kMODE_DISABLED:
|
case this.kMODE_DISABLED:
|
||||||
|
break;
|
||||||
|
|
||||||
case this.kMODE_HIDE:
|
case this.kMODE_HIDE:
|
||||||
|
if (sv.isFloating)
|
||||||
|
sv.updateFloatingTabbar(true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -548,7 +555,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
if (pos == 'left' || pos == 'right') {
|
if (pos == 'left' || pos == 'right') {
|
||||||
let width = sv.maxTabbarWidth(this.getTreePref('tabbar.width'));
|
let width = sv.maxTabbarWidth(this.getTreePref('tabbar.width'));
|
||||||
if (sv.isFloating) // Firefox 4.0-
|
if (sv.isFloating) // Firefox 4.0-
|
||||||
sv.updateFloatingTabbar(width, 0, true);
|
sv.updateFloatingTabbar(true);
|
||||||
else // -Firefox 3.6
|
else // -Firefox 3.6
|
||||||
sv.setTabStripAttribute('width', width);
|
sv.setTabStripAttribute('width', width);
|
||||||
}
|
}
|
||||||
@ -575,19 +582,23 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
switch (this.mode)
|
switch (this.mode)
|
||||||
{
|
{
|
||||||
case this.kMODE_DISABLED:
|
case this.kMODE_DISABLED:
|
||||||
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'hidden');
|
||||||
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_HIDDEN);
|
||||||
|
break;
|
||||||
|
|
||||||
case this.kMODE_HIDE:
|
case this.kMODE_HIDE:
|
||||||
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'hidden');
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'hidden');
|
||||||
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_HIDDEN);
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_HIDDEN);
|
||||||
|
sv.updateFloatingTabbar(true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
case this.kMODE_SHRINK:
|
case this.kMODE_SHRINK:
|
||||||
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'show');
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'show');
|
||||||
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_SHRUNKEN);
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_SHRUNKEN);
|
||||||
if (pos == 'left' || pos == 'right') {
|
if (pos == 'left' || pos == 'right')
|
||||||
sv.setTabStripAttribute('width', this.getTreePref('tabbar.shrunkenWidth'));
|
sv.setTabStripAttribute('width', this.getTreePref('tabbar.shrunkenWidth'));
|
||||||
sv.updateFloatingTabbar(0, 0, true);
|
sv.updateFloatingTabbar(true);
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -871,6 +882,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
else {
|
else {
|
||||||
sv.removeTabbrowserAttribute(this.kTRANSPARENT);
|
sv.removeTabbrowserAttribute(this.kTRANSPARENT);
|
||||||
}
|
}
|
||||||
|
sv.updateFloatingTabbar();
|
||||||
},
|
},
|
||||||
|
|
||||||
// event handling
|
// event handling
|
||||||
@ -1004,7 +1016,10 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
case 'TreeStyleTabTabbarPositionChanged':
|
case 'TreeStyleTabTabbarPositionChanged':
|
||||||
if (this.enabled) this.show();
|
if (this.enabled) {
|
||||||
|
this.hide();
|
||||||
|
this.show();
|
||||||
|
}
|
||||||
this.updateTransparency();
|
this.updateTransparency();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -1113,7 +1128,7 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (
|
if (
|
||||||
!sv.popupMenuShown &&
|
!sv.isPopupShown() &&
|
||||||
(
|
(
|
||||||
!this.expanded ||
|
!this.expanded ||
|
||||||
this.showHideReason & this.kKEEP_SHOWN_ON_MOUSEOVER
|
this.showHideReason & this.kKEEP_SHOWN_ON_MOUSEOVER
|
||||||
@ -1125,7 +1140,9 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
|
|
||||||
onResize : function TSTAutoHide_onResize(aEvent)
|
onResize : function TSTAutoHide_onResize(aEvent)
|
||||||
{
|
{
|
||||||
|
var sv = this.mOwner;
|
||||||
if (
|
if (
|
||||||
|
sv.isFloating ||
|
||||||
!aEvent.originalTarget ||
|
!aEvent.originalTarget ||
|
||||||
(
|
(
|
||||||
aEvent.originalTarget.ownerDocument != document &&
|
aEvent.originalTarget.ownerDocument != document &&
|
||||||
@ -1135,7 +1152,6 @@ TreeStyleTabBrowserAutoHide.prototype = {
|
|||||||
) {
|
) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var sv = this.mOwner;
|
|
||||||
switch (sv.currentTabbarPosition)
|
switch (sv.currentTabbarPosition)
|
||||||
{
|
{
|
||||||
case 'left':
|
case 'left':
|
||||||
|
@ -1881,8 +1881,8 @@ var TreeStyleTabUtils = {
|
|||||||
if (expanded != originalExpanded ||
|
if (expanded != originalExpanded ||
|
||||||
shrunken != originalShrunken) {
|
shrunken != originalShrunken) {
|
||||||
this.tabbarWidthResetting = true;
|
this.tabbarWidthResetting = true;
|
||||||
this.setTreePref('tabbar.width', expanded);
|
this.setTreePref('tabbar.width', Math.max(0, expanded));
|
||||||
this.setTreePref('tabbar.shrunkenWidth', shrunken);
|
this.setTreePref('tabbar.shrunkenWidth', Math.max(0, shrunken));
|
||||||
this.tabbarWidthResetting = false;
|
this.tabbarWidthResetting = false;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -120,7 +120,12 @@ tabbrowser[treestyletab-drop-position] {
|
|||||||
#TabsToolbar[treestyletab-drop-position="top"]:not([treestyletab-tabbar-position="top"]),
|
#TabsToolbar[treestyletab-drop-position="top"]:not([treestyletab-tabbar-position="top"]),
|
||||||
#TabsToolbar[treestyletab-drop-position="right"]:not([treestyletab-tabbar-position="right"]),
|
#TabsToolbar[treestyletab-drop-position="right"]:not([treestyletab-tabbar-position="right"]),
|
||||||
#TabsToolbar[treestyletab-drop-position="bottom"]:not([treestyletab-tabbar-position="bottom"]),
|
#TabsToolbar[treestyletab-drop-position="bottom"]:not([treestyletab-tabbar-position="bottom"]),
|
||||||
#TabsToolbar[treestyletab-drop-position="left"]:not([treestyletab-tabbar-position="left"]) {
|
#TabsToolbar[treestyletab-drop-position="left"]:not([treestyletab-tabbar-position="left"]),
|
||||||
|
#TabsToolbar[treestyletab-drop-position="center"] #treestyletab-tabbar-resizer-box,
|
||||||
|
#TabsToolbar[treestyletab-drop-position="top"]:not([treestyletab-tabbar-position="top"]) #treestyletab-tabbar-resizer-box,
|
||||||
|
#TabsToolbar[treestyletab-drop-position="right"]:not([treestyletab-tabbar-position="right"]) #treestyletab-tabbar-resizer-box,
|
||||||
|
#TabsToolbar[treestyletab-drop-position="bottom"]:not([treestyletab-tabbar-position="bottom"]) #treestyletab-tabbar-resizer-box,
|
||||||
|
#TabsToolbar[treestyletab-drop-position="left"]:not([treestyletab-tabbar-position="left"]) #treestyletab-tabbar-resizer-box {
|
||||||
opacity: 0.5;
|
opacity: 0.5;
|
||||||
}
|
}
|
||||||
tabbrowser[treestyletab-drop-position="top"]:not([treestyletab-tabbar-position="top"]) {
|
tabbrowser[treestyletab-drop-position="top"]:not([treestyletab-tabbar-position="top"]) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user