From 251674258d90cc758bc0fcb930a77715da1ef292 Mon Sep 17 00:00:00 2001 From: Piro / YUKI Hiroshi Date: Fri, 4 Jan 2013 03:56:47 +0900 Subject: [PATCH] Move tree forward correctly by gBrowser.moveTabForward() --- content/treestyletab/license.txt | 2 +- content/treestyletab/windowHelper.js | 19 ++++++++++++++++--- 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/content/treestyletab/license.txt b/content/treestyletab/license.txt index 2de73262..38bcff55 100644 --- a/content/treestyletab/license.txt +++ b/content/treestyletab/license.txt @@ -14,7 +14,7 @@ License. The Original Code is the Tree Style Tab. The Initial Developer of the Original Code is YUKI "Piro" Hiroshi. -Portions created by the Initial Developer are Copyright (C) 2007-2012 +Portions created by the Initial Developer are Copyright (C) 2007-2013 the Initial Developer. All Rights Reserved. Contributor(s): YUKI "Piro" Hiroshi diff --git a/content/treestyletab/windowHelper.js b/content/treestyletab/windowHelper.js index 1e03902a..df4af963 100644 --- a/content/treestyletab/windowHelper.js +++ b/content/treestyletab/windowHelper.js @@ -409,11 +409,24 @@ var TreeStyleTabWindowHelper = { 'tabPos + 1', 'nextTab._tPos' ); } + else { + source = source.replace( + 'if (nextTab)', + '(function() {\n' + + ' if (this.treeStyleTab.hasChildTabs(this.mCurrentTab)) {\n' + + ' let descendant = this.treeStyleTab.getDescendantTabs(this.mCurrentTab);\n' + + ' if (descendant.length)\n' + + ' nextTab = this.treeStyleTab.getNextTab(descendant[descendant.length-1]);\n' + + ' }\n' + + '}).call(this);' + + '$&' + ); + } eval('b.moveTabForward = '+ source.replace( /(this.moveTabTo\([^;]+\);)/, '(function() {\n' + - ' var descendant = this.treeStyleTab.getDescendantTabs(nextTab);\n' + + ' let descendant = this.treeStyleTab.getDescendantTabs(nextTab);\n' + ' if (descendant.length) {\n' + ' nextTab = descendant[descendant.length-1];\n' + ' }\n' + @@ -423,7 +436,7 @@ var TreeStyleTabWindowHelper = { 'this.moveTabToStart();', '(function() {\n' + ' this.treeStyleTab.internallyTabMovingCount++;\n' + - ' var parentTab = this.treeStyleTab.getParentTab(this.mCurrentTab);\n' + + ' let parentTab = this.treeStyleTab.getParentTab(this.mCurrentTab);\n' + ' if (parentTab) {\n' + ' this.moveTabTo(this.mCurrentTab, this.treeStyleTab.getFirstChildTab(parentTab)._tPos);\n' + ' this.mCurrentTab.focus();\n' + @@ -453,7 +466,7 @@ var TreeStyleTabWindowHelper = { 'this.moveTabToEnd();', '(function() {\n' + ' this.treeStyleTab.internallyTabMovingCount++;\n' + - ' var parentTab = this.treeStyleTab.getParentTab(this.mCurrentTab);\n' + + ' let parentTab = this.treeStyleTab.getParentTab(this.mCurrentTab);\n' + ' if (parentTab) {\n' + ' this.moveTabTo(this.mCurrentTab, this.treeStyleTab.getLastChildTab(parentTab)._tPos);\n' + ' this.mCurrentTab.focus();\n' +