2014-09-30 20:09:27 +09:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is the Tree Style Tab.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is YUKI "Piro" Hiroshi.
|
2016-02-12 22:39:49 +09:00
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2010-2016
|
2014-09-30 20:09:27 +09:00
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): YUKI "Piro" Hiroshi <piro.outsider.reflex@gmail.com>
|
|
|
|
* Tetsuharu OHZEKI <https://github.com/saneyuki>
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ******/
|
|
|
|
|
2015-10-11 12:40:17 +09:00
|
|
|
var EXPORTED_SYMBOLS = ['AutoHideBrowser', 'AutoHideWindow'];
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
const Cc = Components.classes;
|
|
|
|
const Ci = Components.interfaces;
|
|
|
|
const Cu = Components.utils;
|
|
|
|
|
|
|
|
Cu.import('resource://gre/modules/XPCOMUtils.jsm');
|
|
|
|
Cu.import('resource://gre/modules/Services.jsm');
|
2016-05-30 02:55:17 +09:00
|
|
|
Cu.import('resource://gre/modules/Timer.jsm');
|
2014-11-11 17:45:12 +09:00
|
|
|
Cu.import('resource://treestyletab-modules/lib/inherit.jsm');
|
|
|
|
Cu.import('resource://treestyletab-modules/constants.js');
|
2015-11-10 03:00:43 +09:00
|
|
|
Cu.import('resource://treestyletab-modules/ReferenceCounter.js');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
XPCOMUtils.defineLazyModuleGetter(this, 'utils', 'resource://treestyletab-modules/utils.js', 'TreeStyleTabUtils');
|
2016-02-12 19:57:35 +09:00
|
|
|
XPCOMUtils.defineLazyModuleGetter(this, 'TabAttributesObserver', 'resource://treestyletab-modules/tabAttributesObserver.js');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
XPCOMUtils.defineLazyGetter(this, 'window', function() {
|
|
|
|
Cu.import('resource://treestyletab-modules/lib/namespace.jsm');
|
|
|
|
return getNamespaceFor('piro.sakura.ne.jp');
|
|
|
|
});
|
|
|
|
XPCOMUtils.defineLazyGetter(this, 'prefs', function() {
|
|
|
|
Cu.import('resource://treestyletab-modules/lib/prefs.js');
|
|
|
|
return window['piro.sakura.ne.jp'].prefs;
|
|
|
|
});
|
|
|
|
|
2016-02-10 19:10:46 +09:00
|
|
|
function log(...aArgs) {
|
|
|
|
utils.log.apply(utils, ['autoHide'].concat(aArgs));
|
|
|
|
}
|
|
|
|
function logWithStackTrace(...aArgs) {
|
|
|
|
utils.logWithStackTrace.apply(utils, ['autoHide'].concat(aArgs));
|
|
|
|
}
|
2014-09-30 20:09:27 +09:00
|
|
|
|
2015-10-10 19:25:00 +09:00
|
|
|
var AutoHideConstants = Object.freeze(inherit(TreeStyleTabConstants, {
|
2014-09-30 20:09:27 +09:00
|
|
|
kMODE : 'treestyletab-tabbar-autohide-mode',
|
|
|
|
kMODE_DISABLED : 0,
|
|
|
|
kMODE_HIDE : 1,
|
|
|
|
kMODE_SHRINK : 2,
|
|
|
|
|
|
|
|
kAUTOHIDE : 'treestyletab-tabbar-autohide',
|
|
|
|
|
|
|
|
kSTATE : 'treestyletab-tabbar-autohide-state',
|
|
|
|
kSTATE_HIDDEN : 'hidden',
|
|
|
|
kSTATE_EXPANDED : 'expanded',
|
|
|
|
kSTATE_SHRUNKEN : 'shrunken',
|
|
|
|
|
|
|
|
kSHOWN_BY_UNKNOWN : 0,
|
|
|
|
kSHOWN_BY_SHORTCUT : 1 << 0,
|
|
|
|
kSHOWN_BY_MOUSEMOVE : 1 << 1,
|
|
|
|
kSHOWN_BY_FEEDBACK : 1 << 2,
|
2016-02-14 22:09:15 +09:00
|
|
|
kSHOWN_AUTOMATICALLY : (1 << 0) | (1 << 1),
|
2014-09-30 20:09:27 +09:00
|
|
|
kSHOWN_BY_ANY_REASON : (1 << 0) | (1 << 1) | (1 << 2),
|
|
|
|
kSHOWHIDE_BY_START : 1 << 3,
|
|
|
|
kSHOWHIDE_BY_END : 1 << 4,
|
|
|
|
kSHOWHIDE_BY_POSITION_CHANGE : 1 << 5,
|
|
|
|
kSHOWHIDE_BY_RESIZE : 1 << 6,
|
|
|
|
kSHOWHIDE_BY_API : 1 << 8,
|
|
|
|
kHIDDEN_BY_CLICK : 1 << 7,
|
2015-03-03 19:16:27 +09:00
|
|
|
|
|
|
|
CLOSE_BUTTONS_ONLY_ON_CURRENT_TAB : 0,
|
|
|
|
CLOSE_BUTTONS_ON_ALL_TABS : 1,
|
|
|
|
CLOSE_BUTTONS_DISABLED : 2,
|
|
|
|
CLOSE_BUTTONS_ON_TABBAR : 3,
|
|
|
|
|
|
|
|
MOUSE_POSITION_UNKNOWN : 0,
|
|
|
|
MOUSE_POSITION_OUTSIDE : (1 << 0),
|
|
|
|
MOUSE_POSITION_INSIDE : (1 << 1),
|
|
|
|
MOUSE_POSITION_NEAR : (1 << 2),
|
|
|
|
MOUSE_POSITION_SENSITIVE : (1 << 1) | (1 << 2)
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2015-03-05 23:59:19 +09:00
|
|
|
function AutoHideBase(aTabBrowser)
|
2015-03-03 19:16:27 +09:00
|
|
|
{
|
|
|
|
}
|
2015-03-05 23:59:19 +09:00
|
|
|
AutoHideBase.prototype = inherit(AutoHideConstants, {
|
|
|
|
window : null,
|
|
|
|
browser : null,
|
|
|
|
treeStyleTab : null,
|
|
|
|
|
|
|
|
getMode : function AHB_getMode(aTabBrowser)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2015-03-05 23:59:19 +09:00
|
|
|
var b = aTabBrowser || this.browser;
|
|
|
|
var mode = b.getAttribute(this.kMODE);
|
2014-09-30 20:09:27 +09:00
|
|
|
return mode ? parseInt(mode) : this.kMODE_DISABLED ;
|
|
|
|
},
|
2015-03-05 23:59:19 +09:00
|
|
|
getModeForNormal : function AHB_getModeForNormal(aTabBrowser)
|
|
|
|
{
|
|
|
|
var b = aTabBrowser || this.browser;
|
|
|
|
return parseInt(b.getAttribute(this.kMODE+'-normal') || this.lastNormalMode);
|
|
|
|
},
|
|
|
|
getModeForFullScreen : function AHB_getModeForFullScreen(aTabBrowser)
|
|
|
|
{
|
|
|
|
var b = aTabBrowser || this.browser;
|
|
|
|
return parseInt(b.getAttribute(this.kMODE+'-fullscreen') || this.lastFullscreenMode);
|
|
|
|
},
|
|
|
|
|
|
|
|
get mode() /* PUBLIC API */
|
|
|
|
{
|
|
|
|
return this.getMode(this.browser);
|
|
|
|
},
|
2014-09-30 20:09:27 +09:00
|
|
|
set mode(aValue)
|
|
|
|
{
|
|
|
|
this.browser.setAttribute(this.kMODE, aValue);
|
|
|
|
return aValue;
|
|
|
|
},
|
2015-03-05 23:59:19 +09:00
|
|
|
|
2015-11-27 19:17:47 +09:00
|
|
|
get shouldShrink()
|
|
|
|
{
|
|
|
|
var toggleKey = 'tabbar.autoHide.mode.toggle';
|
|
|
|
if (this.window.fullScreen)
|
|
|
|
toggleKey += '.fullscreen';
|
|
|
|
return utils.getTreePref(toggleKey) == this.kMODE_SHRINK;
|
|
|
|
},
|
|
|
|
|
2015-03-05 23:13:50 +09:00
|
|
|
get lastNormalMode()
|
2015-03-03 19:45:44 +09:00
|
|
|
{
|
2015-03-05 23:59:19 +09:00
|
|
|
var lastMode = this.treeStyleTab.getWindowValue(this.kMODE + '-normal');
|
2015-03-03 19:45:44 +09:00
|
|
|
if (lastMode !== '')
|
|
|
|
return parseInt(lastMode);
|
|
|
|
|
|
|
|
return utils.getTreePref('tabbar.autoHide.mode');
|
|
|
|
},
|
2015-03-05 23:59:19 +09:00
|
|
|
set lastNormalMode(aValue)
|
2015-03-05 23:13:50 +09:00
|
|
|
{
|
2015-03-05 23:59:19 +09:00
|
|
|
this.treeStyleTab.setWindowValue(this.kMODE + '-normal', aValue);
|
|
|
|
return aValue;
|
|
|
|
},
|
|
|
|
|
|
|
|
get lastFullscreenMode()
|
|
|
|
{
|
|
|
|
var lastMode = this.treeStyleTab.getWindowValue(this.kMODE + '-fullscreen');
|
2015-03-05 23:13:50 +09:00
|
|
|
if (lastMode !== '')
|
|
|
|
return parseInt(lastMode);
|
|
|
|
|
|
|
|
return utils.getTreePref('tabbar.autoHide.mode.fullscreen');
|
|
|
|
},
|
2015-03-05 23:59:19 +09:00
|
|
|
set lastFullscreenMode(aValue)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2015-03-05 23:59:19 +09:00
|
|
|
this.treeStyleTab.setWindowValue(this.kMODE + '-fullscreen', aValue);
|
|
|
|
return aValue;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
|
2015-03-05 23:59:19 +09:00
|
|
|
function AutoHideBrowser(aTabBrowser)
|
|
|
|
{
|
|
|
|
this.init(aTabBrowser);
|
|
|
|
}
|
|
|
|
AutoHideBrowser.prototype = inherit(AutoHideBase.prototype, {
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
get state()
|
|
|
|
{
|
|
|
|
return this.browser.getAttribute(this.kSTATE) || this.kSTATE_EXPANDED;
|
|
|
|
},
|
|
|
|
get expanded()
|
|
|
|
{
|
|
|
|
return this.state == this.kSTATE_EXPANDED;
|
|
|
|
},
|
|
|
|
get shrunken()
|
|
|
|
{
|
|
|
|
return this.state == this.kSTATE_SHRUNKEN;
|
|
|
|
},
|
|
|
|
get hidden()
|
|
|
|
{
|
|
|
|
return this.state == this.kSTATE_HIDDEN;
|
|
|
|
},
|
2015-03-06 00:42:30 +09:00
|
|
|
|
|
|
|
get toggler()
|
|
|
|
{
|
|
|
|
return this.document.getAnonymousElementByAttribute(this.browser, 'class', this.treeStyleTab.kTABBAR_TOGGLER);
|
|
|
|
},
|
2014-09-30 20:09:27 +09:00
|
|
|
|
2015-03-03 20:06:14 +09:00
|
|
|
updateMode : function AHB_updateMode(aNewMode)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2015-03-03 20:06:14 +09:00
|
|
|
if (aNewMode === undefined)
|
|
|
|
aNewMode = this.mode;
|
|
|
|
|
2015-03-05 23:13:50 +09:00
|
|
|
var suffix = this.treeStyleTab.isFullscreenAutoHide ? 'fullscreen' : 'normal' ;
|
2015-03-05 23:59:19 +09:00
|
|
|
this.treeStyleTab.setWindowValue(this.kMODE + '-' + suffix, aNewMode);
|
2015-03-03 20:06:14 +09:00
|
|
|
|
2015-03-03 19:53:26 +09:00
|
|
|
this.end();
|
2014-09-30 20:09:27 +09:00
|
|
|
// update internal property after the appearance of the tab bar is updated.
|
|
|
|
var w = this.window;
|
2016-02-22 14:07:18 +09:00
|
|
|
w.setTimeout((function() {
|
|
|
|
this.mode = aNewMode;
|
|
|
|
if (this.mode != this.kMODE_DISABLED)
|
|
|
|
this.start();
|
|
|
|
}).bind(this), 0);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
togglerSize : 0,
|
|
|
|
sensitiveArea : 7,
|
|
|
|
contentAreaScreenEnabled : true,
|
|
|
|
|
|
|
|
closeButtonsMode : -1,
|
|
|
|
|
|
|
|
get XOffset()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
switch (this.mode)
|
|
|
|
{
|
|
|
|
case this.kMODE_DISABLED:
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
case this.kMODE_HIDE:
|
|
|
|
let offset = this.width + this.splitterWidth;
|
|
|
|
let resizer = this.resizer;
|
|
|
|
if (sv.position == 'left') {
|
|
|
|
offset += this.togglerSize;
|
|
|
|
if (resizer)
|
|
|
|
offset += resizer.boxObject.width;
|
|
|
|
}
|
|
|
|
else if (sv.position == 'right') {
|
|
|
|
offset -= this.togglerSize;
|
|
|
|
if (resizer)
|
|
|
|
offset -= resizer.boxObject.width;
|
|
|
|
}
|
|
|
|
return offset;
|
|
|
|
|
|
|
|
default:
|
|
|
|
case this.kMODE_SHRINK:
|
2015-03-04 00:44:01 +09:00
|
|
|
return this.expandedWidth - this.shrunkenWidth;
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
},
|
|
|
|
get YOffset()
|
|
|
|
{
|
|
|
|
return this.height;
|
|
|
|
},
|
|
|
|
extraXOffset : 0,
|
|
|
|
extraYOffset : 0,
|
|
|
|
|
|
|
|
get currentXOffset()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
return (
|
|
|
|
sv.position == 'left' &&
|
|
|
|
this.mode != this.kMODE_DISABLED &&
|
|
|
|
this.expanded
|
|
|
|
) ? this.XOffset : 0 ;
|
|
|
|
},
|
|
|
|
get currentYOffset()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
return (
|
|
|
|
sv.position == 'top' &&
|
|
|
|
this.mode != this.kMODE_DISABLED &&
|
|
|
|
this.expanded
|
|
|
|
) ? this.YOffset : 0 ;
|
|
|
|
},
|
|
|
|
|
2015-03-04 00:44:01 +09:00
|
|
|
get tabbarWidth()
|
|
|
|
{
|
|
|
|
return this.expanded ? this.expandedWidth : this.shrunkenWidth ;
|
|
|
|
},
|
|
|
|
set tabbarWidth(aValue)
|
|
|
|
{
|
2016-05-30 02:55:17 +09:00
|
|
|
log('setting "width" to '+aValue+' (expanded='+this.expanded+')');
|
2015-03-04 00:44:01 +09:00
|
|
|
if (this.expanded)
|
|
|
|
return this.expandedWidth = aValue;
|
|
|
|
else
|
|
|
|
return this.shrunkenWidth = aValue;
|
|
|
|
},
|
|
|
|
get expandedWidth()
|
|
|
|
{
|
|
|
|
var lastWidth = this.treeStyleTab.getWindowValue(this.kTABBAR_EXPANDED_WIDTH);
|
2015-09-29 05:11:12 +09:00
|
|
|
return lastWidth === '' ?
|
|
|
|
utils.getTreePref('tabbar.width') :
|
|
|
|
parseInt(lastWidth);
|
2015-03-04 00:44:01 +09:00
|
|
|
},
|
|
|
|
set expandedWidth(aValue)
|
|
|
|
{
|
|
|
|
this.treeStyleTab.setWindowValue(this.kTABBAR_EXPANDED_WIDTH, aValue);
|
2015-09-29 03:45:10 +09:00
|
|
|
utils.setTreePref('tabbar.width', aValue);
|
2016-05-30 02:55:17 +09:00
|
|
|
this.reserveFixWidth('expanded');
|
2015-03-04 00:44:01 +09:00
|
|
|
return aValue;
|
|
|
|
},
|
|
|
|
get shrunkenWidth()
|
|
|
|
{
|
|
|
|
var lastWidth = this.treeStyleTab.getWindowValue(this.kTABBAR_SHRUNKEN_WIDTH);
|
2015-09-29 05:11:12 +09:00
|
|
|
return lastWidth === '' ?
|
|
|
|
utils.getTreePref('tabbar.shrunkenWidth') :
|
|
|
|
parseInt(lastWidth);
|
2015-03-04 00:44:01 +09:00
|
|
|
},
|
|
|
|
set shrunkenWidth(aValue)
|
|
|
|
{
|
|
|
|
this.treeStyleTab.setWindowValue(this.kTABBAR_SHRUNKEN_WIDTH, aValue);
|
2015-09-29 03:45:10 +09:00
|
|
|
utils.setTreePref('tabbar.shrunkenWidth', aValue);
|
2016-05-30 02:55:17 +09:00
|
|
|
this.reserveFixWidth('shrunken');
|
2015-03-04 00:44:01 +09:00
|
|
|
return aValue;
|
|
|
|
},
|
|
|
|
|
2016-05-30 02:55:17 +09:00
|
|
|
reserveFixWidth : function(aTrigger)
|
|
|
|
{
|
|
|
|
if (this._collectingTabbarWidth)
|
|
|
|
clearTimeout(this._collectingTabbarWidth);
|
|
|
|
var stack = new Error().stack;
|
|
|
|
this._collectingTabbarWidth = setTimeout((function() {
|
|
|
|
log('reserveFixWidth: \n'+stack);
|
|
|
|
var newWidth = this.treeStyleTab.calculateCorrectExpandedAndShrunkenWidth({
|
|
|
|
expanded : this.expandedWidth,
|
|
|
|
shrunken : this.shrunkenWidth
|
|
|
|
}, aTrigger);
|
|
|
|
if (this.shrunkenWidth != newWidth.shrunken)
|
|
|
|
this.shrunkenWidth = newWidth.shrunken;
|
|
|
|
if (this.expandedWidth != newWidth.expanded)
|
|
|
|
this.expandedWidth = newWidth.expanded;
|
|
|
|
}).bind(this), 100);
|
|
|
|
},
|
|
|
|
|
2015-03-04 00:44:01 +09:00
|
|
|
resetWidth : function AHB_resetWidth()
|
|
|
|
{
|
|
|
|
this.expandedWidth = utils.getTreePref('tabbar.width.default');
|
|
|
|
this.shrunkenWidth = utils.getTreePref('tabbar.shrunkenWidth.default');
|
|
|
|
},
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
get screen()
|
|
|
|
{
|
|
|
|
return this.document.getElementById('treestyletab-autohide-content-area-screen');
|
|
|
|
},
|
|
|
|
get resizer()
|
|
|
|
{
|
|
|
|
return this.document.getElementById('treestyletab-tabbar-resizer-splitter');
|
|
|
|
},
|
|
|
|
|
|
|
|
start : function AHB_start(aReason)
|
|
|
|
{
|
2015-03-03 18:56:55 +09:00
|
|
|
if (this.enabled)
|
|
|
|
return;
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
this.enabled = true;
|
|
|
|
aReason = aReason || 0;
|
|
|
|
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var w = this.window;
|
|
|
|
|
|
|
|
this.screen.hidePopup();
|
|
|
|
|
|
|
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_EXPANDED);
|
|
|
|
|
|
|
|
if (!(aReason & this.kSHOWHIDE_BY_API)) {
|
2016-02-14 22:09:15 +09:00
|
|
|
w.addEventListener('blur', this, true);
|
|
|
|
ReferenceCounter.add('w,blur,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener('dragover', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,dragover,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener('dragleave', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,dragleave,AHW,true');
|
2014-11-11 17:45:12 +09:00
|
|
|
sv.tabStripPlaceHolder.addEventListener('mousedown', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('tabStripPlaceHolder,mousedown,AHW,true');
|
2014-11-11 17:45:12 +09:00
|
|
|
sv.tabStripPlaceHolder.addEventListener('mouseup', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('tabStripPlaceHolder,mouseup,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
sv.tabStrip.addEventListener('mousedown', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('tabStrip,mousedown,AHW,true');
|
2015-11-02 15:18:23 +09:00
|
|
|
w.addEventListener('mouseup', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('w,mouseup,AHW,true');
|
2015-11-02 15:18:23 +09:00
|
|
|
w.addEventListener('dragend', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('w,dragend,AHW,true');
|
2015-11-02 15:18:23 +09:00
|
|
|
w.addEventListener('drop', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('w,drop,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
if (this.shouldListenMouseMove)
|
|
|
|
this.startListenMouseMove();
|
|
|
|
if (b == w.gBrowser && sv.shouldListenKeyEventsForAutoHide)
|
|
|
|
w.TreeStyleTabService.startListenKeyEventsFor(sv.LISTEN_FOR_AUTOHIDE);
|
|
|
|
this.userActionListening = true;
|
2014-11-11 17:45:12 +09:00
|
|
|
this.notifyStatusToAllTabs();
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
w.addEventListener(sv.kEVENT_TYPE_PRINT_PREVIEW_ENTERED, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('w,kEVENT_TYPE_PRINT_PREVIEW_ENTERED,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
w.addEventListener(sv.kEVENT_TYPE_PRINT_PREVIEW_EXITED, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('w,kEVENT_TYPE_PRINT_PREVIEW_EXITED,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
this.updateTransparency();
|
|
|
|
|
|
|
|
this.showHideInternal(this.kSHOWHIDE_BY_START | aReason);
|
|
|
|
|
|
|
|
b.treeStyleTab.fixTooNarrowTabbar();
|
|
|
|
},
|
|
|
|
|
2015-03-03 20:06:14 +09:00
|
|
|
end : function AHB_end()
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2015-03-03 18:56:55 +09:00
|
|
|
if (!this.enabled)
|
|
|
|
return;
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
this.enabled = false;
|
|
|
|
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var w = this.window;
|
|
|
|
|
|
|
|
this.show(this.kSHOWHIDE_BY_END);
|
|
|
|
|
|
|
|
this.screen.hidePopup();
|
|
|
|
|
|
|
|
if (this.userActionListening) {
|
2016-02-14 22:09:15 +09:00
|
|
|
w.removeEventListener('blur', this, true);
|
|
|
|
ReferenceCounter.remove('w,blur,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener('dragover', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,dragover,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener('dragleave', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,dragleave,AHW,true');
|
2014-11-11 17:45:12 +09:00
|
|
|
sv.tabStripPlaceHolder.removeEventListener('mousedown', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('tabStripPlaceHolder,mousedown,AHW,true');
|
2014-11-11 17:45:12 +09:00
|
|
|
sv.tabStripPlaceHolder.removeEventListener('mouseup', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('tabStripPlaceHolder,mouseup,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
sv.tabStrip.removeEventListener('mousedown', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('tabStrip,mousedown,AHW,true');
|
2015-11-02 15:18:23 +09:00
|
|
|
w.removeEventListener('mouseup', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('w,mouseup,AHW,true');
|
2015-11-02 15:18:23 +09:00
|
|
|
w.removeEventListener('dragend', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('w,dragend,AHW,true');
|
2015-11-02 15:18:23 +09:00
|
|
|
w.removeEventListener('drop', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('w,drop,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
this.endListenMouseMove();
|
|
|
|
if (b == w.gBrowser)
|
|
|
|
w.TreeStyleTabService.endListenKeyEventsFor(sv.LISTEN_FOR_AUTOHIDE);
|
|
|
|
this.userActionListening = false;
|
2014-11-11 17:45:12 +09:00
|
|
|
this.notifyStatusToAllTabs();
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
w.removeEventListener(sv.kEVENT_TYPE_PRINT_PREVIEW_ENTERED, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('w,kEVENT_TYPE_PRINT_PREVIEW_ENTERED,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
w.removeEventListener(sv.kEVENT_TYPE_PRINT_PREVIEW_EXITED, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('w,kEVENT_TYPE_PRINT_PREVIEW_EXITED,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
this.updateTransparency();
|
|
|
|
|
|
|
|
sv.removeTabbrowserAttribute(this.kAUTOHIDE);
|
|
|
|
sv.removeTabbrowserAttribute(this.kSTATE);
|
|
|
|
|
|
|
|
if (sv.isVertical)
|
|
|
|
sv.setTabStripAttribute('width', this.widthFromMode);
|
|
|
|
},
|
2014-11-11 17:45:12 +09:00
|
|
|
|
|
|
|
notifyStatusToAllTabs : function AHB_notifyStatusToAllTabs()
|
|
|
|
{
|
|
|
|
let tabs = this.treeStyleTab.getTabs(this.browser);
|
|
|
|
tabs.forEach(this.notifyStatusToTab, this);
|
|
|
|
},
|
|
|
|
notifyStatusToTab : function AHB_notifyStatusToTab(aTab)
|
|
|
|
{
|
|
|
|
aTab.__treestyletab__contentBridge.sendAsyncCommand(this.COMMAND_NOTIFY_AUTOHIDE_STATUS, {
|
|
|
|
basicListening : this.mouseMoveListening || this.userActionListening,
|
|
|
|
advanceListening : this.mouseMoveListening
|
|
|
|
});
|
|
|
|
},
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
// fullscreen
|
|
|
|
|
|
|
|
startForFullScreen : function AHB_startForFullScreen()
|
|
|
|
{
|
|
|
|
this.mode = this.getMode();
|
|
|
|
this.end();
|
|
|
|
this.mode = prefs.getPref('browser.fullscreen.autohide') ?
|
|
|
|
this.getModeForFullScreen() :
|
|
|
|
this.kMODE_DISABLED ;
|
|
|
|
if (this.mode != this.kMODE_DISABLED) {
|
|
|
|
this.start();
|
|
|
|
this.treeStyleTab.removeTabbrowserAttribute('moz-collapsed');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
endForFullScreen : function AHB_endForFullScreen()
|
|
|
|
{
|
|
|
|
this.mode = this.getModeForFullScreen();
|
|
|
|
this.end();
|
|
|
|
this.mode = utils.getTreePref('tabbar.autoHide.mode');
|
|
|
|
this.treeStyleTab.checkTabsIndentOverflow();
|
|
|
|
if (this.mode != this.kMODE_DISABLED)
|
|
|
|
this.start();
|
|
|
|
},
|
|
|
|
|
|
|
|
// mousemove
|
|
|
|
|
|
|
|
startListenMouseMove : function AHB_startListenMouseMove()
|
|
|
|
{
|
2015-03-03 18:56:55 +09:00
|
|
|
if (this.mouseMoveListening)
|
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
this.screen.addEventListener('mousemove', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('screen,mousemove,AHW,true');
|
2015-11-27 18:40:59 +09:00
|
|
|
this.treeStyleTab.browser.addEventListener('mousemove', this, true);
|
|
|
|
ReferenceCounter.add('browser,mousemove,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
this.treeStyleTab.tabStrip.addEventListener('mousemove', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('tabStrip,mousemove,AHW,true');
|
2015-03-06 00:42:30 +09:00
|
|
|
this.toggler.addEventListener('mousemove', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('toggler,mousemove,AHW,true');
|
2015-03-13 16:45:38 +09:00
|
|
|
this.window.addEventListener('TabRemotenessChange', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('window,TabRemotenessChange,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
this.mouseMoveListening = true;
|
2014-11-11 17:45:12 +09:00
|
|
|
|
|
|
|
this.notifyStatusToAllTabs();
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
endListenMouseMove : function AHB_endListenMouseMove()
|
|
|
|
{
|
2015-03-03 18:56:55 +09:00
|
|
|
if (!this.mouseMoveListening)
|
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
this.screen.removeEventListener('mousemove', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('screen,mousemove,AHW,true');
|
2015-11-27 18:40:59 +09:00
|
|
|
this.treeStyleTab.browser.removeEventListener('mousemove', this, true);
|
|
|
|
ReferenceCounter.remove('browser,mousemove,AHW,true');
|
2014-09-30 20:09:27 +09:00
|
|
|
this.treeStyleTab.tabStrip.removeEventListener('mousemove', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('tabStrip,mousemove,AHW,true');
|
2015-03-06 00:42:30 +09:00
|
|
|
this.toggler.removeEventListener('mousemove', this, true);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('toggler,mousemove,AHW,true');
|
2015-03-13 16:45:38 +09:00
|
|
|
this.window.removeEventListener('TabRemotenessChange', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('window,TabRemotenessChange,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
this.mouseMoveListening = false;
|
2014-11-11 17:45:12 +09:00
|
|
|
|
|
|
|
this.notifyStatusToAllTabs();
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
get shouldListenMouseMove()
|
|
|
|
{
|
|
|
|
return utils.getTreePref('tabbar.autoShow.mousemove');
|
|
|
|
},
|
|
|
|
|
|
|
|
get shouldListenKeyEventsForAutoHide()
|
|
|
|
{
|
|
|
|
return utils.getTreePref('tabbar.autoShow.accelKeyDown') ||
|
|
|
|
utils.getTreePref('tabbar.autoShow.tabSwitch');
|
|
|
|
},
|
|
|
|
|
2014-11-11 17:45:12 +09:00
|
|
|
showHideOnMouseMove : function AHB_showHideOnMouseMove(aCoordinates)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2015-11-02 14:43:27 +09:00
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var w = this.window;
|
|
|
|
|
|
|
|
var exapndedByUnknownReason = (
|
|
|
|
this.expanded &&
|
|
|
|
!(this.showHideReason & this.kSHOWN_BY_ANY_REASON)
|
|
|
|
);
|
2014-11-11 17:45:12 +09:00
|
|
|
var position = this.getMousePosition(aCoordinates);
|
2015-11-02 14:43:27 +09:00
|
|
|
|
2015-10-26 16:32:31 +09:00
|
|
|
if (utils.isDebugging('autoHide')) {
|
2014-12-01 23:25:48 +09:00
|
|
|
let humanReadablePosition = [];
|
|
|
|
if (position & this.MOUSE_POSITION_OUTSIDE)
|
|
|
|
humanReadablePosition.push('outside');
|
|
|
|
if (position & this.MOUSE_POSITION_INSIDE)
|
|
|
|
humanReadablePosition.push('inside');
|
|
|
|
if (position & this.MOUSE_POSITION_NEAR)
|
|
|
|
humanReadablePosition.push('near');
|
|
|
|
if (position & this.MOUSE_POSITION_SENSITIVE)
|
|
|
|
humanReadablePosition.push('sensitive');
|
2015-11-02 14:43:27 +09:00
|
|
|
let extraInfo = [];
|
|
|
|
if (sv.isPopupShown())
|
|
|
|
extraInfo.push('popupshown');
|
|
|
|
if (exapndedByUnknownReason)
|
|
|
|
extraInfo.push('expanded-by-unknown');
|
|
|
|
if (this.lastMouseDownTarget)
|
|
|
|
extraInfo.push('mousedown');
|
2016-02-10 19:10:46 +09:00
|
|
|
log('showHideOnMouseMove: ' +
|
2014-12-01 23:25:48 +09:00
|
|
|
'('+aCoordinates.screenX + ', ' + aCoordinates.screenY + ') => ' +
|
2015-11-02 14:43:27 +09:00
|
|
|
humanReadablePosition.join(', ') +
|
2016-02-10 19:10:46 +09:00
|
|
|
(extraInfo.length ? ('[' + extraInfo.join(', ') + ']') : ''));
|
2014-12-01 23:25:48 +09:00
|
|
|
}
|
2015-11-02 14:43:27 +09:00
|
|
|
|
|
|
|
if (sv.isPopupShown() ||
|
|
|
|
exapndedByUnknownReason ||
|
|
|
|
this.lastMouseDownTarget ||
|
|
|
|
position == this.MOUSE_POSITION_UNKNOWN)
|
2014-09-30 20:09:27 +09:00
|
|
|
return;
|
|
|
|
|
|
|
|
this.cancelShowHideOnMouseMove();
|
|
|
|
this.showHideContentsAreaScreen();
|
|
|
|
|
|
|
|
var shouldShow = position & this.MOUSE_POSITION_SENSITIVE;
|
2016-02-22 14:03:26 +09:00
|
|
|
var delayToShow = utils.getTreePref('tabbar.autoHide.delay.show');
|
2014-09-30 20:09:27 +09:00
|
|
|
if (this.expanded) { // currently shown, let's hide it.
|
|
|
|
if (shouldShow) {
|
|
|
|
this.show(this.kSHOWN_BY_MOUSEMOVE);
|
|
|
|
this.cancelDelayedShowForShortcut();
|
|
|
|
}
|
|
|
|
else if (
|
|
|
|
!shouldShow &&
|
|
|
|
utils.getTreePref('tabbar.autoShow.mousemove')
|
|
|
|
) {
|
2016-02-22 14:03:26 +09:00
|
|
|
let delayToHide = utils.getTreePref('tabbar.autoHide.delay.hide');
|
|
|
|
if (delayToHide < 0)
|
|
|
|
delayToHide = delayToShow;
|
2016-02-22 14:07:18 +09:00
|
|
|
this.showHideOnMouseMoveTimer = w.setTimeout((function() {
|
|
|
|
this.cancelDelayedShowForShortcut();
|
|
|
|
this.hide(this.kSHOWN_BY_MOUSEMOVE);
|
|
|
|
}).bind(this), delayToHide);
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (shouldShow) { // currently shown, let's show it.
|
2016-02-22 14:07:18 +09:00
|
|
|
this.showHideOnMouseMoveTimer = w.setTimeout((function() {
|
|
|
|
this.cancelDelayedShowForShortcut();
|
|
|
|
this.show(this.kSHOWN_BY_MOUSEMOVE);
|
|
|
|
}).bind(this), delayToShow);
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
b = null;
|
|
|
|
},
|
2014-11-11 17:45:12 +09:00
|
|
|
getMousePosition : function AHB_getMousePosition(aCoordinates)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
|
|
|
var w = this.window;
|
|
|
|
if ('gestureInProgress' in w && w.gestureInProgress)
|
|
|
|
return this.MOUSE_POSITION_UNKNOWN;
|
|
|
|
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var pos = sv.position;
|
|
|
|
var box = this.getContentsAreaBox();
|
|
|
|
|
|
|
|
var sensitiveArea = this.sensitiveArea;
|
|
|
|
if (this.shrunken) {
|
|
|
|
let clickable;
|
|
|
|
let resizable = !sv.fixed;
|
|
|
|
if (resizable &
|
|
|
|
this.widthFromMode > 24 &&
|
2014-11-11 17:45:12 +09:00
|
|
|
(clickable = this.getNearestClickableBox(aCoordinates))) {
|
2014-09-30 20:09:27 +09:00
|
|
|
/* For resizing of shrunken tab bar and clicking closeboxes,
|
|
|
|
we have to shrink sensitive area. */
|
|
|
|
sensitiveArea = -(clickable.width + clickable.padding);
|
|
|
|
}
|
|
|
|
else if (resizable && this.resizer)
|
|
|
|
sensitiveArea = -this.resizer.boxObject.width;
|
|
|
|
else
|
|
|
|
sensitiveArea = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (
|
|
|
|
pos == 'left' ?
|
2014-11-11 17:45:12 +09:00
|
|
|
(aCoordinates.screenX > box.screenX + sensitiveArea) :
|
2014-09-30 20:09:27 +09:00
|
|
|
pos == 'right' ?
|
2014-11-11 17:45:12 +09:00
|
|
|
(aCoordinates.screenX < box.screenX + box.width - sensitiveArea) :
|
2014-09-30 20:09:27 +09:00
|
|
|
pos == 'bottom' ?
|
2014-11-11 17:45:12 +09:00
|
|
|
(aCoordinates.screenY < box.screenY + box.height - sensitiveArea) :
|
|
|
|
(aCoordinates.screenY > box.screenY + sensitiveArea)
|
2014-09-30 20:09:27 +09:00
|
|
|
) {
|
|
|
|
return this.MOUSE_POSITION_OUTSIDE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (
|
|
|
|
pos == 'left' ?
|
2014-11-11 17:45:12 +09:00
|
|
|
(aCoordinates.screenX <= box.screenX - sensitiveArea) :
|
2014-09-30 20:09:27 +09:00
|
|
|
pos == 'right' ?
|
2014-11-11 17:45:12 +09:00
|
|
|
(aCoordinates.screenX >= box.screenX + box.width + sensitiveArea) :
|
2014-09-30 20:09:27 +09:00
|
|
|
pos == 'bottom' ?
|
2014-11-11 17:45:12 +09:00
|
|
|
(aCoordinates.screenY >= box.screenY + box.height + sensitiveArea) :
|
|
|
|
(aCoordinates.screenY <= box.screenY - sensitiveArea)
|
2014-09-30 20:09:27 +09:00
|
|
|
) {
|
|
|
|
return this.MOUSE_POSITION_INSIDE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.MOUSE_POSITION_NEAR;
|
|
|
|
},
|
|
|
|
getContentsAreaBox : function AHB_getContentsAreaBox()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var box = b.mCurrentBrowser.boxObject;
|
|
|
|
var xoffset = (this.shrunken || this.hidden) ? 0 : this.XOffset ;
|
|
|
|
box = {
|
|
|
|
screenX : box.screenX + (sv.position == 'left' ? xoffset : 0 ),
|
|
|
|
screenY : box.screenY,
|
|
|
|
width : box.width - xoffset,
|
|
|
|
height : box.height
|
|
|
|
};
|
|
|
|
return box;
|
|
|
|
},
|
2014-11-11 17:45:12 +09:00
|
|
|
getNearestClickableBox : function AHB_getNearestClickableBox(aCoordinates)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
2014-11-11 17:45:12 +09:00
|
|
|
var tab = sv.getTabFromCoordinates(aCoordinates);
|
2014-09-30 20:09:27 +09:00
|
|
|
if (!tab)
|
|
|
|
return null;
|
|
|
|
|
|
|
|
var position = sv.invertedScreenPositionProp;
|
|
|
|
var size = sv.invertedSizeProp;
|
2014-11-11 17:45:12 +09:00
|
|
|
var coordinate = aCoordinates[sv.invertedScreenPositionProp];
|
2014-09-30 20:09:27 +09:00
|
|
|
var tabbox = tab.boxObject;
|
|
|
|
|
|
|
|
var closebox;
|
|
|
|
if (this.closeButtonsMode != this.CLOSE_BUTTONS_DISABLED &&
|
|
|
|
this.closeButtonsMode != this.CLOSE_BUTTONS_ON_TABBAR &&
|
|
|
|
(closebox = sv.getTabClosebox(tab)) &&
|
|
|
|
(closebox = closebox.boxObject) &&
|
|
|
|
closebox.width && closebox.height) {
|
|
|
|
let padding = Math.min(
|
|
|
|
closebox[position] - tabbox[position],
|
|
|
|
(tabbox[position] + tabbox[size]) - (closebox[position] + closebox[size])
|
|
|
|
);
|
|
|
|
if (closebox[position] - padding <= coordinate &&
|
|
|
|
closebox[position] + closebox[size] + padding >= coordinate)
|
|
|
|
return this.cloneBoxObject(closebox, { padding : padding });
|
|
|
|
}
|
|
|
|
|
|
|
|
var twisty;
|
|
|
|
if (sv.canCollapseSubtree(tab) &&
|
|
|
|
(twisty = sv.getTabTwisty(tab)) &&
|
|
|
|
(twisty = twisty.boxObject) &&
|
|
|
|
twisty.width && twisty.height) {
|
|
|
|
let padding = Math.min(
|
|
|
|
twisty[position] - tabbox[position],
|
|
|
|
(tabbox[position] + tabbox[size]) - (twisty[position] + twisty[size])
|
|
|
|
);
|
|
|
|
if (twisty[position] - padding <= coordinate &&
|
|
|
|
twisty[position] + twisty[size] + padding >= coordinate)
|
|
|
|
return this.cloneBoxObject(twisty, { padding : padding });
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
cloneBoxObject : function AHB_cloneBoxObject(aBoxObject, aOverride)
|
|
|
|
{
|
|
|
|
var box = {};
|
|
|
|
for (let i in aBoxObject)
|
|
|
|
{
|
|
|
|
if (typeof aBoxObject[i] != 'function')
|
|
|
|
box[i] = aBoxObject[i];
|
|
|
|
}
|
|
|
|
Object.keys(aOverride).forEach(function(aKey) {
|
|
|
|
box[aKey] = aOverride[aKey];
|
|
|
|
});
|
|
|
|
return box;
|
|
|
|
},
|
|
|
|
|
|
|
|
cancelShowHideOnMouseMove : function AHB_cancelShowHideOnMouseMove()
|
|
|
|
{
|
|
|
|
if (this.showHideOnMouseMoveTimer) {
|
|
|
|
this.window.clearTimeout(this.showHideOnMouseMoveTimer);
|
|
|
|
this.showHideOnMouseMoveTimer = null;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// feedback
|
|
|
|
|
2016-02-12 19:57:52 +09:00
|
|
|
showForFeedback : function AHB_showForFeedback(aTab)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
|
|
|
if (!this.enabled ||
|
|
|
|
!utils.getTreePref('tabbar.autoShow.feedback'))
|
|
|
|
return;
|
|
|
|
|
2016-05-30 02:20:07 +09:00
|
|
|
if (aTab.pinned || aTab.hidden)
|
|
|
|
return;
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
var w = this.window;
|
|
|
|
if (this.delayedShowForFeedbackTimer) {
|
|
|
|
w.clearTimeout(this.delayedShowForFeedbackTimer);
|
|
|
|
this.delayedShowForFeedbackTimer = null;
|
|
|
|
}
|
|
|
|
this.cancelHideForFeedback();
|
2016-02-22 14:36:01 +09:00
|
|
|
this.delayedShowForFeedbackTimer = w.setTimeout((function() {
|
2016-02-22 14:07:18 +09:00
|
|
|
this.delayedShowForFeedbackTimer = null;
|
|
|
|
this.delayedShowForFeedback(aTab);
|
|
|
|
}).bind(this), 100);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
2016-02-12 19:57:52 +09:00
|
|
|
delayedShowForFeedback : function AHB_delayedShowForFeedback(aTab)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2016-02-12 20:15:29 +09:00
|
|
|
this.treeStyleTab.highlightTab(aTab);
|
2014-09-30 20:09:27 +09:00
|
|
|
this.show(this.kSHOWN_BY_FEEDBACK);
|
|
|
|
this.cancelHideForFeedback();
|
2016-02-22 14:07:18 +09:00
|
|
|
this.delayedHideTabbarForFeedbackTimer = this.window.setTimeout((function() {
|
|
|
|
// TODO: we do something to highlight the given tab.
|
|
|
|
this.delayedHideTabbarForFeedbackTimer = null;
|
|
|
|
this.hide(this.kSHOWN_BY_FEEDBACK);
|
|
|
|
}).bind(this), utils.getTreePref('tabbar.autoShow.feedback.delay'));
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
cancelHideForFeedback : function AHB_cancelHideForFeedback()
|
|
|
|
{
|
|
|
|
if (this.delayedHideTabbarForFeedbackTimer) {
|
|
|
|
this.window.clearTimeout(this.delayedHideTabbarForFeedbackTimer);
|
|
|
|
this.delayedHideTabbarForFeedbackTimer = null;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
setWidth : function AHB_setWidth(aWidth, aForceExpanded)
|
|
|
|
{
|
2015-03-04 00:44:01 +09:00
|
|
|
aWidth = this.treeStyleTab.maxTabbarWidth(aWidth);
|
2014-09-30 20:09:27 +09:00
|
|
|
if (aForceExpanded ||
|
|
|
|
this.expanded ||
|
|
|
|
this.mode != this.kMODE_SHRINK)
|
2015-03-04 00:44:01 +09:00
|
|
|
this.expandedWidth = aWidth;
|
2014-09-30 20:09:27 +09:00
|
|
|
else
|
2015-03-04 00:44:01 +09:00
|
|
|
this.shrunkenWidth = aWidth;
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
updateMenuItem : function AHB_updateMenuItem(aNode)
|
|
|
|
{
|
2015-03-03 18:56:55 +09:00
|
|
|
if (!aNode)
|
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
if (this.mode != this.kMODE_DISABLED)
|
|
|
|
aNode.setAttribute('checked', true);
|
|
|
|
else
|
|
|
|
aNode.removeAttribute('checked');
|
2015-11-27 19:17:47 +09:00
|
|
|
|
|
|
|
var labelAttribute = this.shouldShrink ? 'label-shrink' : 'label-hide' ;
|
|
|
|
aNode.setAttribute('label', aNode.getAttribute(labelAttribute));
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
// show/hide tabbar
|
|
|
|
|
|
|
|
get width()
|
|
|
|
{
|
|
|
|
if (this.expanded) {
|
|
|
|
this._width = this.treeStyleTab.tabStrip.boxObject.width || this._width;
|
|
|
|
}
|
|
|
|
return this._width;
|
|
|
|
},
|
|
|
|
set width(aNewWidth)
|
|
|
|
{
|
|
|
|
this._width = aNewWidth;
|
|
|
|
return this._width;
|
|
|
|
},
|
|
|
|
_width : 0,
|
|
|
|
|
|
|
|
get widthFromMode()
|
|
|
|
{
|
2015-03-04 00:44:01 +09:00
|
|
|
return this.shrunken ?
|
|
|
|
this.shrunkenWidth :
|
|
|
|
this.expandedWidth ;
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
get placeHolderWidthFromMode()
|
|
|
|
{
|
|
|
|
return (this.mode == this.kMODE_SHRINK) ?
|
2015-03-04 00:44:01 +09:00
|
|
|
this.shrunkenWidth :
|
|
|
|
this.expandedWidth ;
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
get height()
|
|
|
|
{
|
|
|
|
if (this.expanded) {
|
|
|
|
this._height = this.treeStyleTab.tabStrip.boxObject.height;
|
|
|
|
}
|
|
|
|
return this._height;
|
|
|
|
},
|
|
|
|
set height(aNewHeight)
|
|
|
|
{
|
|
|
|
this._height = aNewHeight;
|
|
|
|
return this._height;
|
|
|
|
},
|
|
|
|
_height : 0,
|
|
|
|
|
|
|
|
get splitterWidth()
|
|
|
|
{
|
|
|
|
if (this.expanded) {
|
|
|
|
var splitter = this.document.getAnonymousElementByAttribute(this.browser, 'class', this.treeStyleTab.kSPLITTER);
|
|
|
|
this._splitterWidth = (splitter ? splitter.boxObject.width : 0 );
|
|
|
|
}
|
|
|
|
return this._splitterWidth;
|
|
|
|
},
|
|
|
|
set splitterWidth(aNewWidth)
|
|
|
|
{
|
|
|
|
this._splitterWidth = aNewWidth;
|
|
|
|
return this._splitterWidth;
|
|
|
|
},
|
|
|
|
_splitterWidth : 0,
|
|
|
|
|
|
|
|
showHideInternal : function AHB_showHideInternal(aReason)
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var pos = sv.position;
|
|
|
|
|
|
|
|
aReason = aReason || 0;
|
|
|
|
|
|
|
|
if (this.expanded) { // to be hidden or shrunken
|
|
|
|
let reason = this.kSHOWN_BY_UNKNOWN;
|
|
|
|
if (aReason & this.kSHOWHIDE_BY_API)
|
|
|
|
reason = aReason;
|
|
|
|
this.onHiding();
|
|
|
|
this.showHideReason = reason;
|
|
|
|
}
|
|
|
|
else { // to be shown or expanded
|
|
|
|
this.onShowing();
|
|
|
|
this.showHideReason = aReason || this.showHideReason || this.kSHOWN_BY_UNKNOWN;
|
|
|
|
}
|
|
|
|
|
2015-10-26 16:32:31 +09:00
|
|
|
if (utils.isDebugging('autoHide')) {
|
2015-09-28 21:08:33 +09:00
|
|
|
let givenReason = this._getHumanReadableReason(aReason);
|
|
|
|
let unifiedReason = this._getHumanReadableReason(this.showHideReason);
|
2014-09-30 20:09:27 +09:00
|
|
|
if (this.expanded)
|
2016-02-10 19:10:46 +09:00
|
|
|
logWithStackTrace('autoHide: show by ' + aReason + '(' + givenReason + ' / ' + unifiedReason + ')');
|
2014-09-30 20:09:27 +09:00
|
|
|
else
|
2016-02-10 19:10:46 +09:00
|
|
|
logWithStackTrace('autoHide: hide by ' + aReason + '(' + givenReason + ' / ' + unifiedReason + ')');
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
this.fireStateChangingEvent();
|
|
|
|
|
|
|
|
if (this.expanded)
|
|
|
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'show');
|
|
|
|
b.mTabContainer.adjustTabstrip();
|
|
|
|
sv.checkTabsIndentOverflow();
|
|
|
|
|
2016-02-22 14:07:18 +09:00
|
|
|
this.window.setTimeout((function() {
|
|
|
|
this.fireStateChangeEvent();
|
|
|
|
this.showHideContentsAreaScreen();
|
|
|
|
}).bind(this), 0);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
2015-09-28 21:08:33 +09:00
|
|
|
_getHumanReadableReason: function AHB_getHumanReadableReason(aReason)
|
|
|
|
{
|
|
|
|
let humanReadableReason =
|
|
|
|
(aReason & this.kSHOWN_BY_SHORTCUT ? 'shortcut ' : '' ) +
|
|
|
|
(aReason & this.kSHOWN_BY_MOUSEMOVE ? 'mousemove ' : '' ) +
|
|
|
|
(aReason & this.kSHOWN_BY_FEEDBACK ? 'feedback ' : '' ) +
|
|
|
|
(aReason & this.kSHOWHIDE_BY_START ? 'start ' : '' ) +
|
|
|
|
(aReason & this.kSHOWHIDE_BY_END ? 'end ' : '' ) +
|
|
|
|
(aReason & this.kSHOWHIDE_BY_POSITION_CHANGE ? 'positionchange ' : '' ) +
|
|
|
|
(aReason & this.kSHOWHIDE_BY_RESIZE ? 'resize ' : '' ) +
|
|
|
|
(aReason & this.kHIDDEN_BY_CLICK ? 'click ' : '' );
|
|
|
|
return humanReadableReason.replace(/\s+$/, '');
|
|
|
|
},
|
2014-09-30 20:09:27 +09:00
|
|
|
showHideContentsAreaScreen : function AHB_showHideContentsAreaScreen()
|
|
|
|
{
|
|
|
|
if (
|
|
|
|
this.expanded &&
|
|
|
|
this.contentAreaScreenEnabled &&
|
|
|
|
Services.focus.activeWindow &&
|
2014-11-11 18:42:30 +09:00
|
|
|
Services.focus.activeWindow.top == this.window
|
2014-09-30 20:09:27 +09:00
|
|
|
) {
|
2014-11-11 18:42:30 +09:00
|
|
|
this.browser.selectedTab.__treestyletab__contentBridge.checkPluginAreaExistence()
|
|
|
|
.then((function(aExistence) {
|
|
|
|
if (aExistence)
|
|
|
|
this.showContentsAreaScreen();
|
|
|
|
else
|
|
|
|
this.hideContentsAreaScreen();
|
|
|
|
}).bind(this))
|
|
|
|
.catch((function(aError) {
|
|
|
|
this.hideContentsAreaScreen();
|
|
|
|
Components.utils.reportError(aError);
|
|
|
|
}).bind(this));
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
else {
|
2014-11-11 18:42:30 +09:00
|
|
|
this.hideContentsAreaScreen();
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
},
|
2014-11-11 18:42:30 +09:00
|
|
|
showContentsAreaScreen : function AHB_showContentsAreaScreen()
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2014-11-11 18:42:30 +09:00
|
|
|
let box = this.getContentsAreaBox();
|
|
|
|
let style = this.screen.style;
|
|
|
|
let width = Math.min(box.width, this.window.screen.availWidth - box.screenX);
|
|
|
|
let height = Math.min(box.height, this.window.screen.availHeight - box.screenY);
|
|
|
|
style.width = width+'px';
|
|
|
|
style.height = height+'px';
|
|
|
|
if (this.screen.state == 'open')
|
|
|
|
this.screen.moveTo(box.screenX, box.screenY);
|
|
|
|
else
|
|
|
|
this.screen.openPopupAtScreen(box.screenX, box.screenY, false);
|
|
|
|
this.screen.setAttribute('popup-shown', true);
|
|
|
|
},
|
|
|
|
hideContentsAreaScreen : function AHB_hideContentsAreaScreen()
|
|
|
|
{
|
|
|
|
this.screen.removeAttribute('popup-shown');
|
|
|
|
if (this.screen.state != 'close')
|
|
|
|
this.screen.hidePopup();
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
2014-11-11 18:42:30 +09:00
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
show : function AHB_show(aReason) /* PUBLIC API */
|
|
|
|
{
|
|
|
|
if (this.showHideReason & this.kSHOWHIDE_BY_API) {
|
|
|
|
this.end();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (aReason) {
|
|
|
|
this.showHideReason |= aReason;
|
|
|
|
}
|
|
|
|
if (!this.expanded)
|
2015-09-25 14:36:20 +09:00
|
|
|
this.showHideInternal(aReason);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
hide : function AHB_hide(aReason) /* PUBLIC API */
|
|
|
|
{
|
|
|
|
if (!this.enabled) {
|
|
|
|
this.start(aReason | this.kSHOWHIDE_BY_API);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (aReason) {
|
|
|
|
if (aReason == this.kSHOWN_BY_ANY_REASON)
|
|
|
|
this.showHideReason &= ~this.kSHOWN_BY_ANY_REASON;
|
|
|
|
else if (this.showHideReason & aReason)
|
|
|
|
this.showHideReason ^= aReason;
|
|
|
|
|
|
|
|
if (this.showHideReason & this.kSHOWN_BY_ANY_REASON)
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (this.expanded)
|
2015-09-25 14:36:20 +09:00
|
|
|
this.showHideInternal(aReason);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
onShowing : function AHB_onShowing()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var pos = sv.position;
|
|
|
|
|
|
|
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_EXPANDED);
|
|
|
|
|
|
|
|
switch (this.mode)
|
|
|
|
{
|
|
|
|
case this.kMODE_DISABLED:
|
|
|
|
break;
|
|
|
|
|
|
|
|
case this.kMODE_HIDE:
|
|
|
|
sv.updateFloatingTabbar(sv.kTABBAR_UPDATE_BY_AUTOHIDE);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
case this.kMODE_SHRINK:
|
|
|
|
if (pos == 'left' || pos == 'right') {
|
2015-03-04 00:44:01 +09:00
|
|
|
let width = sv.maxTabbarWidth(this.expandedWidth);
|
2014-09-30 20:09:27 +09:00
|
|
|
sv.updateFloatingTabbar(sv.kTABBAR_UPDATE_BY_AUTOHIDE);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onHiding : function AHB_onHiding()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var pos = sv.position;
|
|
|
|
|
|
|
|
var box = (sv.tabStripPlaceHolder || sv.tabStrip).boxObject;
|
|
|
|
|
|
|
|
this.tabbarHeight = box.height;
|
|
|
|
this.width = box.width || this.width;
|
|
|
|
var splitter = this.document.getAnonymousElementByAttribute(b, 'class', sv.kSPLITTER);
|
|
|
|
this.splitterWidth = (splitter ? splitter.boxObject.width : 0 );
|
|
|
|
|
|
|
|
switch (this.mode)
|
|
|
|
{
|
|
|
|
case this.kMODE_DISABLED:
|
|
|
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'hidden');
|
|
|
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_HIDDEN);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case this.kMODE_HIDE:
|
|
|
|
sv.updateLastScrollPosition();
|
|
|
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'hidden');
|
|
|
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_HIDDEN);
|
|
|
|
sv.updateFloatingTabbar(sv.kTABBAR_UPDATE_BY_AUTOHIDE);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
case this.kMODE_SHRINK:
|
|
|
|
sv.setTabbrowserAttribute(this.kAUTOHIDE, 'show');
|
|
|
|
sv.setTabbrowserAttribute(this.kSTATE, this.kSTATE_SHRUNKEN);
|
|
|
|
if (pos == 'left' || pos == 'right')
|
2015-03-04 00:44:01 +09:00
|
|
|
sv.setTabStripAttribute('width', this.shrunkenWidth);
|
2014-09-30 20:09:27 +09:00
|
|
|
sv.updateFloatingTabbar(sv.kTABBAR_UPDATE_BY_AUTOHIDE);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
fireStateChangingEvent : function AHB_fireStateChangingEvent()
|
|
|
|
{
|
|
|
|
var data = {
|
|
|
|
shown : this.expanded,
|
|
|
|
state : this.state
|
|
|
|
};
|
|
|
|
|
|
|
|
/* PUBLIC API */
|
|
|
|
this.treeStyleTab.fireCustomEvent(this.treeStyleTab.kEVENT_TYPE_AUTO_HIDE_STATE_CHANGING, this.browser, true, false, data);
|
|
|
|
// for backward compatibility
|
|
|
|
this.treeStyleTab.fireCustomEvent(this.treeStyleTab.kEVENT_TYPE_AUTO_HIDE_STATE_CHANGING.replace(/^nsDOM/, ''), this.browser, true, false, data);
|
|
|
|
},
|
|
|
|
|
|
|
|
fireStateChangeEvent : function AHB_fireStateChangeEvent()
|
|
|
|
{
|
|
|
|
var data = {
|
|
|
|
shown : this.expanded,
|
|
|
|
state : this.state,
|
|
|
|
xOffset : this.XOffset,
|
|
|
|
yOffset : this.YOffset
|
|
|
|
};
|
|
|
|
|
|
|
|
/* PUBLIC API */
|
|
|
|
this.treeStyleTab.fireCustomEvent(this.treeStyleTab.kEVENT_TYPE_AUTO_HIDE_STATE_CHANGE, this.browser, true, false, data);
|
|
|
|
// for backward compatibility
|
|
|
|
this.treeStyleTab.fireCustomEvent(this.treeStyleTab.kEVENT_TYPE_AUTO_HIDE_STATE_CHANGE.replace(/^nsDOM/, ''), this.browser, true, false, data);
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
updateTransparency : function AHB_updateTransparency()
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
sv.updateFloatingTabbar(sv.kTABBAR_UPDATE_BY_APPEARANCE_CHANGE);
|
|
|
|
},
|
|
|
|
|
|
|
|
// event handling
|
|
|
|
|
|
|
|
observe : function AHB_observe(aSubject, aTopic, aData)
|
|
|
|
{
|
|
|
|
switch (aTopic)
|
|
|
|
{
|
|
|
|
case 'nsPref:changed':
|
|
|
|
this.onPrefChange(aData);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
domains : [
|
|
|
|
'extensions.treestyletab.',
|
|
|
|
'browser.fullscreen.autohide',
|
|
|
|
'browser.tabs.closeButtons'
|
|
|
|
],
|
|
|
|
|
|
|
|
onPrefChange : function AHB_onPrefChange(aPrefName)
|
|
|
|
{
|
|
|
|
// ignore after destruction
|
|
|
|
if (!this.window || !this.window.TreeStyleTabService)
|
|
|
|
return;
|
|
|
|
|
|
|
|
var value = prefs.getPref(aPrefName);
|
|
|
|
switch (aPrefName)
|
|
|
|
{
|
|
|
|
case 'extensions.treestyletab.tabbar.autoHide.mode':
|
2015-09-29 03:45:10 +09:00
|
|
|
if (!this.window.TreeStyleTabService.shouldApplyNewPref('tabbar.autoHide.mode'))
|
2015-03-03 18:56:55 +09:00
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
this.browser.setAttribute(this.kMODE+'-normal', value);
|
2015-11-02 12:00:24 +09:00
|
|
|
if (!this.window.fullScreen)
|
|
|
|
this.updateMode(value);
|
2014-09-30 20:09:27 +09:00
|
|
|
return;
|
|
|
|
|
|
|
|
case 'extensions.treestyletab.tabbar.autoHide.mode.fullscreen':
|
2015-09-29 03:45:10 +09:00
|
|
|
if (!this.window.TreeStyleTabService.shouldApplyNewPref('tabbar.autoHide.mode.fullscreen'))
|
2015-03-03 18:56:55 +09:00
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
this.browser.setAttribute(this.kMODE+'-fullscreen', value);
|
2015-11-02 12:00:24 +09:00
|
|
|
if (this.window.fullScreen)
|
|
|
|
this.updateMode(value);
|
2014-09-30 20:09:27 +09:00
|
|
|
return;
|
|
|
|
|
|
|
|
case 'extensions.treestyletab.tabbar.autoShow.mousemove':
|
|
|
|
case 'extensions.treestyletab.tabbar.autoShow.accelKeyDown':
|
|
|
|
case 'extensions.treestyletab.tabbar.autoShow.feedback':
|
|
|
|
if (this.enabled && this.shouldListenMouseMove)
|
|
|
|
this.startListenMouseMove();
|
|
|
|
else
|
|
|
|
this.endListenMouseMove();
|
|
|
|
return;
|
|
|
|
|
|
|
|
case 'extensions.treestyletab.tabbar.autoHide.area':
|
|
|
|
this.sensitiveArea = value;
|
|
|
|
return;
|
|
|
|
|
|
|
|
case 'extensions.treestyletab.tabbar.togglerSize':
|
|
|
|
this.togglerSize = value;
|
2015-03-06 00:42:30 +09:00
|
|
|
{
|
|
|
|
let toggler = this.toggler;
|
|
|
|
toggler.style.minWidth = toggler.style.minHeight = value+'px';
|
|
|
|
if (this.togglerSize <= 0)
|
|
|
|
toggler.setAttribute('collapsed', true);
|
|
|
|
else
|
|
|
|
toggler.removeAttribute('collapsed');
|
|
|
|
}
|
2014-09-30 20:09:27 +09:00
|
|
|
return;
|
|
|
|
|
|
|
|
case 'extensions.treestyletab.tabbar.autoHide.contentAreaScreen.enabled':
|
|
|
|
return this.contentAreaScreenEnabled = value;
|
|
|
|
|
|
|
|
case 'browser.fullscreen.autohide':
|
2015-03-03 18:56:55 +09:00
|
|
|
if (!this.window.fullScreen)
|
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
this.end();
|
|
|
|
this.mode = value ?
|
|
|
|
this.getModeForFullScreen() :
|
|
|
|
this.kMODE_DISABLED ;
|
|
|
|
if (this.mode != this.kMODE_DISABLED)
|
|
|
|
this.start();
|
|
|
|
return;
|
|
|
|
|
|
|
|
case 'browser.tabs.closeButtons':
|
|
|
|
return this.closeButtonsMode = value;
|
|
|
|
|
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
handleEvent : function AHB_handleEvent(aEvent)
|
|
|
|
{
|
|
|
|
switch (aEvent.type)
|
|
|
|
{
|
2016-02-14 22:09:15 +09:00
|
|
|
case 'blur':
|
|
|
|
let activeWindow = Cc['@mozilla.org/focus-manager;1']
|
|
|
|
.getService(Ci.nsIFocusManager)
|
|
|
|
.activeWindow;
|
|
|
|
var inactive = !activeWindow || activeWindow != this.window;
|
|
|
|
if (inactive &&
|
|
|
|
this.showHideReason & this.kSHOWN_AUTOMATICALLY)
|
|
|
|
this.hide(this.kSHOWN_BY_ANY_REASON);
|
|
|
|
return;
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
case 'mousedown':
|
|
|
|
return this.onMouseDown(aEvent);
|
|
|
|
|
|
|
|
case 'mouseup':
|
2015-11-02 15:06:44 +09:00
|
|
|
// Note, we must handle "drop" event also to handle the end
|
|
|
|
// of drag-and-drop of a tab due to the bug:
|
|
|
|
// https://bugzilla.mozilla.org/show_bug.cgi?id=460801
|
|
|
|
case 'dragend':
|
|
|
|
case 'drop':
|
2014-09-30 20:09:27 +09:00
|
|
|
return this.onMouseUp(aEvent);
|
|
|
|
|
|
|
|
case 'mousemove':
|
|
|
|
return this.handleMouseMove(aEvent);
|
|
|
|
|
2015-03-13 16:45:38 +09:00
|
|
|
case 'TabRemotenessChange':
|
2015-03-13 16:56:32 +09:00
|
|
|
return this.notifyStatusToAllTabs(aEvent.target);
|
2015-03-13 16:45:38 +09:00
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
case 'TabOpen':
|
2016-02-13 23:28:22 +09:00
|
|
|
if (utils.getTreePref('tabbar.autoShow.feedback.opened'))
|
|
|
|
this.showForFeedback(aEvent.originalTarget);
|
|
|
|
return;
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
case 'TabClose':
|
2016-02-13 23:28:22 +09:00
|
|
|
if (utils.getTreePref('tabbar.autoShow.feedback.closed'))
|
|
|
|
this.showForFeedback(aEvent.originalTarget);
|
|
|
|
return;
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
case 'TabMove':
|
2016-02-14 03:17:28 +09:00
|
|
|
if (utils.getTreePref('tabbar.autoShow.feedback.moved') &&
|
2016-02-13 23:28:22 +09:00
|
|
|
!this.treeStyleTab.subTreeMovingCount &&
|
2016-01-25 17:00:03 +09:00
|
|
|
!this.treeStyleTab.isTabInternallyMoving(aEvent.originalTarget))
|
2016-02-12 19:57:52 +09:00
|
|
|
this.showForFeedback(aEvent.originalTarget);
|
2014-09-30 20:09:27 +09:00
|
|
|
return;
|
|
|
|
|
|
|
|
case 'select':
|
2016-02-13 23:28:22 +09:00
|
|
|
if (utils.getTreePref('tabbar.autoShow.feedback.selected') &&
|
|
|
|
!this.window.TreeStyleTabService.accelKeyPressed)
|
2016-02-12 19:57:52 +09:00
|
|
|
this.showForFeedback(aEvent.originalTarget);
|
2014-09-30 20:09:27 +09:00
|
|
|
return;
|
|
|
|
|
|
|
|
case 'dragover':
|
|
|
|
return this.onDragOver(aEvent);
|
|
|
|
|
|
|
|
case 'dragleave':
|
|
|
|
return this.onDragLeave(aEvent);
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_TABBAR_POSITION_CHANGING:
|
|
|
|
this.isResizing = false;
|
|
|
|
return;
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_TABBAR_POSITION_CHANGED:
|
|
|
|
if (this.enabled)
|
2016-02-22 14:07:18 +09:00
|
|
|
this.window.setTimeout((function() {
|
|
|
|
this.show(this.kSHOWHIDE_BY_POSITION_CHANGE);
|
|
|
|
this.hide(this.kSHOWHIDE_BY_POSITION_CHANGE);
|
|
|
|
}).bind(this), 0);
|
2014-09-30 20:09:27 +09:00
|
|
|
this.updateTransparency();
|
|
|
|
return;
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_TAB_FOCUS_SWITCHING_KEY_DOWN:
|
|
|
|
return this.onKeyDown(aEvent.detail.sourceEvent);
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_TAB_FOCUS_SWITCHING_START:
|
|
|
|
this.cancelDelayedShowForShortcut();
|
|
|
|
if (this.enabled &&
|
|
|
|
utils.getTreePref('tabbar.autoShow.tabSwitch') &&
|
|
|
|
(
|
|
|
|
aEvent.detail.scrollDown ||
|
|
|
|
aEvent.detail.scrollUp ||
|
|
|
|
( // when you release "shift" key
|
|
|
|
this.expanded &&
|
|
|
|
aEvent.detail.standBy &&
|
|
|
|
aEvent.detail.onlyShiftKey
|
|
|
|
)
|
|
|
|
))
|
|
|
|
this.show(this.kSHOWN_BY_SHORTCUT);
|
|
|
|
return;
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_TAB_FOCUS_SWITCHING_END:
|
|
|
|
this.cancelDelayedShowForShortcut();
|
|
|
|
if (this.enabled)
|
|
|
|
this.hide(this.kSHOWN_BY_SHORTCUT);
|
|
|
|
return;
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_PRINT_PREVIEW_ENTERED:
|
|
|
|
this.hide(this.kSHOWHIDE_BY_END);
|
|
|
|
this.endListenMouseMove();
|
|
|
|
return;
|
|
|
|
|
|
|
|
case this.treeStyleTab.kEVENT_TYPE_PRINT_PREVIEW_EXITED:
|
|
|
|
if (this.enabled && this.shouldListenMouseMove)
|
|
|
|
this.startListenMouseMove();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onMouseDown : function AHB_onMouseDown(aEvent)
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var w = this.window;
|
|
|
|
if (
|
2014-11-11 17:45:12 +09:00
|
|
|
aEvent.target &&
|
2014-09-30 20:09:27 +09:00
|
|
|
!this.isResizing &&
|
2016-02-10 17:42:37 +09:00
|
|
|
utils.evaluateXPath(
|
2014-09-30 20:09:27 +09:00
|
|
|
'ancestor-or-self::*[@class="'+sv.kSPLITTER+'"]',
|
|
|
|
aEvent.originalTarget || aEvent.target,
|
|
|
|
Ci.nsIDOMXPathResult.BOOLEAN_TYPE
|
|
|
|
).booleanValue
|
|
|
|
) {
|
|
|
|
this.isResizing = true;
|
|
|
|
sv.setTabbrowserAttribute(sv.kRESIZING, true);
|
|
|
|
}
|
|
|
|
this.cancelShowHideOnMouseMove();
|
|
|
|
if (
|
|
|
|
this.enabled &&
|
|
|
|
this.expanded &&
|
|
|
|
(
|
2014-11-11 17:45:12 +09:00
|
|
|
!aEvent.originalTarget ||
|
2014-09-30 20:09:27 +09:00
|
|
|
aEvent.originalTarget.ownerDocument != this.document ||
|
|
|
|
!sv.getTabBrowserFromChild(aEvent.originalTarget)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
this.hide(this.kHIDDEN_BY_CLICK);
|
2014-11-11 17:45:12 +09:00
|
|
|
this.lastMouseDownTarget = (
|
|
|
|
aEvent.originalTargetLocalName ||
|
|
|
|
(aEvent.originalTarget && aEvent.originalTarget.localName) ||
|
|
|
|
''
|
|
|
|
);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
onMouseUp : function AHB_onMouseUp(aEvent)
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
2015-11-02 15:18:23 +09:00
|
|
|
if (this.isResizing &&
|
|
|
|
aEvent.originalTarget &&
|
2016-02-10 17:42:37 +09:00
|
|
|
utils.evaluateXPath(
|
2014-09-30 20:09:27 +09:00
|
|
|
'ancestor-or-self::*[@class="'+sv.kSPLITTER+'"]',
|
|
|
|
aEvent.originalTarget,
|
|
|
|
Ci.nsIDOMXPathResult.BOOLEAN_TYPE
|
|
|
|
).booleanValue) {
|
|
|
|
this.isResizing = false;
|
|
|
|
sv.removeTabbrowserAttribute(sv.kRESIZING);
|
|
|
|
}
|
|
|
|
this.cancelShowHideOnMouseMove();
|
|
|
|
this.lastMouseDownTarget = null;
|
|
|
|
},
|
|
|
|
|
|
|
|
handleMouseMove : function AHB_handleMouseMove(aEvent)
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
if (this.isResizing &&
|
2014-11-11 17:45:12 +09:00
|
|
|
/^(scrollbar|thumb|slider|scrollbarbutton)$/i.test(this.lastMouseDownTarget || ''))
|
2014-09-30 20:09:27 +09:00
|
|
|
return true;
|
|
|
|
|
2015-11-02 14:43:27 +09:00
|
|
|
if (!aEvent.shiftKey)
|
2014-09-30 20:09:27 +09:00
|
|
|
this.showHideOnMouseMove(aEvent);
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
|
|
|
onDragOver : function AHB_onDragOver(aEvent)
|
|
|
|
{
|
|
|
|
if (this.expanded)
|
|
|
|
return;
|
|
|
|
|
|
|
|
var position = this.getMousePosition(aEvent);
|
|
|
|
if (!(position & this.MOUSE_POSITION_SENSITIVE))
|
|
|
|
return;
|
|
|
|
|
|
|
|
var draggedTabs = this.window['piro.sakura.ne.jp'].tabsDragUtils.getSelectedTabs(aEvent);
|
|
|
|
if (
|
|
|
|
draggedTabs.length ||
|
|
|
|
this.treeStyleTab.tabbarDNDObserver.retrieveURLsFromDataTransfer(aEvent.dataTransfer).length
|
|
|
|
) {
|
|
|
|
this.show(this.kSHOWN_BY_MOUSEMOVE);
|
|
|
|
|
|
|
|
if (this._autoHideOnDragLeaveTimer) {
|
|
|
|
this.window.clearTimeout(this._autoHideOnDragLeaveTimer);
|
|
|
|
delete this._autoHideOnDragLeaveTimer;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onDragLeave : function AHB_onDragLeave(aEvent)
|
|
|
|
{
|
|
|
|
if (!this.expanded)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (this._autoHideOnDragLeaveTimer)
|
|
|
|
this.window.clearTimeout(this._autoHideOnDragLeaveTimer);
|
|
|
|
|
|
|
|
var position = this.getMousePosition(aEvent);
|
|
|
|
if (position & this.MOUSE_POSITION_SENSITIVE)
|
|
|
|
return;
|
|
|
|
|
2016-02-22 14:07:18 +09:00
|
|
|
this._autoHideOnDragLeaveTimer = this.window.setTimeout((function() {
|
|
|
|
delete this._autoHideOnDragLeaveTimer;
|
|
|
|
this.hide(this.kSHOWN_BY_MOUSEMOVE);
|
|
|
|
}).bind(this), 100);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
onKeyDown : function AHB_onKeyDown(aEvent)
|
|
|
|
{
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
var w = this.window;
|
|
|
|
|
|
|
|
if (this.delayedShowForShortcutDone)
|
|
|
|
this.cancelDelayedShowForShortcut();
|
|
|
|
|
|
|
|
if (
|
|
|
|
sv.getTabs(b).length > 1 &&
|
|
|
|
!aEvent.altKey &&
|
|
|
|
w.TreeStyleTabService.accelKeyPressed
|
|
|
|
) {
|
|
|
|
if (this.enabled &&
|
|
|
|
utils.getTreePref('tabbar.autoShow.accelKeyDown') &&
|
|
|
|
!this.delayedAutoShowTimer &&
|
|
|
|
!this.delayedShowForShortcutTimer) {
|
2016-02-22 14:07:18 +09:00
|
|
|
this.delayedShowForShortcutTimer = w.setTimeout((function() {
|
|
|
|
this.delayedShowForShortcutDone = true;
|
|
|
|
this.show(this.kSHOWN_BY_SHORTCUT);
|
|
|
|
sv = null;
|
|
|
|
b = null;
|
|
|
|
}).bind(this), utils.getTreePref('tabbar.autoShow.accelKeyDown.delay'));
|
2014-09-30 20:09:27 +09:00
|
|
|
this.delayedShowForShortcutDone = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (this.enabled)
|
|
|
|
this.hide(this.kSHOWN_BY_SHORTCUT);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
cancelDelayedShowForShortcut : function AHB_cancelDelayedShowForShortcut()
|
|
|
|
{
|
|
|
|
if (this.delayedShowForShortcutTimer) {
|
|
|
|
this.window.clearTimeout(this.delayedShowForShortcutTimer);
|
|
|
|
this.delayedShowForShortcutTimer = null;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
delayedShowForShortcutTimer : null,
|
|
|
|
delayedShowForShortcutDone : true,
|
2016-02-12 19:57:35 +09:00
|
|
|
|
|
|
|
onTabTitleChanged : function AHB_onTabTitleChanged(aTab)
|
|
|
|
{
|
2016-02-13 23:28:22 +09:00
|
|
|
if (utils.getTreePref('tabbar.autoShow.feedback.titleChanged'))
|
2016-02-13 23:28:39 +09:00
|
|
|
this.showForFeedback(aTab);
|
2016-02-12 19:57:35 +09:00
|
|
|
},
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
init : function AHB_init(aTabBrowser)
|
|
|
|
{
|
|
|
|
this.browser = aTabBrowser;
|
|
|
|
this.document = aTabBrowser.ownerDocument;
|
|
|
|
this.window = this.document.defaultView;
|
|
|
|
this.treeStyleTab = aTabBrowser.treeStyleTab;
|
|
|
|
|
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
|
|
|
|
this.enabled = false;
|
|
|
|
this.mouseMoveListening = false;
|
|
|
|
this.showHideReason = this.kSHOWN_BY_UNKNOWN;
|
|
|
|
this.lastMouseDownTarget = null;
|
|
|
|
this.isResizing = false;
|
|
|
|
|
|
|
|
this.showHideOnMouseMoveTimer = null;
|
|
|
|
this.delayedShowForFeedbackTimer = null;
|
|
|
|
|
2015-03-05 23:13:50 +09:00
|
|
|
b.setAttribute(this.kMODE+'-normal', this.lastNormalMode);
|
|
|
|
b.setAttribute(this.kMODE+'-fullscreen', this.lastFullscreenMode);
|
2014-09-30 20:09:27 +09:00
|
|
|
prefs.addPrefListener(this);
|
|
|
|
this.onPrefChange('browser.tabs.closeButtons');
|
|
|
|
this.onPrefChange('extensions.treestyletab.tabbar.autoHide.area');
|
|
|
|
this.onPrefChange('extensions.treestyletab.tabbar.togglerSize');
|
|
|
|
this.onPrefChange('extensions.treestyletab.tabbar.autoHide.contentAreaScreen.enabled');
|
|
|
|
|
|
|
|
b.mTabContainer.addEventListener('TabOpen', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('mTabContainer,TabOpen,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.mTabContainer.addEventListener('TabClose', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('mTabContainer,TabClose,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.mTabContainer.addEventListener('TabMove', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('mTabContainer,TabMove,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.mTabContainer.addEventListener('select', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('mTabContainer,select,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener(sv.kEVENT_TYPE_TABBAR_POSITION_CHANGING, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,kEVENT_TYPE_TABBAR_POSITION_CHANGING,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener(sv.kEVENT_TYPE_TABBAR_POSITION_CHANGED, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,kEVENT_TYPE_TABBAR_POSITION_CHANGED,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener(sv.kEVENT_TYPE_TAB_FOCUS_SWITCHING_KEY_DOWN, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,kEVENT_TYPE_TAB_FOCUS_SWITCHING_KEY_DOWN,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener(sv.kEVENT_TYPE_TAB_FOCUS_SWITCHING_START, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,kEVENT_TYPE_TAB_FOCUS_SWITCHING_START,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.addEventListener(sv.kEVENT_TYPE_TAB_FOCUS_SWITCHING_END, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('b,kEVENT_TYPE_TAB_FOCUS_SWITCHING_END,AHW,false');
|
2016-02-12 19:57:35 +09:00
|
|
|
|
|
|
|
this.tabsAttributeObserver = new TabAttributesObserver({
|
|
|
|
container : b.mTabContainer,
|
|
|
|
attributes : 'titlechanged',
|
|
|
|
callback : (function(aTab) {
|
|
|
|
if (aTab.getAttribute('titlechanged') == 'true')
|
|
|
|
this.onTabTitleChanged(aTab);
|
|
|
|
}).bind(this)
|
|
|
|
});
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
|
|
|
destroy : function AHB_destroy()
|
|
|
|
{
|
2015-03-03 20:06:14 +09:00
|
|
|
this.end();
|
2014-09-30 20:09:27 +09:00
|
|
|
prefs.removePrefListener(this);
|
|
|
|
|
2016-02-12 19:57:35 +09:00
|
|
|
this.tabsAttributeObserver.destroy();
|
|
|
|
delete this.tabsAttributeObserver;
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
var sv = this.treeStyleTab;
|
|
|
|
var b = this.browser;
|
|
|
|
b.mTabContainer.removeEventListener('TabOpen', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('mTabContainer,TabOpen,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.mTabContainer.removeEventListener('TabClose', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('mTabContainer,TabClose,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.mTabContainer.removeEventListener('TabMove', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('mTabContainer,TabMove,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.mTabContainer.removeEventListener('select', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('mTabContainer,select,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener(sv.kEVENT_TYPE_TABBAR_POSITION_CHANGING, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,kEVENT_TYPE_TABBAR_POSITION_CHANGING,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener(sv.kEVENT_TYPE_TABBAR_POSITION_CHANGED, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,kEVENT_TYPE_TABBAR_POSITION_CHANGED,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener(sv.kEVENT_TYPE_TAB_FOCUS_SWITCHING_KEY_DOWN, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,kEVENT_TYPE_TAB_FOCUS_SWITCHING_KEY_DOWN,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener(sv.kEVENT_TYPE_TAB_FOCUS_SWITCHING_START, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,kEVENT_TYPE_TAB_FOCUS_SWITCHING_START,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
b.removeEventListener(sv.kEVENT_TYPE_TAB_FOCUS_SWITCHING_END, this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('b,kEVENT_TYPE_TAB_FOCUS_SWITCHING_END,AHW,false');
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
delete this.treeStyleTab;
|
|
|
|
delete this.browser;
|
|
|
|
delete this.document;
|
|
|
|
delete this.window;
|
|
|
|
}
|
|
|
|
|
2014-11-11 17:45:12 +09:00
|
|
|
});
|
2014-09-30 20:09:27 +09:00
|
|
|
|
|
|
|
function AutoHideWindow(aWindow)
|
|
|
|
{
|
|
|
|
this.init(aWindow);
|
|
|
|
}
|
2015-03-05 23:59:19 +09:00
|
|
|
AutoHideWindow.prototype = inherit(AutoHideBase.prototype, {
|
2014-09-30 20:09:27 +09:00
|
|
|
get browser()
|
|
|
|
{
|
|
|
|
return this.treeStyleTab.browser;
|
|
|
|
},
|
|
|
|
|
|
|
|
// mode
|
|
|
|
|
2015-03-05 23:59:19 +09:00
|
|
|
get mode() /* PUBLIC API, overrides base class's one */
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
|
|
|
var mode = this.getMode();
|
2015-03-05 23:59:19 +09:00
|
|
|
if (mode == this.kMODE_SHRINK && !this.treeStyleTab.isVertical)
|
|
|
|
return this.kMODE_HIDE;
|
2014-09-30 20:09:27 +09:00
|
|
|
return mode;
|
|
|
|
},
|
|
|
|
|
|
|
|
toggleMode : function AHW_toggleMode(aTabBrowser) /* PUBLIC API */
|
|
|
|
{
|
|
|
|
var b = aTabBrowser || this.browser;
|
|
|
|
var w = this.window;
|
|
|
|
|
|
|
|
var key = 'tabbar.autoHide.mode';
|
|
|
|
var toggleKey = 'tabbar.autoHide.mode.toggle';
|
|
|
|
if (w.fullScreen) {
|
|
|
|
key += '.fullscreen';
|
|
|
|
toggleKey += '.fullscreen';
|
|
|
|
}
|
|
|
|
|
|
|
|
var mode = this.getMode(b) == AutoHideBrowser.prototype.kMODE_DISABLED ?
|
|
|
|
utils.getTreePref(toggleKey) :
|
|
|
|
AutoHideBrowser.prototype.kMODE_DISABLED ;
|
|
|
|
|
2015-09-29 03:45:10 +09:00
|
|
|
utils.setTreePref(key, mode);
|
|
|
|
b.setAttribute(AutoHideBrowser.prototype.kMODE+'-'+(w.fullScreen ? 'fullscreen' : 'normal' ), mode);
|
|
|
|
b.treeStyleTab.autoHide.updateMode(mode);
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
2015-03-05 23:59:19 +09:00
|
|
|
initMode : function AHW_initMode()
|
2015-03-03 19:45:44 +09:00
|
|
|
{
|
2015-03-05 23:59:19 +09:00
|
|
|
// save current state for this window's last state for new (clean) window
|
|
|
|
this.lastNormalMode = this.lastNormalMode;
|
|
|
|
this.lastFullscreenMode = this.lastFullscreenMode;
|
|
|
|
|
2015-03-03 19:45:44 +09:00
|
|
|
var mode = this.treeStyleTab.isFullscreenAutoHide ?
|
2015-03-05 23:13:50 +09:00
|
|
|
this.lastFullscreenMode :
|
|
|
|
this.lastNormalMode;
|
2015-03-03 20:48:49 +09:00
|
|
|
|
2015-03-03 20:10:12 +09:00
|
|
|
if (mode == this.mode)
|
|
|
|
return;
|
|
|
|
|
2015-03-03 19:45:44 +09:00
|
|
|
this.mode = mode;
|
|
|
|
if (mode != this.kMODE_DISABLED)
|
|
|
|
this.updateKeyListeners(this.window);
|
2015-03-03 20:13:35 +09:00
|
|
|
|
2016-02-22 14:07:18 +09:00
|
|
|
this.window.setTimeout((function() {
|
|
|
|
this.window.gBrowser.treeStyleTab.autoHide.updateMode(mode);
|
|
|
|
}).bind(this), 0);
|
2015-03-03 19:45:44 +09:00
|
|
|
},
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
// for shortcuts
|
|
|
|
|
|
|
|
updateKeyListeners : function AHW_updateKeyListeners()
|
|
|
|
{
|
|
|
|
// ignore after destruction
|
|
|
|
if (!this.window || !this.window.TreeStyleTabService)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (
|
|
|
|
this.getMode() &&
|
|
|
|
this.shouldListenKeyEvents
|
|
|
|
) {
|
|
|
|
this.treeStyleTab.startListenKeyEventsFor(this.treeStyleTab.LISTEN_FOR_AUTOHIDE);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
this.treeStyleTab.endListenKeyEventsFor(this.treeStyleTab.LISTEN_FOR_AUTOHIDE);
|
|
|
|
}
|
|
|
|
var w = this.window;
|
|
|
|
w.setTimeout(function() {
|
|
|
|
if (w.windowState != Ci.nsIDOMChromeWindow.STATE_NORMAL)
|
|
|
|
return;
|
|
|
|
var count = 0;
|
|
|
|
var resizeTimer = w.setInterval(function(){
|
|
|
|
if (w.windowState != Ci.nsIDOMChromeWindow.STATE_NORMAL)
|
|
|
|
return w.clearInterval(resizeTimer);
|
|
|
|
|
|
|
|
if (++count > 100 || w.innerHeight > 0) {
|
|
|
|
w.clearInterval(resizeTimer);
|
|
|
|
w.resizeBy(-1,-1);
|
|
|
|
w.resizeBy(1,1);
|
|
|
|
}
|
|
|
|
}, 250);
|
|
|
|
}, 0);
|
|
|
|
},
|
|
|
|
|
|
|
|
get shouldListenKeyEvents()
|
|
|
|
{
|
2016-01-15 15:21:57 +09:00
|
|
|
return (
|
2014-09-30 20:09:27 +09:00
|
|
|
utils.getTreePref('tabbar.autoShow.accelKeyDown') ||
|
|
|
|
utils.getTreePref('tabbar.autoShow.tabSwitch') ||
|
|
|
|
utils.getTreePref('tabbar.autoShow.feedback')
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
2015-03-03 20:01:03 +09:00
|
|
|
init : function AHW_init(aWindow)
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
|
|
|
this.window = aWindow;
|
|
|
|
this.document = aWindow.document;
|
|
|
|
this.treeStyleTab = aWindow.TreeStyleTabService;
|
2015-03-03 20:01:03 +09:00
|
|
|
prefs.addPrefListener(this);
|
2015-03-05 23:59:19 +09:00
|
|
|
this.waitForWindowReady();
|
|
|
|
|
2014-09-30 20:09:27 +09:00
|
|
|
},
|
|
|
|
|
2015-03-03 20:01:03 +09:00
|
|
|
destroy : function AHW_destroy()
|
2014-09-30 20:09:27 +09:00
|
|
|
{
|
2015-03-05 23:59:19 +09:00
|
|
|
this.endWaitForWindowReady();
|
2015-03-03 20:01:03 +09:00
|
|
|
prefs.removePrefListener(this);
|
2014-09-30 20:09:27 +09:00
|
|
|
delete this.treeStyleTab;
|
|
|
|
delete this.document;
|
|
|
|
delete this.window;
|
2015-03-03 20:01:03 +09:00
|
|
|
},
|
|
|
|
|
2015-03-05 23:59:19 +09:00
|
|
|
waitForWindowReady : function AHW_waitForWindowReady()
|
|
|
|
{
|
|
|
|
if (this.waitingForWindowReady)
|
|
|
|
return;
|
|
|
|
|
|
|
|
this.waitingForWindowReady = true;
|
|
|
|
this.window.addEventListener('SSWindowStateReady', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.add('window,SSWindowStateReady,AHW,false');
|
2015-03-05 23:59:19 +09:00
|
|
|
Services.obs.addObserver(this, 'browser-delayed-startup-finished', false);
|
|
|
|
},
|
|
|
|
|
|
|
|
endWaitForWindowReady : function AHW_endWaitForWindowReady()
|
|
|
|
{
|
|
|
|
if (!this.waitingForWindowReady)
|
|
|
|
return;
|
|
|
|
|
|
|
|
this.waitingForWindowReady = false;
|
|
|
|
this.window.removeEventListener('SSWindowStateReady', this, false);
|
2015-11-10 03:00:43 +09:00
|
|
|
ReferenceCounter.remove('window,SSWindowStateReady,AHW,false');
|
2015-03-05 23:59:19 +09:00
|
|
|
Services.obs.removeObserver(this, 'browser-delayed-startup-finished');
|
|
|
|
},
|
|
|
|
|
2015-03-03 23:11:55 +09:00
|
|
|
handleEvent : function AHW_handleEvent(aEvent)
|
|
|
|
{
|
|
|
|
switch (aEvent.type)
|
|
|
|
{
|
|
|
|
case 'SSWindowStateReady':
|
2015-03-05 23:59:19 +09:00
|
|
|
this.endWaitForWindowReady();
|
|
|
|
this.initMode();
|
2015-03-03 23:11:55 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2015-03-05 23:59:19 +09:00
|
|
|
observe : function AHW_observe(aSubject, aTopic, aData)
|
|
|
|
{
|
|
|
|
if (aSubject != this.window)
|
|
|
|
return;
|
|
|
|
|
|
|
|
this.endWaitForWindowReady();
|
|
|
|
this.window.setTimeout(this.initMode.bind(this), 0);
|
|
|
|
},
|
|
|
|
|
2015-03-03 20:01:03 +09:00
|
|
|
domains : [
|
2016-01-15 15:21:57 +09:00
|
|
|
'extensions.treestyletab.'
|
2015-03-03 20:01:03 +09:00
|
|
|
],
|
|
|
|
|
|
|
|
onPrefChange : function AHW_onPrefChange(aPrefName)
|
|
|
|
{
|
|
|
|
var value = prefs.getPref(aPrefName);
|
|
|
|
switch (aPrefName)
|
|
|
|
{
|
|
|
|
case 'extensions.treestyletab.tabbar.autoHide.mode':
|
|
|
|
case 'extensions.treestyletab.tabbar.autoShow.accelKeyDown':
|
|
|
|
case 'extensions.treestyletab.tabbar.autoShow.tabSwitch':
|
|
|
|
case 'extensions.treestyletab.tabbar.autoShow.feedback':
|
|
|
|
this.updateKeyListeners(this.window);
|
|
|
|
|
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
2014-09-30 20:09:27 +09:00
|
|
|
}
|
|
|
|
|
2015-03-03 19:16:27 +09:00
|
|
|
});
|
2014-09-30 20:09:27 +09:00
|
|
|
|