タブバーの縦横を切り替えた時、タブがあふれているかどうかの状態が更新さていなかったのを修正
git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@4778 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
parent
77e630276f
commit
f47aa8407b
@ -153,37 +153,6 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
b.mTabContainer.addEventListener('scroll', this, true);
|
b.mTabContainer.addEventListener('scroll', this, true);
|
||||||
|
|
||||||
|
|
||||||
let (container) {
|
|
||||||
b.mTabContainer.removeAttribute('overflow'); // Firefox 3.0.x
|
|
||||||
container = document.getAnonymousElementByAttribute(b.mTabContainer, 'class', 'tabs-container');
|
|
||||||
if (container) {
|
|
||||||
container.removeAttribute('overflow');
|
|
||||||
|
|
||||||
this.scrollBox.addEventListener('overflow', this, true);
|
|
||||||
this.scrollBox.addEventListener('underflow', this, true);
|
|
||||||
window.setTimeout(function(aBox, aTabBrowser, aContainer) {
|
|
||||||
aBox = document.getAnonymousElementByAttribute(aBox, 'anonid', 'scrollbox');
|
|
||||||
if (aBox) aBox = document.getAnonymousNodes(aBox)[0];
|
|
||||||
if (
|
|
||||||
aBox &&
|
|
||||||
(
|
|
||||||
aBox.boxObject.width > aContainer.boxObject.width ||
|
|
||||||
aBox.boxObject.height > aContainer.boxObject.height
|
|
||||||
)
|
|
||||||
) {
|
|
||||||
aTabBrowser.mTabContainer.setAttribute('overflow', true); // Firefox 3.0.x
|
|
||||||
aContainer.setAttribute('overflow', true);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
aTabBrowser.mTabContainer.removeAttribute('overflow'); // Firefox 3.0.x
|
|
||||||
aContainer.removeAttribute('overflow');
|
|
||||||
}
|
|
||||||
}, 100, this.scrollBox, b, container);
|
|
||||||
}
|
|
||||||
container = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Closing collapsed last tree breaks selected tab.
|
/* Closing collapsed last tree breaks selected tab.
|
||||||
To solve this problem, I override the setter to
|
To solve this problem, I override the setter to
|
||||||
force to set a tab and forbid it becomes null. */
|
force to set a tab and forbid it becomes null. */
|
||||||
@ -956,6 +925,7 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
window.setTimeout(function(aSelf, aTabBrowser, aSplitter, aToggler) {
|
window.setTimeout(function(aSelf, aTabBrowser, aSplitter, aToggler) {
|
||||||
delayedPostProcess(aSelf, aTabBrowser, aSplitter, aToggler);
|
delayedPostProcess(aSelf, aTabBrowser, aSplitter, aToggler);
|
||||||
aSelf.updateTabbarState();
|
aSelf.updateTabbarState();
|
||||||
|
aSelf.updateTabbarOverflow();
|
||||||
delayedPostProcess = null;
|
delayedPostProcess = null;
|
||||||
}, 0, this, b, splitter, toggler);
|
}, 0, this, b, splitter, toggler);
|
||||||
|
|
||||||
@ -971,6 +941,7 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
scrollInnerBox = null;
|
scrollInnerBox = null;
|
||||||
allTabsButton = null;
|
allTabsButton = null;
|
||||||
},
|
},
|
||||||
|
|
||||||
updateTabbarState : function()
|
updateTabbarState : function()
|
||||||
{
|
{
|
||||||
var b = this.mTabBrowser;
|
var b = this.mTabBrowser;
|
||||||
@ -1020,6 +991,39 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
this.updateAllTabsIndent();
|
this.updateAllTabsIndent();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateTabbarOverflow : function()
|
||||||
|
{
|
||||||
|
var b = this.mTabBrowser;
|
||||||
|
b.mTabContainer.removeAttribute('overflow'); // Firefox 3.0.x
|
||||||
|
var container = document.getAnonymousElementByAttribute(b.mTabContainer, 'class', 'tabs-container');
|
||||||
|
|
||||||
|
if (!container) return;
|
||||||
|
|
||||||
|
container.removeAttribute('overflow');
|
||||||
|
|
||||||
|
var scrollBox = this.scrollBox;
|
||||||
|
scrollBox.addEventListener('overflow', this, true);
|
||||||
|
scrollBox.addEventListener('underflow', this, true);
|
||||||
|
window.setTimeout(function() {
|
||||||
|
scrollBox = document.getAnonymousElementByAttribute(scrollBox, 'anonid', 'scrollbox');
|
||||||
|
if (scrollBox) scrollBox = document.getAnonymousNodes(scrollBox)[0];
|
||||||
|
if (
|
||||||
|
scrollBox &&
|
||||||
|
(
|
||||||
|
scrollBox.boxObject.width > container.boxObject.width ||
|
||||||
|
scrollBox.boxObject.height > container.boxObject.height
|
||||||
|
)
|
||||||
|
) {
|
||||||
|
b.mTabContainer.setAttribute('overflow', true); // Firefox 3.0.x
|
||||||
|
container.setAttribute('overflow', true);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
b.mTabContainer.removeAttribute('overflow'); // Firefox 3.0.x
|
||||||
|
container.removeAttribute('overflow');
|
||||||
|
}
|
||||||
|
}, 100);
|
||||||
|
},
|
||||||
|
|
||||||
destroy : function()
|
destroy : function()
|
||||||
{
|
{
|
||||||
this.endAutoHide();
|
this.endAutoHide();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user