セッション保存APIを用いたセッションの保存時にタブのツリーの状態が完全には
保存されていなかったのを修正 git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@1343 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
parent
c33cd32ea1
commit
7e22e0548a
@ -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--;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user