rearrange thumbnails dynamically on TabMove

This commit is contained in:
Piro / SHIMODA Hiroshi 2011-01-12 04:16:35 +09:00
parent 33525e2989
commit 3b3f904b77

View File

@ -392,8 +392,6 @@ TreeStyleTabBrowser.prototype = {
window.addEventListener('resize', this, true); window.addEventListener('resize', this, true);
window.addEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_ENTERED, this, false); window.addEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_ENTERED, this, false);
window.addEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_EXITED, this, false); window.addEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_EXITED, this, false);
window.addEventListener('tabviewshown', this, true);
window.addEventListener('tabviewhidden', this, true);
b.addEventListener('nsDOMMultipleTabHandlerTabsClosing', this, false); b.addEventListener('nsDOMMultipleTabHandlerTabsClosing', this, false);
@ -1549,8 +1547,6 @@ TreeStyleTabBrowser.prototype = {
window.removeEventListener('resize', this, true); window.removeEventListener('resize', this, true);
window.removeEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_ENTERED, this, false); window.removeEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_ENTERED, this, false);
window.removeEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_EXITED, this, false); window.removeEventListener(this.kEVENT_TYPE_PRINT_PREVIEW_EXITED, this, false);
window.removeEventListener('tabviewshown', this, true);
window.removeEventListener('tabviewhidden', this, true);
b.removeEventListener('nsDOMMultipleTabHandlerTabsClosing', this, false); b.removeEventListener('nsDOMMultipleTabHandlerTabsClosing', this, false);
@ -1956,11 +1952,6 @@ TreeStyleTabBrowser.prototype = {
case this.kEVENT_TYPE_PRINT_PREVIEW_EXITED: case this.kEVENT_TYPE_PRINT_PREVIEW_EXITED:
return this.onTreeStyleTabPrintPreviewExited(aEvent); return this.onTreeStyleTabPrintPreviewExited(aEvent);
case 'tabviewshown':
return this.onTabViewShown();
case 'tabviewhidden':
return this.onTabViewHidden();
case 'nsDOMMultipleTabHandlerTabsClosing': case 'nsDOMMultipleTabHandlerTabsClosing':
if (!this.onTabsRemoving(aEvent)) if (!this.onTabsRemoving(aEvent))
@ -2327,8 +2318,6 @@ TreeStyleTabBrowser.prototype = {
onTabMove : function TSTBrowser_onTabMove(aEvent) onTabMove : function TSTBrowser_onTabMove(aEvent)
{ {
if (this._tabViewShown) this._tabViewTabMoveCount++;
var tab = aEvent.originalTarget; var tab = aEvent.originalTarget;
var b = this.mTabBrowser; var b = this.mTabBrowser;
@ -2403,6 +2392,7 @@ TreeStyleTabBrowser.prototype = {
return; return;
this.attachTabFromPosition(tab, aEvent.detail); this.attachTabFromPosition(tab, aEvent.detail);
this.rearrangeTabViewItems(tab);
}, },
attachTabFromPosition : function TSTBrowser_attachTabFromPosition(aTab, aOldPosition) attachTabFromPosition : function TSTBrowser_attachTabFromPosition(aTab, aOldPosition)
@ -2488,6 +2478,20 @@ TreeStyleTabBrowser.prototype = {
); );
}, },
rearrangeTabViewItems : function TSTBrowser_rearrangeTabViewItems(aTab)
{
if (
!('TabView' in window) ||
!TabView.isVisible() ||
!aTab.tabItem ||
!aTab.tabItem.parent ||
!aTab.tabItem.parent.reorderTabItemsBasedOnTabOrder
)
return;
aTab.tabItem.parent.reorderTabItemsBasedOnTabOrder();
},
onTabVisibilityChanged : function TSTBrowser_onTabVisibilityChanged(aEvent) onTabVisibilityChanged : function TSTBrowser_onTabVisibilityChanged(aEvent)
{ {
this.updateInvertedTabContentsOrder(aEvent.originalTarget); this.updateInvertedTabContentsOrder(aEvent.originalTarget);
@ -3348,38 +3352,6 @@ TreeStyleTabBrowser.prototype = {
this.removeTabbrowserAttribute(this.kPRINT_PREVIEW); this.removeTabbrowserAttribute(this.kPRINT_PREVIEW);
}, },
onTabViewShown : function TSTBrowser_onTabViewShown(aEvent)
{
this._tabViewShown = true;
this._tabViewTabMoveCount = 0;
},
onTabViewHidden : function TSTBrowser_onTabViewHidden(aEvent)
{
var count = this._tabViewTabMoveCount;
this._tabViewShown = false;
this._tabViewTabMoveCount = -1;
var w = TabView._window;
if (
!count ||
!w ||
!w.UI ||
!w.UI.setReorderTabItemsOnShow ||
!w.GroupItems ||
!w.GroupItems.groupItems ||
!w.GroupItems.groupItems.length
)
return;
w.GroupItems.groupItems.forEach(function(aGroupItem) {
w.UI.setReorderTabItemsOnShow(aGroupItem);
});
},
_tabViewShown : false,
_tabViewTabMoveCount : -1,
/* commands */ /* commands */
/* reset */ /* reset */