refactoring around performDrop()
This commit is contained in:
parent
213aa81361
commit
c39d55061a
@ -4339,6 +4339,22 @@ TreeStyleTabBrowser.prototype = {
|
||||
), this);
|
||||
},
|
||||
|
||||
partTabs : function TSTBrowser_partTabs(aTabs)
|
||||
{
|
||||
var aTabs = Array.slice(aTabs);
|
||||
for each (let tab in aTabs)
|
||||
{
|
||||
if (aTabs.indexOf(this.getParentTab(tab)) > -1)
|
||||
continue;
|
||||
this.partAllChildren(tab, {
|
||||
behavior : this.getCloseParentBehaviorForTab(
|
||||
tab,
|
||||
this.kCLOSE_PARENT_BEHAVIOR_PROMOTE_FIRST_CHILD
|
||||
)
|
||||
});
|
||||
}
|
||||
},
|
||||
|
||||
getCloseParentBehaviorForTab : function TSTBrowser_getCloseParentBehaviorForTab(aTab, aDefaultBehavior)
|
||||
{
|
||||
var closeParentBehavior = this.getTreePref('closeParentBehavior');
|
||||
@ -4693,6 +4709,24 @@ TreeStyleTabBrowser.prototype = {
|
||||
return false;
|
||||
},
|
||||
|
||||
importTab : function TSTBrowser_importTab(aTab)
|
||||
{
|
||||
var newTab = this.mTabBrowser.addTab();
|
||||
newTab.linkedBrowser.stop();
|
||||
newTab.linkedBrowser.docShell;
|
||||
this.mTabBrowser.swapBrowsersAndCloseOther(newTab, aTab);
|
||||
this.mTabBrowser.setTabTitle(newTab);
|
||||
return newTab;
|
||||
},
|
||||
|
||||
duplicateTabAsOrphan : function TSTBrowser_duplicateTabAsOrphan(aTab)
|
||||
{
|
||||
var newTab = this.mTabBrowser.duplicateTab(aTab);
|
||||
this.deleteTabValue(newTab, this.kCHILDREN);
|
||||
this.deleteTabValue(newTab, this.kPARENT);
|
||||
return newTab;
|
||||
},
|
||||
|
||||
/* collapse/expand */
|
||||
|
||||
collapseExpandSubtree : function TSTBrowser_collapseExpandSubtree(aTab, aCollapse, aJustNow) /* PUBLIC API */
|
||||
|
@ -401,21 +401,22 @@ catch(e) {
|
||||
var tabsInfo = this.getDraggedTabsInfoFromOneTab(aInfo, aDraggedTab);
|
||||
if (!tabsInfo.draggedTab) return false;
|
||||
|
||||
var sourceWindow = aDraggedTab.ownerDocument.defaultView;
|
||||
var sourceBrowser = sourceWindow.TreeStyleTabService.getTabBrowserFromChild(aDraggedTab);
|
||||
var sourceService = sourceBrowser.treeStyleTab;
|
||||
|
||||
aDraggedTab = tabsInfo.draggedTab;
|
||||
var draggedTabs = tabsInfo.draggedTabs;
|
||||
var draggedRoots = sv.collectRootTabs(tabsInfo.draggedTabs);
|
||||
var draggedRoots = sourceService.collectRootTabs(tabsInfo.draggedTabs);
|
||||
|
||||
|
||||
var targetBrowser = b;
|
||||
var tabs = sv.getTabsArray(targetBrowser);
|
||||
|
||||
var sourceWindow = aDraggedTab.ownerDocument.defaultView;
|
||||
var sourceBrowser = sv.getTabBrowserFromChild(aDraggedTab);
|
||||
var tabs = sourceService.getTabsArray(targetBrowser);
|
||||
|
||||
var draggedWholeTree = [].concat(draggedRoots);
|
||||
for each (let root in draggedRoots)
|
||||
{
|
||||
let tabs = sv.getDescendantTabs(root);
|
||||
let tabs = sourceService.getDescendantTabs(root);
|
||||
for each (let tab in tabs)
|
||||
{
|
||||
if (draggedWholeTree.indexOf(tab) < 0)
|
||||
@ -429,19 +430,8 @@ catch(e) {
|
||||
if (draggedWholeTree.length != selectedTabs.length &&
|
||||
selectedTabs.length) {
|
||||
draggedTabs = draggedRoots = selectedTabs;
|
||||
if (aInfo.action & sv.kACTIONS_FOR_SOURCE) {
|
||||
for each (let tab in Array.slice(selectedTabs))
|
||||
{
|
||||
if (selectedTabs.indexOf(sv.getParentTab(tab)) > -1)
|
||||
continue;
|
||||
sv.partAllChildren(tab, {
|
||||
behavior : sv.getCloseParentBehaviorForTab(
|
||||
tab,
|
||||
sv.kCLOSE_PARENT_BEHAVIOR_PROMOTE_FIRST_CHILD
|
||||
)
|
||||
});
|
||||
}
|
||||
}
|
||||
if (aInfo.action & sv.kACTIONS_FOR_SOURCE)
|
||||
sourceService.partTabs(selectedTabs);
|
||||
}
|
||||
|
||||
while (aInfo.insertBefore && draggedWholeTree.indexOf(aInfo.insertBefore) > -1)
|
||||
@ -462,7 +452,7 @@ catch(e) {
|
||||
|
||||
if ( // if this move will cause no change...
|
||||
sourceBrowser == targetBrowser &&
|
||||
sourceBrowser.treeStyleTab.getNextVisibleTab(draggedTabs[draggedTabs.length-1]) == aInfo.insertBefore
|
||||
sourceService.getNextVisibleTab(draggedTabs[draggedTabs.length-1]) == aInfo.insertBefore
|
||||
) {
|
||||
// then, do nothing
|
||||
return true;
|
||||
@ -475,105 +465,74 @@ catch(e) {
|
||||
targetBrowser.movingSelectedTabs = true;
|
||||
|
||||
|
||||
var newRoots = [];
|
||||
var shouldClose = (
|
||||
aInfo.action & sv.kACTION_IMPORT &&
|
||||
sv.getAllTabsArray(sourceBrowser).length == draggedTabs.length
|
||||
sourceService.getAllTabsArray(sourceBrowser).length == draggedTabs.length
|
||||
);
|
||||
var oldTabs = [];
|
||||
var newTabs = [];
|
||||
var treeStructure = draggedTabs.map(function(aTab) {
|
||||
var parent = sourceBrowser.treeStyleTab.getParentTab(aTab);
|
||||
return parent ? draggedTabs.indexOf(parent) : -1 ;
|
||||
});
|
||||
|
||||
var parentTabsArray = draggedTabs.map(function(aTab) {
|
||||
return (aInfo.action & sv.kACTIONS_FOR_DESTINATION) ?
|
||||
sourceBrowser.treeStyleTab.getParentTab(aTab) : null ;
|
||||
}, this);
|
||||
var treeStructure = sourceService.getTreeStructureFromTabs(draggedTabs);
|
||||
|
||||
// Firefox fails to "move" collapsed tabs. So, expand them first
|
||||
// and collapse them after they are moved.
|
||||
var collapseExpandState = [];
|
||||
if (aInfo.action & sv.kACTION_MOVE || aInfo.action & sv.kACTION_IMPORT) {
|
||||
for each (let tab in draggedWholeTree)
|
||||
{
|
||||
collapseExpandState.push(sv.getTabValue(tab, sv.kSUBTREE_COLLAPSED) == 'true');
|
||||
sv.collapseExpandSubtree(tab, false, true);
|
||||
sv.collapseExpandTab(tab, false, true);
|
||||
}
|
||||
}
|
||||
var collapsedStates = (
|
||||
aInfo.action & sv.kACTION_MOVE ||
|
||||
aInfo.action & sv.kACTION_IMPORT ||
|
||||
aInfo.action & sv.kACTION_DUPLICATE
|
||||
) ?
|
||||
sourceService.forceExpandTabs(draggedWholeTree) :
|
||||
[] ;
|
||||
|
||||
var lastTabIndex = tabs[tabs.length -1]._tPos;
|
||||
for (let i in draggedTabs)
|
||||
{
|
||||
let tab = draggedTabs[i];
|
||||
let TST = sourceService;
|
||||
if (aInfo.action & sv.kACTIONS_FOR_DESTINATION) {
|
||||
let parent = parentTabsArray[i];
|
||||
if (tabsInfo.isMultipleMove && 'MultipleTabService' in sourceWindow)
|
||||
sourceWindow.MultipleTabService.setSelection(tab, false);
|
||||
if (aInfo.action & sv.kACTION_IMPORT) {
|
||||
let newTab = targetBrowser.addTab();
|
||||
newTab.linkedBrowser.stop();
|
||||
newTab.linkedBrowser.docShell;
|
||||
targetBrowser.swapBrowsersAndCloseOther(newTab, tab);
|
||||
targetBrowser.setTabTitle(newTab);
|
||||
tab = newTab;
|
||||
}
|
||||
else {
|
||||
newTab = targetBrowser.duplicateTab(tab);
|
||||
sv.deleteTabValue(newTab, sv.kCHILDREN);
|
||||
sv.deleteTabValue(newTab, sv.kPARENT);
|
||||
if (aInfo.action & sv.kACTION_IMPORT)
|
||||
oldTabs.push(tab);
|
||||
tab = newTab;
|
||||
}
|
||||
tab = (aInfo.action & sv.kACTION_IMPORT) ?
|
||||
sv.importTab(tab) :
|
||||
sv.duplicateTabAsOrphan(tab) ;
|
||||
newTabs.push(tab);
|
||||
if (tabsInfo.isMultipleMove && 'MultipleTabService' in w)
|
||||
w.MultipleTabService.setSelection(tab, true);
|
||||
if (!parent || draggedTabs.indexOf(parent) < 0)
|
||||
newRoots.push(tab);
|
||||
lastTabIndex++;
|
||||
TST = sv;
|
||||
}
|
||||
|
||||
let newIndex = aInfo.insertBefore ? aInfo.insertBefore._tPos : lastTabIndex ;
|
||||
if (aInfo.insertBefore && newIndex > tab._tPos) newIndex--;
|
||||
|
||||
sv.internallyTabMovingCount++;
|
||||
TST.internallyTabMovingCount++;
|
||||
targetBrowser.moveTabTo(tab, newIndex);
|
||||
sv.collapseExpandTab(tab, false, true);
|
||||
sv.internallyTabMovingCount--;
|
||||
TST.collapseExpandTab(tab, false, true);
|
||||
TST.internallyTabMovingCount--;
|
||||
}
|
||||
|
||||
// close imported tabs from the source browser
|
||||
for each (let tab in oldTabs)
|
||||
{
|
||||
sourceBrowser.removeTab(tab, { animate : true });
|
||||
}
|
||||
if (shouldClose)
|
||||
this.closeOwner(sourceBrowser);
|
||||
|
||||
// restore tree structure for newly opened tabs
|
||||
for (let i in newTabs)
|
||||
{
|
||||
let index = treeStructure[i];
|
||||
if (index < 0) continue;
|
||||
sv.attachTabTo(newTabs[i], newTabs[index]);
|
||||
};
|
||||
|
||||
if (newTabs.length || aInfo.action & sv.kACTION_MOVE || aInfo.action & sv.kACTION_IMPORT) {
|
||||
for (let i = collapseExpandState.length - 1; i > -1; i--)
|
||||
{
|
||||
let collapsed = collapseExpandState[i];
|
||||
sv.collapseExpandSubtree(draggedWholeTree[i], collapsed, true);
|
||||
if (newTabs.length)
|
||||
sv.collapseExpandSubtree(newTabs[i], collapsed, true);
|
||||
}
|
||||
sv.applyTreeStructureToTabs(
|
||||
newTabs,
|
||||
treeStructure,
|
||||
collapsedStates.map(function(aCollapsed) {
|
||||
return !aCollapsed
|
||||
})
|
||||
);
|
||||
|
||||
for (let i = collapsedStates.length - 1; i > -1; i--)
|
||||
{
|
||||
sourceService.collapseExpandSubtree(draggedWholeTree[i], collapsedStates[i], true);
|
||||
}
|
||||
|
||||
if (aInfo.action & sv.kACTIONS_FOR_DESTINATION &&
|
||||
aInfo.action & sv.kACTION_ATTACH)
|
||||
this.attachTabsOnDrop(newRoots, aInfo.parent);
|
||||
if (newTabs.length && aInfo.action & sv.kACTION_ATTACH)
|
||||
this.attachTabsOnDrop(
|
||||
newTabs.filter(function(aTab, aIndex) {
|
||||
return treeStructure[aIndex] == -1;
|
||||
}),
|
||||
aInfo.parent
|
||||
);
|
||||
|
||||
// Multiple Tab Handler
|
||||
targetBrowser.movingSelectedTabs = false;
|
||||
@ -585,10 +544,11 @@ catch(e) {
|
||||
getDraggedTabsInfoFromOneTab : function TabbarDND_getDraggedTabsInfoFromOneTab(aInfo, aTab)
|
||||
{
|
||||
var sv = this.treeStyleTab;
|
||||
var b = this.browser;
|
||||
var w = this.window;
|
||||
var sourceWindow = aTab.ownerDocument.defaultView;
|
||||
var sourceBrowser = sourceWindow.TreeStyleTabService.getTabBrowserFromChild(aTab);
|
||||
var sourceService = sourceBrowser.treeStyleTab;
|
||||
|
||||
aTab = sv.getTabFromChild(aTab);
|
||||
aTab = sourceService.getTabFromChild(aTab);
|
||||
if (!aTab || !aTab.parentNode) // ignore removed tabs!
|
||||
return {
|
||||
draggedTab : null,
|
||||
@ -596,20 +556,14 @@ catch(e) {
|
||||
isMultipleMove : false
|
||||
};
|
||||
|
||||
var targetBrowser = b;
|
||||
var tabs = sv.getTabsArray(targetBrowser);
|
||||
|
||||
var sourceWindow = aTab.ownerDocument.defaultView;
|
||||
var sourceBrowser = sv.getTabBrowserFromChild(aTab);
|
||||
|
||||
var draggedTabs = w['piro.sakura.ne.jp'].tabsDragUtils.getSelectedTabs(aTab || sourceBrowser || aInfo.event);
|
||||
var draggedTabs = sourceWindow['piro.sakura.ne.jp'].tabsDragUtils.getSelectedTabs(aTab || sourceBrowser || aInfo.event);
|
||||
var isMultipleMove = false;
|
||||
|
||||
if (draggedTabs.length > 1) {
|
||||
isMultipleMove = true;
|
||||
}
|
||||
else if (aInfo.action & sv.kACTIONS_FOR_DESTINATION) {
|
||||
draggedTabs = [aTab].concat(sourceBrowser.treeStyleTab.getDescendantTabs(aTab));
|
||||
draggedTabs = [aTab].concat(sourceService.getDescendantTabs(aTab));
|
||||
}
|
||||
|
||||
return {
|
||||
@ -621,8 +575,8 @@ catch(e) {
|
||||
|
||||
attachTabsOnDrop : function TabbarDND_attachTabsOnDrop(aTabs, aParent)
|
||||
{
|
||||
var sv = this.treeStyleTab;
|
||||
var b = this.browser;
|
||||
var b = aTabs[0].ownerDocument.defaultView.TreeStyleTabService.getTabBrowserFromChild(aTabs[0]);
|
||||
var sv = b.treeStyleTab;
|
||||
|
||||
b.movingSelectedTabs = true; // Multiple Tab Handler
|
||||
aTabs.forEach(function(aTab) {
|
||||
@ -638,8 +592,8 @@ catch(e) {
|
||||
|
||||
partTabsOnDrop : function TabbarDND_partTabsOnDrop(aTabs)
|
||||
{
|
||||
var sv = this.treeStyleTab;
|
||||
var b = this.browser;
|
||||
var b = aTabs[0].ownerDocument.defaultView.TreeStyleTabService.getTabBrowserFromChild(aTabs[0]);
|
||||
var sv = b.treeStyleTab;
|
||||
|
||||
b.movingSelectedTabs = true; // Multiple Tab Handler
|
||||
aTabs.forEach(function(aTab) {
|
||||
|
@ -2081,21 +2081,11 @@ var TreeStyleTabUtils = {
|
||||
|
||||
collectRootTabs : function TSTUtils_collectRootTabs(aTabs) /* PUBLIC API */
|
||||
{
|
||||
var roots = [];
|
||||
aTabs.forEach(function(aTab) {
|
||||
var parent = aTab,
|
||||
current;
|
||||
do {
|
||||
current = parent;
|
||||
parent = this.getParentTab(parent)
|
||||
if (parent && aTabs.indexOf(parent) > -1) continue;
|
||||
if (aTabs.indexOf(current) < 0)
|
||||
aTabs.push(current);
|
||||
return;
|
||||
}
|
||||
while (parent);
|
||||
aTabs = Array.slice(aTabs);
|
||||
return aTabs.filter(function(aTab) {
|
||||
var parent = this.getParentTab(aTab);
|
||||
return !parent || aTabs.indexOf(parent) < 0;
|
||||
}, this);
|
||||
return roots;
|
||||
},
|
||||
|
||||
getChildIndex : function TSTUtils_getChildIndex(aTab, aParent) /* PUBLIC API */
|
||||
@ -2187,6 +2177,18 @@ var TreeStyleTabUtils = {
|
||||
).numberValue;
|
||||
},
|
||||
|
||||
forceExpandTabs : function TSTUtils_forceExpandTabs(aTabs)
|
||||
{
|
||||
var collapsedStates = aTabs.map(function(aTab) {
|
||||
return this.getTabValue(aTab, this.kSUBTREE_COLLAPSED) == 'true';
|
||||
}, this);
|
||||
aTabs.forEach(function(aTab) {
|
||||
this.collapseExpandSubtree(aTab, false, true);
|
||||
this.collapseExpandTab(aTab, false, true);
|
||||
}, this);
|
||||
return collapsedStates;
|
||||
},
|
||||
|
||||
getTreeStructureFromTabs : function TSTUtils_getTreeStructureFromTabs(aTabs)
|
||||
{
|
||||
/* this returns...
|
||||
@ -2229,7 +2231,7 @@ var TreeStyleTabUtils = {
|
||||
return aTreeStructure;
|
||||
},
|
||||
|
||||
applyTreeStructureToTabs : function TSTUtils_applyTreeStructureToTabs(aTabs, aTreeStructure, aExpandAllTree)
|
||||
applyTreeStructureToTabs : function TSTUtils_applyTreeStructureToTabs(aTabs, aTreeStructure, aExpandStates)
|
||||
{
|
||||
var b = this.getTabBrowserFromChild(aTabs[0]);
|
||||
if (!b) return;
|
||||
@ -2238,30 +2240,40 @@ var TreeStyleTabUtils = {
|
||||
aTabs = aTabs.slice(0, aTreeStructure.length);
|
||||
aTreeStructure = aTreeStructure.slice(0, aTabs.length);
|
||||
|
||||
aExpandStates = (aExpandStates && typeof aExpandStates == 'object') ?
|
||||
aExpandStates :
|
||||
aTabs.map(function(aTab) {
|
||||
return !!aExpandStates;
|
||||
});
|
||||
aExpandStates = aExpandStates.slice(0, aTabs.length);
|
||||
while (aExpandStates.length < aTabs.length) aExpandStates.push(-1);
|
||||
|
||||
var parentTab = null;
|
||||
aTabs.forEach(function(aTab, aIndex) {
|
||||
if (sv.isCollapsed(aTab)) sv.collapseExpandTab(aTab, false, true);
|
||||
sv.partTab(aTab);
|
||||
|
||||
var pareintIndexInTree = aTreeStructure[aIndex];
|
||||
if (pareintIndexInTree < 0) { // there is no parent, so this is a new parent!
|
||||
var parentIndexInTree = aTreeStructure[aIndex];
|
||||
if (parentIndexInTree < 0) // there is no parent, so this is a new parent!
|
||||
parentTab = aTab.getAttribute(sv.kID);
|
||||
}
|
||||
|
||||
var parent = sv.getTabById(parentTab);
|
||||
if (parent) {
|
||||
let tabs = [parent].concat(sv.getDescendantTabs(parent));
|
||||
parent = pareintIndexInTree < tabs.length ? tabs[pareintIndexInTree] : parent ;
|
||||
parent = parentIndexInTree < tabs.length ? tabs[parentIndexInTree] : parent ;
|
||||
}
|
||||
if (parent) {
|
||||
sv.attachTabTo(aTab, parent, {
|
||||
dontExpand : true,
|
||||
dontMove : true
|
||||
});
|
||||
if (aExpandAllTree)
|
||||
sv.collapseExpandSubtree(parent, false);
|
||||
}
|
||||
}, sv);
|
||||
});
|
||||
|
||||
for (let i = aTabs.length-1; i > -1; i--)
|
||||
{
|
||||
sv.collapseExpandSubtree(aTabs[i], !aExpandStates[i], true);
|
||||
}
|
||||
},
|
||||
|
||||
getTreeStructureFromTabBrowser : function TSTUtils_getTreeStructureFromTabBrowser(aTabBrowser)
|
||||
|
Loading…
x
Reference in New Issue
Block a user