* 展開された状態でフローティング状態のタブバーの幅を変えられるように

* ポップアップが閉じられたことを検出できていない場合があった(タブバーを自動で隠す機能で、タブバーが隠れっぱなしになることがあった)

git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@7172 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
piro 2010-09-10 10:21:26 +00:00
parent f138fb9096
commit b938013e2b
7 changed files with 227 additions and 63 deletions

View File

@ -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;
}

View File

@ -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 : [],

View File

@ -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>

View File

@ -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()

View File

@ -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':

View File

@ -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;
} }
}, },

View File

@ -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"]) {