split and rearrange methods

This commit is contained in:
Piro / SHIMODA Hiroshi 2011-01-22 13:06:59 +09:00
parent dbbdc42aca
commit 54eaa6aa78

View File

@ -321,44 +321,21 @@ TreeStyleTabBrowser.prototype = {
{ {
this.stopRendering(); this.stopRendering();
this.updateFloatingTabbarReason = 0;
var b = this.mTabBrowser; var b = this.mTabBrowser;
b.tabContainer.treeStyleTab = this; b.tabContainer.treeStyleTab = this;
if (b.tabContainer.parentNode.localName == 'toolbar') if (b.tabContainer.parentNode.localName == 'toolbar')
b.tabContainer.parentNode.classList.add(this.kTABBAR_TOOLBAR); b.tabContainer.parentNode.classList.add(this.kTABBAR_TOOLBAR);
this.tabsHash = {}; this.tabsHash = {};
this.tabStripPlaceHolder = null;
this.tabVisibilityChangedTabs = []; this.tabVisibilityChangedTabs = [];
this._updateFloatingTabbarReason = 0;
this.internallyTabMovingCount = 0; this.internallyTabMovingCount = 0;
this.subTreeMovingCount = 0; this.subTreeMovingCount = 0;
this.subTreeChildrenMovingCount = 0; this.subTreeChildrenMovingCount = 0;
this._treeViewEnabled = true; this._treeViewEnabled = true;
let (toggler, placeHolder) { this._initTabbrowserExtraContents();
toggler = document.getAnonymousElementByAttribute(b, 'class', this.kTABBAR_TOGGLER);
if (!toggler) {
toggler = document.createElement('spacer');
toggler.setAttribute('class', this.kTABBAR_TOGGLER);
toggler.setAttribute('layer', true); // https://bugzilla.mozilla.org/show_bug.cgi?id=590468
b.mTabBox.insertBefore(toggler, b.mTabBox.firstChild);
if (b.mTabDropIndicatorBar == toggler)
b.mTabDropIndicatorBar = document.getAnonymousElementByAttribute(b, 'class', 'tab-drop-indicator-bar');
}
placeHolder = document.getAnonymousElementByAttribute(b, 'anonid', 'strip');
if (!placeHolder) {
placeHolder = document.createElement('hbox');
placeHolder.setAttribute('anonid', 'strip');
placeHolder.setAttribute('class', 'tabbrowser-strip '+this.kTABBAR_PLACEHOLDER);
placeHolder.setAttribute('layer', true); // https://bugzilla.mozilla.org/show_bug.cgi?id=590468
b.mTabBox.insertBefore(placeHolder, toggler.nextSibling);
}
if (placeHolder != this.tabStrip)
this.tabStripPlaceHolder = placeHolder;
}
let position = this.currentTabbarPosition; let position = this.currentTabbarPosition;
this.fireTabbarPositionEvent(this.kEVENT_TYPE_TABBAR_POSITION_CHANGING, 'top', position); /* PUBLIC API */ this.fireTabbarPositionEvent(this.kEVENT_TYPE_TABBAR_POSITION_CHANGING, 'top', position); /* PUBLIC API */
@ -368,34 +345,6 @@ TreeStyleTabBrowser.prototype = {
this.initTabbar(null, this.kTABBAR_TOP); this.initTabbar(null, this.kTABBAR_TOP);
var tabContainer = b.mTabContainer;
tabContainer.addEventListener('TabOpen', this, true);
tabContainer.addEventListener('TabClose', this, true);
tabContainer.addEventListener('TabMove', this, true);
tabContainer.addEventListener('TabShow', this, true);
tabContainer.addEventListener('TabHide', this, true);
tabContainer.addEventListener('SSTabRestoring', this, true);
tabContainer.addEventListener('SSTabRestored', this, true);
tabContainer.addEventListener('TabPinned', this, true);
tabContainer.addEventListener('TabUnpinned', this, true);
if (!this.isFloating && 'tabutils' in window)
tabContainer.addEventListener('DOMAttrModified', this, true); // Tab Utilities
tabContainer.addEventListener('mouseover', this, true);
tabContainer.addEventListener('dblclick', this, true);
tabContainer.addEventListener('select', this, true);
tabContainer.addEventListener('scroll', this, true);
tabContainer.addEventListener('nsDOMMultipleTabHandler:TabsDragStart', this, true);
var strip = this.tabStrip;
strip.addEventListener('MozMouseHittest', this, true); // to block default behaviors of the tab bar
strip.addEventListener('mousedown', this, true);
strip.addEventListener('click', this, true);
this.scrollBox.addEventListener('overflow', this, true);
this.scrollBox.addEventListener('underflow', this, true);
this.tabTooltip.addEventListener('popupshowing', this, true);
window.addEventListener('resize', this, true); window.addEventListener('resize', this, true);
window.addEventListener('beforecustomization', this, true); window.addEventListener('beforecustomization', this, true);
window.addEventListener('aftercustomization', this, false); window.addEventListener('aftercustomization', this, false);
@ -404,76 +353,71 @@ TreeStyleTabBrowser.prototype = {
b.addEventListener('nsDOMMultipleTabHandlerTabsClosing', this, false); b.addEventListener('nsDOMMultipleTabHandlerTabsClosing', this, false);
this.tabbarDNDObserver;
this.panelDNDObserver;
window['piro.sakura.ne.jp'].tabsDragUtils.initTabBrowser(b); window['piro.sakura.ne.jp'].tabsDragUtils.initTabBrowser(b);
this._initTabbrowserMethods();
eval('b.mTabContainer.advanceSelectedTab = '+ this._initTabbrowserContextMenu();
b.mTabContainer.advanceSelectedTab.toSource().replace(
'{',
<![CDATA[$&
var treeStyleTab = TreeStyleTabService.getTabBrowserFromChild(this).treeStyleTab;
treeStyleTab._focusChangedByShortcut = TreeStyleTabService.accelKeyPressed;
if (treeStyleTab.canCollapseSubtree(this.selectedItem) &&
treeStyleTab.getTreePref('focusMode') == treeStyleTab.kFOCUS_VISIBLE) {
(function(aDir, aWrap, aSelf) {
var nextTab = (aDir < 0) ? treeStyleTab.getPreviousVisibleTab(aSelf.selectedItem) : treeStyleTab.getNextVisibleTab(aSelf.selectedItem) ;
if (!nextTab && aWrap) {
nextTab = TreeStyleTabService.evaluateXPath(
'child::xul:tab[not(@'+TreeStyleTabService.kCOLLAPSED+'="true")]['+
(aDir < 0 ? 'last()' : '1' )+
']',
aSelf,
XPathResult.FIRST_ORDERED_NODE_TYPE
).singleNodeValue;
}
if (nextTab && nextTab != aSelf.selectedItem) {
aSelf._selectNewTab(nextTab, aDir, aWrap);
}
})(arguments[0], arguments[1], this);
return;
}
]]>
)
);
eval('b.mTabContainer._notifyBackgroundTab = '+
b.mTabContainer._notifyBackgroundTab.toSource().replace(
'{',
'{ var treeStyleTab = TreeStyleTabService.getTabBrowserFromChild(this).treeStyleTab;'
).replace(
/\.screenX/g, '[treeStyleTab.positionProp]'
).replace(
/\.width/g, '[treeStyleTab.sizeProp]'
).replace(
/\.left/g, '[treeStyleTab.startProp]'
).replace(
/\.right/g, '[treeStyleTab.endProp]'
)
);
TreeStyleTabService.updateTabDNDObserver(b); TreeStyleTabService.updateTabDNDObserver(b);
if (b.tabContainer && '_getDropIndex' in b.tabContainer) { // Firefox 4.0 or later this.getAllTabsArray(b).forEach(this.initTab, this);
eval('b.tabContainer._getDropIndex = '+
b.tabContainer._getDropIndex.toSource().replace( this.onPrefChange('extensions.treestyletab.maxTreeLevel');
/\.screenX/g, '[this.treeStyleTab.positionProp]' this.onPrefChange('extensions.treestyletab.tabbar.style');
).replace( this.onPrefChange('extensions.treestyletab.twisty.style');
/\.width/g, '[this.treeStyleTab.sizeProp]' this.onPrefChange('extensions.treestyletab.showBorderForFirstTab');
) this.onPrefChange('extensions.treestyletab.tabbar.invertTabContents');
); this.onPrefChange('extensions.treestyletab.tabbar.invertClosebox');
this.onPrefChange('extensions.treestyletab.tabbar.autoShow.mousemove');
this.onPrefChange('extensions.treestyletab.animation.enabled');
this.ObserverService.addObserver(this, this.kTOPIC_INDENT_MODIFIED, false);
this.ObserverService.addObserver(this, this.kTOPIC_COLLAPSE_EXPAND_ALL, false);
this.ObserverService.addObserver(this, this.kTOPIC_CHANGE_TREEVIEW_AVAILABILITY, false);
this.ObserverService.addObserver(this, 'sessionstore-windows-restored', false);
this.ObserverService.addObserver(this, 'sessionstore-browser-state-restored', false);
this.ObserverService.addObserver(this, 'private-browsing-change-granted', false);
this.ObserverService.addObserver(this, 'lightweight-theme-styling-update', false);
this.addPrefListener(this);
this.tabbarDNDObserver;
this.panelDNDObserver;
this.autoHide;
this.updateFloatingTabbar(this.kTABBAR_UPDATE_BY_INITIALIZE);
this.fireTabbarPositionEvent(false, 'top', position); /* PUBLIC API */
this.startRendering();
},
_initTabbrowserExtraContents : function TSTBrowser_initTabbrowserExtraContents()
{
var b = this.mTabBrowser;
var toggler = document.getAnonymousElementByAttribute(b, 'class', this.kTABBAR_TOGGLER);
if (!toggler) {
toggler = document.createElement('spacer');
toggler.setAttribute('class', this.kTABBAR_TOGGLER);
toggler.setAttribute('layer', true); // https://bugzilla.mozilla.org/show_bug.cgi?id=590468
b.mTabBox.insertBefore(toggler, b.mTabBox.firstChild);
if (b.mTabDropIndicatorBar == toggler)
b.mTabDropIndicatorBar = document.getAnonymousElementByAttribute(b, 'class', 'tab-drop-indicator-bar');
} }
else if ('getNewIndex' in b) { // Firefox 3.6 or older
eval('b.getNewIndex = '+ var placeHolder = document.getAnonymousElementByAttribute(b, 'anonid', 'strip');
b.getNewIndex.toSource().replace( if (!placeHolder) {
/\.screenX/g, '[this.treeStyleTab.positionProp]' placeHolder = document.createElement('hbox');
).replace( placeHolder.setAttribute('anonid', 'strip');
/\.width/g, '[this.treeStyleTab.sizeProp]' placeHolder.setAttribute('class', 'tabbrowser-strip '+this.kTABBAR_PLACEHOLDER);
) placeHolder.setAttribute('layer', true); // https://bugzilla.mozilla.org/show_bug.cgi?id=590468
); b.mTabBox.insertBefore(placeHolder, toggler.nextSibling);
} }
this.tabStripPlaceHolder = (placeHolder != this.tabStrip) ? placeHolder : null ;
},
_initTabbrowserMethods : function TSTBrowser_initTabbrowserMethods()
{
var b = this.mTabBrowser;
eval('b.moveTabForward = '+ eval('b.moveTabForward = '+
b.moveTabForward.toSource().replace( b.moveTabForward.toSource().replace(
@ -575,17 +519,11 @@ TreeStyleTabBrowser.prototype = {
'{', '{',
'{ if (!this.treeStyleTab.warnAboutClosingTabSubtreeOf(this.selectedTab)) return;' '{ if (!this.treeStyleTab.warnAboutClosingTabSubtreeOf(this.selectedTab)) return;'
)); ));
},
this.getAllTabsArray(b).forEach(this.initTab, this);
_initTabbrowserContextMenu : function TSTBrowser_initTabbrowserContextMenu()
this.onPrefChange('extensions.treestyletab.maxTreeLevel'); {
this.onPrefChange('extensions.treestyletab.tabbar.style'); var b = this.mTabBrowser;
this.onPrefChange('extensions.treestyletab.twisty.style');
this.onPrefChange('extensions.treestyletab.showBorderForFirstTab');
this.onPrefChange('extensions.treestyletab.tabbar.invertTabContents');
this.onPrefChange('extensions.treestyletab.tabbar.invertClosebox');
this.onPrefChange('extensions.treestyletab.tabbar.autoShow.mousemove');
this.onPrefChange('extensions.treestyletab.animation.enabled');
var tabContextMenu = b.tabContextMenu || var tabContextMenu = b.tabContextMenu ||
document.getAnonymousElementByAttribute(b, 'anonid', 'tabContextMenu'); document.getAnonymousElementByAttribute(b, 'anonid', 'tabContextMenu');
@ -633,38 +571,18 @@ TreeStyleTabBrowser.prototype = {
}, 0, this, b, tabContextMenu); }, 0, this, b, tabContextMenu);
} }
let (removeTabItem = document.getAnonymousElementByAttribute(b, 'id', 'context_closeTab')) { var removeTabItem = document.getAnonymousElementByAttribute(b, 'id', 'context_closeTab');
if (removeTabItem) { if (removeTabItem) {
removeTabItem.setAttribute( removeTabItem.setAttribute(
'oncommand', 'oncommand',
removeTabItem.getAttribute('oncommand').replace( removeTabItem.getAttribute('oncommand').replace(
/(tabbrowser\.removeTab\(([^\)]+)\))/, /(tabbrowser\.removeTab\(([^\)]+)\))/,
'if (tabbrowser.treeStyleTab.warnAboutClosingTabSubtreeOf($2)) $1' 'if (tabbrowser.treeStyleTab.warnAboutClosingTabSubtreeOf($2)) $1'
) )
); );
}
} }
this.ObserverService.addObserver(this, this.kTOPIC_INDENT_MODIFIED, false);
this.ObserverService.addObserver(this, this.kTOPIC_COLLAPSE_EXPAND_ALL, false);
this.ObserverService.addObserver(this, this.kTOPIC_CHANGE_TREEVIEW_AVAILABILITY, false);
this.ObserverService.addObserver(this, 'sessionstore-windows-restored', false);
this.ObserverService.addObserver(this, 'sessionstore-browser-state-restored', false);
this.ObserverService.addObserver(this, 'private-browsing-change-granted', false);
this.ObserverService.addObserver(this, 'lightweight-theme-styling-update', false);
this.addPrefListener(this);
this.autoHide;
this.updateFloatingTabbar(this.kTABBAR_UPDATE_BY_INITIALIZE);
this.fireTabbarPositionEvent(false, 'top', position); /* PUBLIC API */
b = null;
this.startRendering();
}, },
initTab : function TSTBrowser_initTab(aTab) initTab : function TSTBrowser_initTab(aTab)
{ {
if (!aTab.hasAttribute(this.kID)) { if (!aTab.hasAttribute(this.kID)) {
@ -864,6 +782,9 @@ TreeStyleTabBrowser.prototype = {
if (aOldPosition && typeof aOldPosition == 'string') if (aOldPosition && typeof aOldPosition == 'string')
aOldPosition = this.getPositionFlag(aOldPosition); aOldPosition = this.getPositionFlag(aOldPosition);
this._startListenTabbarEvents();
this._initTabbarMethods();
this.stopRendering(); this.stopRendering();
var b = this.mTabBrowser; var b = this.mTabBrowser;
@ -1068,7 +989,7 @@ TreeStyleTabBrowser.prototype = {
this.updateTabCollapsed(aTab, aTab.getAttribute(this.kCOLLAPSED) == 'true', true); this.updateTabCollapsed(aTab, aTab.getAttribute(this.kCOLLAPSED) == 'true', true);
}, this); }, this);
this.updateTabbarState(); this.updateTabbarState(false);
window.setTimeout(function(aSelf, aTabBrowser, aSplitter, aToggler) { window.setTimeout(function(aSelf, aTabBrowser, aSplitter, aToggler) {
delayedPostProcess(aSelf, aTabBrowser, aSplitter, aToggler); delayedPostProcess(aSelf, aTabBrowser, aSplitter, aToggler);
aSelf.updateTabbarOverflow(); aSelf.updateTabbarOverflow();
@ -1095,6 +1016,107 @@ TreeStyleTabBrowser.prototype = {
scrollInnerBox = null; scrollInnerBox = null;
}, },
_startListenTabbarEvents : function TSTBrowser_startListenTabbarEvents()
{
var b = this.mTabBrowser;
var tabContainer = b.mTabContainer;
tabContainer.addEventListener('TabOpen', this, true);
tabContainer.addEventListener('TabClose', this, true);
tabContainer.addEventListener('TabMove', this, true);
tabContainer.addEventListener('TabShow', this, true);
tabContainer.addEventListener('TabHide', this, true);
tabContainer.addEventListener('SSTabRestoring', this, true);
tabContainer.addEventListener('SSTabRestored', this, true);
tabContainer.addEventListener('TabPinned', this, true);
tabContainer.addEventListener('TabUnpinned', this, true);
if (!this.isFloating && 'tabutils' in window)
tabContainer.addEventListener('DOMAttrModified', this, true); // Tab Utilities
tabContainer.addEventListener('mouseover', this, true);
tabContainer.addEventListener('dblclick', this, true);
tabContainer.addEventListener('select', this, true);
tabContainer.addEventListener('scroll', this, true);
tabContainer.addEventListener('nsDOMMultipleTabHandler:TabsDragStart', this, true);
var strip = this.tabStrip;
strip.addEventListener('MozMouseHittest', this, true); // to block default behaviors of the tab bar
strip.addEventListener('mousedown', this, true);
strip.addEventListener('click', this, true);
this.scrollBox.addEventListener('overflow', this, true);
this.scrollBox.addEventListener('underflow', this, true);
this.tabTooltip.addEventListener('popupshowing', this, true);
},
_initTabbarMethods : function TSTBrowser_initTabbarMethods()
{
var b = this.mTabBrowser;
eval('b.mTabContainer.advanceSelectedTab = '+
b.mTabContainer.advanceSelectedTab.toSource().replace(
'{',
<![CDATA[$&
var treeStyleTab = TreeStyleTabService.getTabBrowserFromChild(this).treeStyleTab;
treeStyleTab._focusChangedByShortcut = TreeStyleTabService.accelKeyPressed;
if (treeStyleTab.canCollapseSubtree(this.selectedItem) &&
treeStyleTab.getTreePref('focusMode') == treeStyleTab.kFOCUS_VISIBLE) {
(function(aDir, aWrap, aSelf) {
var nextTab = (aDir < 0) ? treeStyleTab.getPreviousVisibleTab(aSelf.selectedItem) : treeStyleTab.getNextVisibleTab(aSelf.selectedItem) ;
if (!nextTab && aWrap) {
nextTab = TreeStyleTabService.evaluateXPath(
'child::xul:tab[not(@'+TreeStyleTabService.kCOLLAPSED+'="true")]['+
(aDir < 0 ? 'last()' : '1' )+
']',
aSelf,
XPathResult.FIRST_ORDERED_NODE_TYPE
).singleNodeValue;
}
if (nextTab && nextTab != aSelf.selectedItem) {
aSelf._selectNewTab(nextTab, aDir, aWrap);
}
})(arguments[0], arguments[1], this);
return;
}
]]>
)
);
eval('b.mTabContainer._notifyBackgroundTab = '+
b.mTabContainer._notifyBackgroundTab.toSource().replace(
'{',
'{ var treeStyleTab = TreeStyleTabService.getTabBrowserFromChild(this).treeStyleTab;'
).replace(
/\.screenX/g, '[treeStyleTab.positionProp]'
).replace(
/\.width/g, '[treeStyleTab.sizeProp]'
).replace(
/\.left/g, '[treeStyleTab.startProp]'
).replace(
/\.right/g, '[treeStyleTab.endProp]'
)
);
if (b.tabContainer && '_getDropIndex' in b.tabContainer) { // Firefox 4.0 or later
eval('b.tabContainer._getDropIndex = '+
b.tabContainer._getDropIndex.toSource().replace(
/\.screenX/g, '[this.treeStyleTab.positionProp]'
).replace(
/\.width/g, '[this.treeStyleTab.sizeProp]'
)
);
}
else if ('getNewIndex' in b) { // Firefox 3.6 or older
eval('b.getNewIndex = '+
b.getNewIndex.toSource().replace(
/\.screenX/g, '[this.treeStyleTab.positionProp]'
).replace(
/\.width/g, '[this.treeStyleTab.sizeProp]'
)
);
}
},
_ensureNewSplitter : function TSTBrowser__ensureNewSplitter() _ensureNewSplitter : function TSTBrowser__ensureNewSplitter()
{ {
var splitter = this.splitter; var splitter = this.splitter;
@ -1135,8 +1157,29 @@ TreeStyleTabBrowser.prototype = {
return splitter; return splitter;
}, },
updateTabbarState : function TSTBrowser_updateTabbarState() fireTabbarPositionEvent : function TSTBrowser_fireTabbarPositionEvent(aChanging, aOldPosition, aNewPosition)
{ {
if (aOldPosition == aNewPosition) return false;
var type = aChanging ? this.kEVENT_TYPE_TABBAR_POSITION_CHANGING : this.kEVENT_TYPE_TABBAR_POSITION_CHANGED;
var data = {
oldPosition : aOldPosition,
newPosition : aNewPosition
};
/* PUBLIC API */
this.fireDataContainerEvent(type, this.mTabBrowser, true, false, data);
// for backward compatibility
this.fireDataContainerEvent(type.replace(/^nsDOM/, ''), this.mTabBrowser, true, false, data);
return true;
},
updateTabbarState : function TSTBrowser_updateTabbarState(aCancelable)
{
if (!this._fireTabbarStateChangingEvent() && aCancelable)
return;
this.stopRendering(); this.stopRendering();
var b = this.mTabBrowser; var b = this.mTabBrowser;
@ -1185,7 +1228,7 @@ TreeStyleTabBrowser.prototype = {
window.setTimeout(function(aSelf) { window.setTimeout(function(aSelf) {
aSelf.updateFloatingTabbar(aSelf.kTABBAR_UPDATE_BY_APPEARANCE_CHANGE); aSelf.updateFloatingTabbar(aSelf.kTABBAR_UPDATE_BY_APPEARANCE_CHANGE);
aSelf.fireTabbarStateChangedEvent(); aSelf._fireTabbarStateChangedEvent();
aSelf.startRendering(); aSelf.startRendering();
}, 0, this); }, 0, this);
@ -1211,49 +1254,104 @@ TreeStyleTabBrowser.prototype = {
this.updateAllTabsIndent(); this.updateAllTabsIndent();
}, },
onTabsOnTopSyncCommand : function TSTBrowser_onTabsOnTopSyncCommand(aEnabled) _fireTabbarStateChangingEvent : function TSTBrowser_fireTabbarStateChangingEvent()
{ {
if ( var b = this.mTabBrowser;
!aEnabled || var orient = this.isVertical ? 'vertical' : 'horizontal' ;
this.currentTabbarPosition != 'top' || var oldState = {
this.isFixed fixed : this.isFixed,
) maxTreeLevel : this.maxTreeLevel,
return; indented : this.maxTreeLevel != 0,
window.setTimeout(function(aTabBrowser) { canCollapse : b.getAttribute(this.kALLOW_COLLAPSE) == 'true'
TreeStyleTabService.toggleFixed(aTabBrowser); };
window.setTimeout(function() { if (!this.isFloating) {
if (TabsOnTop.enabled != aEnabled) oldState.alltabsButton = b.getAttribute(this.kHIDE_ALLTABS) != 'true';
TabsOnTop.enabled = aEnabled; oldState.allTabsButton = oldState.alltabsButton;
}, 0); }
}, 0, this.mTabBrowser); var newState = {
fixed : this.getTreePref('tabbar.fixed.'+orient),
maxTreeLevel : this.getTreePref('maxTreeLevel.'+orient),
indented : this.getTreePref('maxTreeLevel.'+orient) != 0,
canCollapse : this.getTreePref('allowSubtreeCollapseExpand.'+orient)
};
if (!this.isFloating) {
newState.alltabsButton = !this.getTreePref('tabbar.hideAlltabsButton.'+orient);
newState.allTabsButton = newState.alltabsButton;
}
if (oldState.fixed == newState.fixed &&
oldState.maxTreeLevel == newState.maxTreeLevel &&
oldState.indented == newState.indented &&
oldState.canCollapse == newState.canCollapse &&
oldState.alltabsButton == newState.alltabsButton)
return false;
var data = {
oldState : oldState,
newState : newState
};
/* PUBLIC API */
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGING, this.mTabBrowser, true, false, data);
// for backward compatibility
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGING.replace(/^nsDOM/, ''), this.mTabBrowser, true, false, data);
return true;
}, },
_fireTabbarStateChangedEvent : function TSTBrowser_fireTabbarStateChangedEvent()
{
var b = this.mTabBrowser;
var state = {
fixed : this.isFixed,
maxTreeLevel : this.maxTreeLevel,
indented : this.maxTreeLevel != 0,
canCollapse : b.getAttribute(this.kALLOW_COLLAPSE) == 'true'
};
if (!this.isFloating) {
state.alltabsButton = b.getAttribute(this.kHIDE_ALLTABS) != 'true';
state.allTabsButton = state.alltabsButton;
}
var data = {
state : state
};
/* PUBLIC API */
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGED, this.mTabBrowser, true, false, data);
// for backward compatibility
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGED.replace(/^nsDOM/, ''), this.mTabBrowser, true, false, data);
return true;
},
updateFloatingTabbar : function TSTBrowser_updateFloatingTabbar(aReason) updateFloatingTabbar : function TSTBrowser_updateFloatingTabbar(aReason)
{ {
// this method is just for Firefox 4.0 or later // this method is just for Firefox 4.0 or later
if (!this.isFloating) return; if (!this.isFloating) return;
if (this.updateFloatingTabbarTimer) { if (this._updateFloatingTabbarTimer) {
window.clearTimeout(this.updateFloatingTabbarTimer); window.clearTimeout(this._updateFloatingTabbarTimer);
this.updateFloatingTabbarTimer = null; this._updateFloatingTabbarTimer = null;
} }
this.updateFloatingTabbarReason |= aReason; this._updateFloatingTabbarReason |= aReason;
if (this.updateFloatingTabbarReason & this.kTABBAR_UPDATE_NOW) { if (this._updateFloatingTabbarReason & this.kTABBAR_UPDATE_NOW) {
this.updateFloatingTabbarInternal(this.updateFloatingTabbarReason); this._updateFloatingTabbarInternal(this.updateFloatingTabbarReason);
this.updateFloatingTabbarReason = 0; this._updateFloatingTabbarReason = 0;
} }
else { else {
this.updateFloatingTabbarTimer = window.setTimeout(function(aSelf) { this._updateFloatingTabbarTimer = window.setTimeout(function(aSelf) {
aSelf.updateFloatingTabbarTimer = null; aSelf._updateFloatingTabbarTimer = null;
aSelf.updateFloatingTabbarInternal(aSelf.updateFloatingTabbarReason) aSelf._updateFloatingTabbarInternal(aSelf._updateFloatingTabbarReason)
aSelf.updateFloatingTabbarReason = 0; aSelf._updateFloatingTabbarReason = 0;
}, 0, this); }, 0, this);
} }
}, },
updateFloatingTabbarInternal : function TSTBrowser_updateFloatingTabbarInternal(aReason)
_updateFloatingTabbarInternal : function TSTBrowser_updateFloatingTabbarInternal(aReason)
{ {
aReason = aReason || this.kTABBAR_UPDATE_BY_UNKNOWN_REASON; aReason = aReason || this.kTABBAR_UPDATE_BY_UNKNOWN_REASON;
@ -1300,7 +1398,7 @@ TreeStyleTabBrowser.prototype = {
strip.style.width = (tabContainerBox.width = width)+'px'; strip.style.width = (tabContainerBox.width = width)+'px';
strip.style.height = (tabContainerBox.height = height)+'px'; strip.style.height = (tabContainerBox.height = height)+'px';
this.updateFloatingTabbarResizer({ this._updateFloatingTabbarResizer({
width : width, width : width,
realWidth : realWidth, realWidth : realWidth,
height : height, height : height,
@ -1325,7 +1423,8 @@ TreeStyleTabBrowser.prototype = {
this.positionPinnedTabs(); this.positionPinnedTabs();
}, },
updateFloatingTabbarResizer : function TSTBrowser_updateFloatingTabbarResizer(aSize)
_updateFloatingTabbarResizer : function TSTBrowser_updateFloatingTabbarResizer(aSize)
{ {
var width = aSize.width; var width = aSize.width;
var realWidth = this.autoHide.mode == this.autoHide.kMODE_HIDE ? 0 : aSize.realWidth ; var realWidth = this.autoHide.mode == this.autoHide.kMODE_HIDE ? 0 : aSize.realWidth ;
@ -1385,24 +1484,7 @@ TreeStyleTabBrowser.prototype = {
vertical ? '0' : vertical ? '0' :
box.height+'px' ; box.height+'px' ;
}, },
resetTabbarSize : function TSTBrowser_resetTabbarSize()
{
if (this.isVertical) {
this.clearTreePref('tabbar.shrunkenWidth');
this.clearTreePref('tabbar.width');
}
else {
this.clearTreePref('tabbar.height');
if (this.isFloating) {
let tabContainerBox = this.getTabContainerBox(this.mTabBrowser);
tabContainerBox.removeAttribute('height');
this._tabStripPlaceHolder.height = tabContainerBox.boxObject.height;
}
}
this.updateFloatingTabbar(this.kTABBAR_UPDATE_BY_RESET);
},
updateTabbarOverflow : function TSTBrowser_updateTabbarOverflow() updateTabbarOverflow : function TSTBrowser_updateTabbarOverflow()
{ {
var b = this.mTabBrowser; var b = this.mTabBrowser;
@ -1439,127 +1521,6 @@ TreeStyleTabBrowser.prototype = {
}, 100); }, 100);
}, },
fireTabbarPositionEvent : function TSTBrowser_fireTabbarPositionEvent(aChanging, aOldPosition, aNewPosition)
{
if (aOldPosition == aNewPosition) return false;
var type = aChanging ? this.kEVENT_TYPE_TABBAR_POSITION_CHANGING : this.kEVENT_TYPE_TABBAR_POSITION_CHANGED;
var data = {
oldPosition : aOldPosition,
newPosition : aNewPosition
};
/* PUBLIC API */
this.fireDataContainerEvent(type, this.mTabBrowser, true, false, data);
// for backward compatibility
this.fireDataContainerEvent(type.replace(/^nsDOM/, ''), this.mTabBrowser, true, false, data);
return true;
},
fireTabbarStateChangingEvent : function TSTBrowser_fireTabbarStateChangingEvent()
{
var b = this.mTabBrowser;
var orient = this.isVertical ? 'vertical' : 'horizontal' ;
var oldState = {
fixed : this.isFixed,
maxTreeLevel : this.maxTreeLevel,
indented : this.maxTreeLevel != 0,
canCollapse : b.getAttribute(this.kALLOW_COLLAPSE) == 'true'
};
if (!this.isFloating) {
oldState.alltabsButton = b.getAttribute(this.kHIDE_ALLTABS) != 'true';
oldState.allTabsButton = oldState.alltabsButton;
}
var newState = {
fixed : this.getTreePref('tabbar.fixed.'+orient),
maxTreeLevel : this.getTreePref('maxTreeLevel.'+orient),
indented : this.getTreePref('maxTreeLevel.'+orient) != 0,
canCollapse : this.getTreePref('allowSubtreeCollapseExpand.'+orient)
};
if (!this.isFloating) {
newState.alltabsButton = !this.getTreePref('tabbar.hideAlltabsButton.'+orient);
newState.allTabsButton = newState.alltabsButton;
}
if (oldState.fixed == newState.fixed &&
oldState.maxTreeLevel == newState.maxTreeLevel &&
oldState.indented == newState.indented &&
oldState.canCollapse == newState.canCollapse &&
oldState.alltabsButton == newState.alltabsButton)
return false;
var data = {
oldState : oldState,
newState : newState
};
/* PUBLIC API */
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGING, this.mTabBrowser, true, false, data);
// for backward compatibility
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGING.replace(/^nsDOM/, ''), this.mTabBrowser, true, false, data);
return true;
},
fireTabbarStateChangedEvent : function TSTBrowser_fireTabbarStateChangedEvent()
{
var b = this.mTabBrowser;
var state = {
fixed : this.isFixed,
maxTreeLevel : this.maxTreeLevel,
indented : this.maxTreeLevel != 0,
canCollapse : b.getAttribute(this.kALLOW_COLLAPSE) == 'true'
};
if (!this.isFloating) {
state.alltabsButton = b.getAttribute(this.kHIDE_ALLTABS) != 'true';
state.allTabsButton = state.alltabsButton;
}
var data = {
state : state
};
/* PUBLIC API */
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGED, this.mTabBrowser, true, false, data);
// for backward compatibility
this.fireDataContainerEvent(this.kEVENT_TYPE_TABBAR_STATE_CHANGED.replace(/^nsDOM/, ''), this.mTabBrowser, true, false, data);
return true;
},
syncDestroyTabbar : function TSTBrowser_syncDestroyTabbar()
{
if (this.currentTabbarPosition != 'top') {
this._lastTabbarPositionBeforeDestroyed = this.currentTabbarPosition;
let self = this;
this.doAndWaitDOMEvent(
this.kEVENT_TYPE_TABBAR_POSITION_CHANGED,
window,
100,
function() { self.currentTabbarPosition = 'top'; }
);
}
if (!this.isFixed) {
this._lastTabbarFixedBeforeDestroyed = this.isFixed;
let self = this;
this.doAndWaitDOMEvent(
this.kEVENT_TYPE_TABBAR_STATE_CHANGED,
window,
100,
function() { self.toggleFixed(); }
);
}
this.updateFloatingTabbar(this.kTABBAR_UPDATE_NOW);
this.removeTabStripAttribute('width');
this.removeTabStripAttribute('height');
this.removeTabStripAttribute('ordinal');
this.mTabBrowser.mTabContainer.parentNode.classList.remove(this.kTABBAR_TOOLBAR);
},
syncReinitTabbar : function TSTBrowser_syncReinitTabbar() syncReinitTabbar : function TSTBrowser_syncReinitTabbar()
{ {
this.mTabBrowser.mTabContainer.parentNode.classList.add(this.kTABBAR_TOOLBAR); this.mTabBrowser.mTabContainer.parentNode.classList.add(this.kTABBAR_TOOLBAR);
@ -1615,28 +1576,7 @@ TreeStyleTabBrowser.prototype = {
this.destroyTab(aTab); this.destroyTab(aTab);
}, this); }, this);
var tabContainer = b.mTabContainer; this._endListenTabbarEvents();
tabContainer.removeEventListener('TabOpen', this, true);
tabContainer.removeEventListener('TabClose', this, true);
tabContainer.removeEventListener('TabMove', this, true);
tabContainer.removeEventListener('TabShow', this, true);
tabContainer.removeEventListener('TabHide', this, true);
tabContainer.removeEventListener('SSTabRestoring', this, true);
tabContainer.removeEventListener('SSTabRestored', this, true);
tabContainer.removeEventListener('TabPinned', this, true);
tabContainer.removeEventListener('TabUnpinned', this, true);
if (!this.isFloating && 'tabutils' in window)
b.mTabContainer.removeEventListener('DOMAttrModified', this, true); // Tab Utilites
tabContainer.removeEventListener('mouseover', this, true);
tabContainer.removeEventListener('dblclick', this, true);
tabContainer.removeEventListener('select', this, true);
tabContainer.removeEventListener('scroll', this, true);
tabContainer.removeEventListener('nsDOMMultipleTabHandler:TabsDragStart', this, true);
var strip = this.tabStrip;
strip.removeEventListener('MozMouseHittest', this, true);
strip.removeEventListener('mousedown', this, true);
strip.removeEventListener('click', this, true);
window.removeEventListener('resize', this, true); window.removeEventListener('resize', this, true);
window.removeEventListener('beforecustomization', this, true); window.removeEventListener('beforecustomization', this, true);
@ -1648,11 +1588,6 @@ TreeStyleTabBrowser.prototype = {
window['piro.sakura.ne.jp'].tabsDragUtils.destroyTabBrowser(b); window['piro.sakura.ne.jp'].tabsDragUtils.destroyTabBrowser(b);
this.scrollBox.removeEventListener('overflow', this, true);
this.scrollBox.removeEventListener('underflow', this, true);
this.tabTooltip.removeEventListener('popupshowing', this, true);
var tabContextMenu = b.tabContextMenu || var tabContextMenu = b.tabContextMenu ||
document.getAnonymousElementByAttribute(b, 'anonid', 'tabContextMenu'); document.getAnonymousElementByAttribute(b, 'anonid', 'tabContextMenu');
tabContextMenu.removeEventListener('popupshowing', this, false); tabContextMenu.removeEventListener('popupshowing', this, false);
@ -1684,6 +1619,71 @@ TreeStyleTabBrowser.prototype = {
delete aTab.__treestyletab__linkedTabBrowser; delete aTab.__treestyletab__linkedTabBrowser;
}, },
_endListenTabbarEvents : function TSTBrowser_endListenTabbarEvents()
{
var b = this.mTabBrowser;
var tabContainer = b.mTabContainer;
tabContainer.removeEventListener('TabOpen', this, true);
tabContainer.removeEventListener('TabClose', this, true);
tabContainer.removeEventListener('TabMove', this, true);
tabContainer.removeEventListener('TabShow', this, true);
tabContainer.removeEventListener('TabHide', this, true);
tabContainer.removeEventListener('SSTabRestoring', this, true);
tabContainer.removeEventListener('SSTabRestored', this, true);
tabContainer.removeEventListener('TabPinned', this, true);
tabContainer.removeEventListener('TabUnpinned', this, true);
if (!this.isFloating && 'tabutils' in window)
b.mTabContainer.removeEventListener('DOMAttrModified', this, true); // Tab Utilites
tabContainer.removeEventListener('mouseover', this, true);
tabContainer.removeEventListener('dblclick', this, true);
tabContainer.removeEventListener('select', this, true);
tabContainer.removeEventListener('scroll', this, true);
tabContainer.removeEventListener('nsDOMMultipleTabHandler:TabsDragStart', this, true);
var strip = this.tabStrip;
strip.removeEventListener('MozMouseHittest', this, true);
strip.removeEventListener('mousedown', this, true);
strip.removeEventListener('click', this, true);
this.scrollBox.removeEventListener('overflow', this, true);
this.scrollBox.removeEventListener('underflow', this, true);
this.tabTooltip.removeEventListener('popupshowing', this, true);
},
syncDestroyTabbar : function TSTBrowser_syncDestroyTabbar()
{
if (this.currentTabbarPosition != 'top') {
this._lastTabbarPositionBeforeDestroyed = this.currentTabbarPosition;
let self = this;
this.doAndWaitDOMEvent(
this.kEVENT_TYPE_TABBAR_POSITION_CHANGED,
window,
100,
function() { self.currentTabbarPosition = 'top'; }
);
}
if (!this.isFixed) {
this._lastTabbarFixedBeforeDestroyed = this.isFixed;
let self = this;
this.doAndWaitDOMEvent(
this.kEVENT_TYPE_TABBAR_STATE_CHANGED,
window,
100,
function() { self.toggleFixed(); }
);
}
this.updateFloatingTabbar(this.kTABBAR_UPDATE_NOW);
this.removeTabStripAttribute('width');
this.removeTabStripAttribute('height');
this.removeTabStripAttribute('ordinal');
this.mTabBrowser.mTabContainer.parentNode.classList.remove(this.kTABBAR_TOOLBAR);
},
saveCurrentState : function TSTBrowser_saveCurrentState() saveCurrentState : function TSTBrowser_saveCurrentState()
{ {
this.autoHide.saveCurrentState(); this.autoHide.saveCurrentState();
@ -1825,8 +1825,8 @@ TreeStyleTabBrowser.prototype = {
case 'extensions.treestyletab.maxTreeLevel.horizontal': case 'extensions.treestyletab.maxTreeLevel.horizontal':
case 'extensions.treestyletab.allowSubtreeCollapseExpand.horizontal': case 'extensions.treestyletab.allowSubtreeCollapseExpand.horizontal':
case 'extensions.treestyletab.tabbar.hideAlltabsButton.horizontal': case 'extensions.treestyletab.tabbar.hideAlltabsButton.horizontal':
if (!this.isVertical && this.fireTabbarStateChangingEvent()) if (!this.isVertical)
this.updateTabbarState(); this.updateTabbarState(true);
return; return;
case 'extensions.treestyletab.tabbar.fixed.vertical': case 'extensions.treestyletab.tabbar.fixed.vertical':
@ -1835,8 +1835,8 @@ TreeStyleTabBrowser.prototype = {
case 'extensions.treestyletab.maxTreeLevel.vertical': case 'extensions.treestyletab.maxTreeLevel.vertical':
case 'extensions.treestyletab.allowSubtreeCollapseExpand.vertical': case 'extensions.treestyletab.allowSubtreeCollapseExpand.vertical':
case 'extensions.treestyletab.tabbar.hideAlltabsButton.vertical': case 'extensions.treestyletab.tabbar.hideAlltabsButton.vertical':
if (this.isVertical && this.fireTabbarStateChangingEvent()) if (this.isVertical)
this.updateTabbarState(); this.updateTabbarState(true);
return; return;
case 'extensions.treestyletab.tabbar.width': case 'extensions.treestyletab.tabbar.width':
@ -2120,7 +2120,7 @@ TreeStyleTabBrowser.prototype = {
return this.onResize(aEvent); return this.onResize(aEvent);
// toolbar customizing on Firefox 4 or later // toolbar customizing on Firefox 4 or later
case 'beforecustomization': case 'beforecustomization':
return this.syncDestroyTabbar(); return this.syncDestroyTabbar();
case 'aftercustomization': case 'aftercustomization':
@ -3524,6 +3524,23 @@ TreeStyleTabBrowser.prototype = {
}, },
onTabsOnTopSyncCommand : function TSTBrowser_onTabsOnTopSyncCommand(aEnabled)
{
if (
!aEnabled ||
this.currentTabbarPosition != 'top' ||
this.isFixed
)
return;
window.setTimeout(function(aTabBrowser) {
TreeStyleTabService.toggleFixed(aTabBrowser);
window.setTimeout(function() {
if (TabsOnTop.enabled != aEnabled)
TabsOnTop.enabled = aEnabled;
}, 0);
}, 0, this.mTabBrowser);
},
onTreeStyleTabPrintPreviewEntered : function TSTBrowser_onTreeStyleTabPrintPreviewEntered(aEvent) onTreeStyleTabPrintPreviewEntered : function TSTBrowser_onTreeStyleTabPrintPreviewEntered(aEvent)
{ {
this.setTabbrowserAttribute(this.kPRINT_PREVIEW, true); this.setTabbrowserAttribute(this.kPRINT_PREVIEW, true);
@ -3569,6 +3586,23 @@ TreeStyleTabBrowser.prototype = {
}, this); }, this);
}, },
resetTabbarSize : function TSTBrowser_resetTabbarSize()
{
if (this.isVertical) {
this.clearTreePref('tabbar.shrunkenWidth');
this.clearTreePref('tabbar.width');
}
else {
this.clearTreePref('tabbar.height');
if (this.isFloating) {
let tabContainerBox = this.getTabContainerBox(this.mTabBrowser);
tabContainerBox.removeAttribute('height');
this._tabStripPlaceHolder.height = tabContainerBox.boxObject.height;
}
}
this.updateFloatingTabbar(this.kTABBAR_UPDATE_BY_RESET);
},
get treeViewEnabled() /* PUBLIC API */ get treeViewEnabled() /* PUBLIC API */
{ {
return this._treeViewEnabled; return this._treeViewEnabled;