children of a newly pinned tab should be treated same to children of a closed tab (https://github.com/piroor/treestyletab/issues/155 )
This commit is contained in:
parent
893cb42a5c
commit
78a178b0c2
@ -2875,6 +2875,7 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
{
|
{
|
||||||
var tab = aEvent.originalTarget;
|
var tab = aEvent.originalTarget;
|
||||||
var b = this.mTabBrowser;
|
var b = this.mTabBrowser;
|
||||||
|
tab.__treestyletab__previousPosition = aEvent.detail;
|
||||||
|
|
||||||
// When the tab was moved before TabOpen event is fired, we have to update manually.
|
// When the tab was moved before TabOpen event is fired, we have to update manually.
|
||||||
var newlyOpened = !this.isTabInitialized(tab) && this.onTabAdded(null, tab);
|
var newlyOpened = !this.isTabInitialized(tab) && this.onTabAdded(null, tab);
|
||||||
@ -3577,24 +3578,34 @@ TreeStyleTabBrowser.prototype = {
|
|||||||
{
|
{
|
||||||
var parentTab = this.getParentTab(aTab);
|
var parentTab = this.getParentTab(aTab);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Children of the newly pinned tab are possibly
|
||||||
|
* moved to the top of the tab bar, by TabMove event
|
||||||
|
* from the newly pinned tab. So, we have to
|
||||||
|
* reposition unexpectedly moved children.
|
||||||
|
*/
|
||||||
if (!parentTab) {
|
if (!parentTab) {
|
||||||
this.collapseExpandSubtree(aTab, false);
|
/**
|
||||||
|
* Universal but dangerous logic. "__treestyletab__previousPosition"
|
||||||
|
* can be broken by multiple movings.
|
||||||
|
*/
|
||||||
|
let b = this.browser;
|
||||||
|
this.internallyTabMovingCount++;
|
||||||
|
this.getDescendantTabs(aTab).reverse().forEach(function(aChildTab) {
|
||||||
|
if (aChildTab.__treestyletab__previousPosition > aChildTab._tPos)
|
||||||
|
b.moveTabTo(aChildTab, aChildTab.__treestyletab__previousPosition);
|
||||||
|
}, this);
|
||||||
|
this.internallyTabMovingCount--;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/**
|
/**
|
||||||
* This logic should work for any pinned tabs, but, now we have
|
* Safer logic. This cannot be available for "root" tabs because
|
||||||
* no way to know previous positions of children correctly when
|
* their children (already moved) have no way to know the anchor
|
||||||
* the pinned tab has no parent...
|
* position (the next sibling of the pinned tab itself).
|
||||||
*/
|
*/
|
||||||
let b = this.browser;
|
let b = this.browser;
|
||||||
this.internallyTabMovingCount++;
|
this.internallyTabMovingCount++;
|
||||||
this.getChildTabs(aTab).reverse().forEach(function(aChildTab) {
|
this.getChildTabs(aTab).reverse().forEach(function(aChildTab) {
|
||||||
/**
|
|
||||||
* Children of the newly pinned tab are possibly
|
|
||||||
* moved to the top of the tab bar, by TabMove event
|
|
||||||
* from the newly pinned tab. So, we have to
|
|
||||||
* reposition unexpectedly moved children.
|
|
||||||
*/
|
|
||||||
if (aChildTab._tPos < parentTab._tPos)
|
if (aChildTab._tPos < parentTab._tPos)
|
||||||
b.moveTabTo(aChildTab, parentTab._tPos);
|
b.moveTabTo(aChildTab, parentTab._tPos);
|
||||||
}, this);
|
}, this);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user