セッション保存APIを用いたセッションの保存時にタブのツリーの状態が完全には

保存されていなかったのを修正


git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@1343 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
piro 2007-10-26 10:25:59 +00:00
parent c33cd32ea1
commit 7e22e0548a

View File

@ -229,11 +229,11 @@ var TreeStyleTabService = {
if (aTab.__treestyletab__linkedTabBrowser) if (aTab.__treestyletab__linkedTabBrowser)
return aTab.__treestyletab__linkedTabBrowser; return aTab.__treestyletab__linkedTabBrowser;
var target = aTab; return this.evaluateXPath(
while (target.localName != 'tabbrowser' && target.parentNode) 'ancestor-or-self::xul:tabbrowser',
target = target.parentNode; aTab,
XPathResult.FIRST_ORDERED_NODE_TYPE
return (target.localName == 'tabbrowser') ? target : null ; ).singleNodeValue;
}, },
getTabBrowserFromFrame : function(aFrame) getTabBrowserFromFrame : function(aFrame)
@ -923,15 +923,6 @@ catch(e) {
aTabBrowser.__treestyletab__observer.destroy(); aTabBrowser.__treestyletab__observer.destroy();
delete aTabBrowser.__treestyletab__observer; delete aTabBrowser.__treestyletab__observer;
var tabs = aTabBrowser.mTabContainer.childNodes;
var parent;
for (var i = 0, maxi = tabs.length; i < maxi; i++)
{
parent = this.getParentTab(tabs[i]);
if (parent)
this.setTabValue(tabs[i], this.kPARENT, parent.getAttribute(this.kID));
}
aTabBrowser.mTabContainer.removeEventListener('TreeStyleTab:TabOpen', this, true); aTabBrowser.mTabContainer.removeEventListener('TreeStyleTab:TabOpen', this, true);
aTabBrowser.mTabContainer.removeEventListener('TabClose', this, true); aTabBrowser.mTabContainer.removeEventListener('TabClose', this, true);
aTabBrowser.mTabContainer.removeEventListener('TabMove', this, true); aTabBrowser.mTabContainer.removeEventListener('TabMove', this, true);
@ -1067,12 +1058,9 @@ catch(e) {
var parentTab = this.getParentTab(tab); var parentTab = this.getParentTab(tab);
var nextFocusedTab = null; var nextFocusedTab = null;
if (parentTab) { var next = this.getNextSiblingTab(tab);
this.setTabValue(tab, this.kPARENT, parentTab.getAttribute(this.kID)); if (next)
var next = this.getNextSiblingTab(tab); this.setTabValue(tab, this.kINSERT_BEFORE, next.getAttribute(this.kID));
if (next)
this.setTabValue(tab, this.kINSERT_BEFORE, next.getAttribute(this.kID));
}
if (firstChild) { if (firstChild) {
var backupChildren = this.getTabValue(tab, this.kCHILDREN); var backupChildren = this.getTabValue(tab, this.kCHILDREN);
@ -1169,17 +1157,29 @@ catch(e) {
var parent = this.getTabValue(tab, this.kPARENT); var parent = this.getTabValue(tab, this.kPARENT);
var before = this.getTabValue(tab, this.kINSERT_BEFORE); var before = this.getTabValue(tab, this.kINSERT_BEFORE);
if (parent && (parent = this.getTabById(parent, b))) { if (parent) {
this.attachTabTo(tab, parent, { dontExpand : true, insertBefore : (before ? this.getTabById(before, b) : null ), dontUpdateIndent : true }); parent = this.getTabById(parent, b);
this.deleteTabValue(tab, this.kPARENT); if (parent) {
this.updateTabsIndent([tab]); this.attachTabTo(tab, parent, { dontExpand : true, insertBefore : (before ? this.getTabById(before, b) : null ), dontUpdateIndent : true });
this.checkTabsIndentOverflow(b); this.updateTabsIndent([tab]);
this.checkTabsIndentOverflow(b);
}
else {
this.deleteTabValue(tab, this.kPARENT);
}
} }
else if (children) { else if (children) {
this.updateTabsIndent(tabs); this.updateTabsIndent(tabs);
this.checkTabsIndentOverflow(b); this.checkTabsIndentOverflow(b);
} }
if (!parent && (before = this.getTabById(before, b))) {
var index = before._tPos;
if (index > tab._tPos) index--;
b.moveTabTo(tab, index);
}
this.deleteTabValue(tab, this.kINSERT_BEFORE);
if (isSubTreeCollapsed) { if (isSubTreeCollapsed) {
this.collapseExpandTabSubTree(tab, isSubTreeCollapsed); this.collapseExpandTabSubTree(tab, isSubTreeCollapsed);
} }
@ -1778,6 +1778,7 @@ catch(e) {
} }
this.setTabValue(aParent, this.kCHILDREN, children); this.setTabValue(aParent, this.kCHILDREN, children);
this.setTabValue(aChild, this.kPARENT, aParent.getAttribute(this.kID));
this.updateTabsCount(aParent); this.updateTabsCount(aParent);
if (newIndex > aChild._tPos) newIndex--; if (newIndex > aChild._tPos) newIndex--;