twisty上でドラッグ開始できなくなっていたのを修正

git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@1229 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
piro 2007-10-18 18:54:25 +00:00
parent 9b461385d3
commit 3e94c50af9
2 changed files with 49 additions and 35 deletions

View File

@ -9,6 +9,7 @@ var TreeStyleTabService = {
kCOLLAPSED : 'treestyletab-tab-collapsed', kCOLLAPSED : 'treestyletab-tab-collapsed',
kTWISTY : 'treestyletab-tab-tree-twisty', kTWISTY : 'treestyletab-tab-tree-twisty',
kTWISTY_CONTAINER : 'treestyletab-tab-tree-twisty-container',
levelMargin : 12, levelMargin : 12,
@ -330,10 +331,15 @@ var TreeStyleTabService = {
{ {
if (document.getAnonymousElementByAttribute(aTab, 'class', this.kTWISTY)) return; if (document.getAnonymousElementByAttribute(aTab, 'class', this.kTWISTY)) return;
var twisty = document.createElement('toolbarbutton'); var twisty = document.createElement('image');
twisty.setAttribute('class', this.kTWISTY); twisty.setAttribute('class', this.kTWISTY);
var container = document.createElement('hbox');
container.setAttribute('class', this.kTWISTY_CONTAINER);
container.appendChild(twisty);
var icon = document.getAnonymousElementByAttribute(aTab, 'class', 'tab-icon'); var icon = document.getAnonymousElementByAttribute(aTab, 'class', 'tab-icon');
icon.appendChild(twisty); icon.appendChild(container);
}, },
destroy : function() destroy : function()
@ -511,7 +517,7 @@ var TreeStyleTabService = {
self.moveTabSubTreeTo(aTab, b.mTabContainer.lastChild._tPos); self.moveTabSubTreeTo(aTab, b.mTabContainer.lastChild._tPos);
} : } :
parentTab ? function(aTab) { parentTab ? function(aTab) {
self.adoptTabTo(aTab, parentTab, tab, true); self.adoptTabTo(aTab, parentTab, { insertBefore : tab, dontUpdateIndent : true });
} : } :
function(aTab) { function(aTab) {
self.repudiateTab(aTab, true); self.repudiateTab(aTab, true);
@ -566,7 +572,7 @@ var TreeStyleTabService = {
for (var i = 0, maxi = children.length; i < maxi; i++) for (var i = 0, maxi = children.length; i < maxi; i++)
{ {
if (children[i] && (children[i] = this.getTabById(children[i], b))) { if (children[i] && (children[i] = this.getTabById(children[i], b))) {
this.adoptTabTo(children[i], tab, null, true); this.adoptTabTo(children[i], tab, { dontExpand : true, dontUpdateIndent : true });
tabs.push(children[i]); tabs.push(children[i]);
} }
} }
@ -575,7 +581,7 @@ var TreeStyleTabService = {
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 && (parent = this.getTabById(parent, b))) {
this.adoptTabTo(tab, parent, (before ? this.getTabById(before, b) : null ), true); this.adoptTabTo(tab, parent, { dontExpand : true, insertBefore : (before ? this.getTabById(before, b) : null ), dontUpdateIndent : true });
this.deleteTabValue(tab, this.kPARENT); this.deleteTabValue(tab, this.kPARENT);
this.updateTabsIndent([tab]); this.updateTabsIndent([tab]);
} }
@ -583,11 +589,9 @@ var TreeStyleTabService = {
this.updateTabsIndent(tabs); this.updateTabsIndent(tabs);
} }
/*
if (isSubTreeCollapsed) { if (isSubTreeCollapsed) {
this.collapseExpandTabSubTree(tab, isSubTreeCollapsed); this.collapseExpandTabSubTree(tab, isSubTreeCollapsed);
} }
*/
}, },
onTabMouseDown : function(aEvent) onTabMouseDown : function(aEvent)
@ -829,9 +833,10 @@ var TreeStyleTabService = {
/* Commands */ /* Commands */
adoptTabTo : function(aChild, aParent, aInsertBefore, aDontUpdateIndent) adoptTabTo : function(aChild, aParent, aInfo)
{ {
if (!aChild || !aParent) return; if (!aChild || !aParent) return;
if (!aInfo) aInfo = {};
var id = aChild.getAttribute(this.kID); var id = aChild.getAttribute(this.kID);
var b = this.getTabBrowserFromChildren(aParent); var b = this.getTabBrowserFromChildren(aParent);
@ -845,10 +850,11 @@ var TreeStyleTabService = {
children = ('|'+children).replace('|'+id, '').replace(/^\|/); children = ('|'+children).replace('|'+id, '').replace(/^\|/);
} }
var beforeTab = aInsertBefore ? aInsertBefore.getAttribute(this.kID) : null ; var insertBefore = aInfo.insertBefore;
if (aInsertBefore && children.indexOf(beforeTab) > -1) { var beforeTab = insertBefore ? insertBefore.getAttribute(this.kID) : null ;
if (beforeTab && children.indexOf(beforeTab) > -1) {
children = children.replace(beforeTab, id+'|'+beforeTab); children = children.replace(beforeTab, id+'|'+beforeTab);
newIndex = aInsertBefore._tPos; newIndex = insertBefore._tPos;
} }
else { else {
children = ((children || '')+'|'+id).replace(/^\|/, ''); children = ((children || '')+'|'+id).replace(/^\|/, '');
@ -866,6 +872,7 @@ var TreeStyleTabService = {
if (newIndex > aChild._tPos) newIndex--; if (newIndex > aChild._tPos) newIndex--;
this.moveTabSubTreeTo(aChild, newIndex); this.moveTabSubTreeTo(aChild, newIndex);
if (!aInfo.dontExpand) {
if ( if (
( (
aParent.getAttribute(this.kSUBTREE_COLLAPSED) == 'true' || aParent.getAttribute(this.kSUBTREE_COLLAPSED) == 'true' ||
@ -876,6 +883,7 @@ var TreeStyleTabService = {
this.collapseExpandTreesIntelligentlyFor(aChild); this.collapseExpandTreesIntelligentlyFor(aChild);
} }
else if (aParent.getAttribute(this.kSUBTREE_COLLAPSED) == 'true') { else if (aParent.getAttribute(this.kSUBTREE_COLLAPSED) == 'true') {
if (this.getPref('extensions.treestyletab.autoExpandSubTreeOnAppendChild')) {
var p = aParent; var p = aParent;
do { do {
this.collapseExpandTabSubTree(p, false); this.collapseExpandTabSubTree(p, false);
@ -888,8 +896,13 @@ var TreeStyleTabService = {
if (aParent.getAttribute(this.kCOLLAPSED) == 'true') if (aParent.getAttribute(this.kCOLLAPSED) == 'true')
this.collapseExpandTab(aChild, true); this.collapseExpandTab(aChild, true);
}
else if (aParent.getAttribute(this.kSUBTREE_COLLAPSED) == 'true' ||
aParent.getAttribute(this.kCOLLAPSED) == 'true') {
this.collapseExpandTab(aChild, true);
}
if (!aDontUpdateIndent) this.updateTabsIndent([aChild]); if (!aInfo.dontUpdateIndent) this.updateTabsIndent([aChild]);
}, },
repudiateTab : function(aChild, aDontUpdateIndent) repudiateTab : function(aChild, aDontUpdateIndent)

View File

@ -1,12 +1,14 @@
@namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"); @namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");
.treestyletab-tab-tree-twisty-container {
margin: 0 3px 0 -3px;
-moz-box-pack: start;
-moz-box-align: center;
-moz-box-flex: 1;
}
.treestyletab-tab-tree-twisty { .treestyletab-tab-tree-twisty {
-moz-appearance: none; -moz-appearance: none;
margin: -2px -3px -2px -4px;
padding: 1px;
width: auto;
height: auto;
border: none; border: none;
outline: none; outline: none;
background: none; background: none;
@ -24,4 +26,3 @@ tab:not([treestyletab-children]) .treestyletab-tab-tree-twisty {
tab[treestyletab-tab-collapsed="true"] { tab[treestyletab-tab-collapsed="true"] {
visibility: collapse; visibility: collapse;
} }