Inherit width, height, and others via xbl:inherits (#550)
The inner box of the tab bar should inherit width, height, and other attributes given via setTabbrowserAttribute(), from the parent element. However, if the binding is re-assigned again and again, then it can happen infinitely loop when the inheritance is done by xbl:constructor.
This commit is contained in:
parent
4df2d498cb
commit
6bce4e5e19
@ -12,21 +12,26 @@
|
|||||||
</content>
|
</content>
|
||||||
</binding>
|
</binding>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
If these bindings are unexpectedly re-assigned, then all attributes
|
||||||
|
(including sizes) are lost and the appearance becomes broken.
|
||||||
|
To prevent this problem, the inner box should inherit all attributes
|
||||||
|
given via setTabbrowserAttribute() method, from the parent element.
|
||||||
|
See also: https://github.com/piroor/treestyletab/issues/538
|
||||||
|
|
||||||
|
On some versions, these inheritence are done by xbl:constructor.
|
||||||
|
However, it causes infinitely loop on some environments, so
|
||||||
|
now I use xbl:inherits.
|
||||||
|
See also: https://github.com/piroor/treestyletab/issues/550
|
||||||
|
-->
|
||||||
|
|
||||||
<binding id="toolbar"
|
<binding id="toolbar"
|
||||||
extends="chrome://global/content/bindings/toolbar.xml#toolbar">
|
extends="chrome://global/content/bindings/toolbar.xml#toolbar">
|
||||||
<content><xul:hbox flex="1"
|
<content><xul:hbox flex="1"
|
||||||
xbl:inherits="orient"
|
xbl:inherits="orient,width,height,treestyletab-allow-subtree-collapse,treestyletab-animation-enabled,treestyletab-closebox-inverted,treestyletab-firsttab-border,treestyletab-invert-scrollbar,treestyletab-max-tree-level,treestyletab-mode,treestyletab-narrow-scrollbar,treestyletab-print-preview,treestyletab-stack-collapsed-tabs,treestyletab-style,treestyletab-tab-contents-inverted,treestyletab-tab-inverted,treestyletab-tabbar-autohide,treestyletab-tabbar-autohide-state,treestyletab-tabbar-fixed,treestyletab-tabbar-fixed-horizontal,treestyletab-tabbar-fixed-vertical,treestyletab-tabbar-position,treestyletab-tabbar-resizing,treestyletab-tabs-indented,treestyletab-twisty-style"
|
||||||
anonid="toolbar-innerbox"
|
anonid="toolbar-innerbox"
|
||||||
class="treestyletab-toolbar-inner-box"><xbl:children/></xul:hbox></content>
|
class="treestyletab-toolbar-inner-box"><xbl:children/></xul:hbox></content>
|
||||||
<implementation>
|
<implementation>
|
||||||
<constructor><![CDATA[
|
|
||||||
// If the binding is unexpectedly re-assigned, then
|
|
||||||
// the size of the inner box is lost.
|
|
||||||
// So we have to update it immediately.
|
|
||||||
// See: https://github.com/piroor/treestyletab/issues/538
|
|
||||||
if (gBrowser.treeStyleTab)
|
|
||||||
gBrowser.treeStyleTab.updateFloatingTabbar(gBrowser.treeStyleTab.kTABBAR_UPDATE_BY_APPEARANCE_CHANGE);
|
|
||||||
]]></constructor>
|
|
||||||
<field name="treeStyleTabToolbarInnerBox" readonly="true">
|
<field name="treeStyleTabToolbarInnerBox" readonly="true">
|
||||||
document.getAnonymousElementByAttribute(this, 'anonid', 'toolbar-innerbox')
|
document.getAnonymousElementByAttribute(this, 'anonid', 'toolbar-innerbox')
|
||||||
</field>
|
</field>
|
||||||
@ -36,18 +41,10 @@
|
|||||||
<binding id="toolbar-drag"
|
<binding id="toolbar-drag"
|
||||||
extends="chrome://global/content/bindings/toolbar.xml#toolbar-drag">
|
extends="chrome://global/content/bindings/toolbar.xml#toolbar-drag">
|
||||||
<content><xul:hbox flex="1"
|
<content><xul:hbox flex="1"
|
||||||
xbl:inherits="orient"
|
xbl:inherits="orient,width,height,treestyletab-allow-subtree-collapse,treestyletab-animation-enabled,treestyletab-closebox-inverted,treestyletab-firsttab-border,treestyletab-invert-scrollbar,treestyletab-max-tree-level,treestyletab-mode,treestyletab-narrow-scrollbar,treestyletab-print-preview,treestyletab-stack-collapsed-tabs,treestyletab-style,treestyletab-tab-contents-inverted,treestyletab-tab-inverted,treestyletab-tabbar-autohide,treestyletab-tabbar-autohide-state,treestyletab-tabbar-fixed,treestyletab-tabbar-fixed-horizontal,treestyletab-tabbar-fixed-vertical,treestyletab-tabbar-position,treestyletab-tabbar-resizing,treestyletab-tabs-indented,treestyletab-twisty-style"
|
||||||
anonid="toolbar-innerbox"
|
anonid="toolbar-innerbox"
|
||||||
class="treestyletab-toolbar-inner-box"><xbl:children/></xul:hbox></content>
|
class="treestyletab-toolbar-inner-box"><xbl:children/></xul:hbox></content>
|
||||||
<implementation>
|
<implementation>
|
||||||
<constructor><![CDATA[
|
|
||||||
// If the binding is unexpectedly re-assigned, then
|
|
||||||
// the size of the inner box is lost.
|
|
||||||
// So we have to update it immediately.
|
|
||||||
// See: https://github.com/piroor/treestyletab/issues/538
|
|
||||||
if (gBrowser.treeStyleTab)
|
|
||||||
gBrowser.treeStyleTab.updateFloatingTabbar(gBrowser.treeStyleTab.kTABBAR_UPDATE_BY_APPEARANCE_CHANGE);
|
|
||||||
]]></constructor>
|
|
||||||
<field name="treeStyleTabToolbarInnerBox" readonly="true">
|
<field name="treeStyleTabToolbarInnerBox" readonly="true">
|
||||||
document.getAnonymousElementByAttribute(this, 'anonid', 'toolbar-innerbox')
|
document.getAnonymousElementByAttribute(this, 'anonid', 'toolbar-innerbox')
|
||||||
</field>
|
</field>
|
||||||
|
@ -1865,8 +1865,8 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
stripStyle.right = pos != 'right' ? '' :
|
stripStyle.right = pos != 'right' ? '' :
|
||||||
((root.screenX + root.width) - (box.screenX + box.width))+'px';
|
((root.screenX + root.width) - (box.screenX + box.width))+'px';
|
||||||
|
|
||||||
stripStyle.width = (tabContainerBox.width = width)+'px';
|
stripStyle.width = (strip.width = tabContainerBox.width = width)+'px';
|
||||||
stripStyle.height = (tabContainerBox.height = height)+'px';
|
stripStyle.height = (strip.height = tabContainerBox.height = height)+'px';
|
||||||
|
|
||||||
this._updateFloatingTabbarResizer({
|
this._updateFloatingTabbarResizer({
|
||||||
width : width,
|
width : width,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user