加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
zzzz-VerticalTabbarforFx8.0.uc.js 27.20 KB
一键复制 编辑 原始数据 按行查看 历史
alice0775 提交于 2012-12-11 02:03 . remove e4x
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759
// ==UserScript==
// @name zzzz-VerticalTabbarforFx8.0.uc.js
// @namespace http://space.geocities.yahoo.co.jp/gl/alice0775
// @description CSS入れ替えまくりバージョン
// @include main
// @compatibility Nightly9.0a1
// @author Alice0775
// @note デフォルトテーマ
// @version 2012/12/08 22:30 Bug 788290 Bug 788293 Remove E4X
// ==/UserScript==
// @version 2012/08/12 22:30 Bug 761723 implement toString of function objects by saving source
// @version 2011/10/07 scrollbar position
// @version 2011/09/16 14:00 Sidebar伸縮時
// @version 2011/09/16 13:30 resize時の実行方法
// @version 2011/09/16 resize時の実行方法
// @version 2011/09/13 Menu bar非表示の時
// @version 2011/08/20 デタッチ中タブがシフトしてしまう
// @version 2011/08/16 pinnedタブ とりあえず見かけは普通のタブと同じ(ただしボーダのみハイライト))
// @version 2011/08/15 Nightly8.0a1
// @version 2011/04/15 tryserver Bug 455694
// @version 2011/04/22 13:00 Bug 648368 - Add Aurora branding, switch default branding from "Minefield" to "Nightly"
// @version 2010/07/22 12:00 tab context
// @version 2010/06/24 23:00 ウインドサイズがおかしくなるので rendering stop/startは止め
// @version 2010/05/04 08:00 選択タブ色
// @version 2010/04/28 08:00 Bug 457187 - Make the tabs toolbar customizable
// @version 2010/04/06 18:00 不要なメニュー
// @version 2010/03/24 18:00 tab style
// @version 2010/03/24 00:00 ポップアップの時非表示
// @version 2010/03/22 01:10 D&D
// @version 2010/03/21 18:50 フルスクリーンの時タブバー表示/非表示
// @version 2010/03/20 21:00 マージン
// @version 2010/03/20 15:10 タブのデタッチ範囲
// @version 2010/03/20 15:10 プリントプレビュー時は非表示
// @version 2010/03/20 14:40 splitterリサイズしたときにタブ幅追従するように
// @version 2010/03/20 14:10 grippy追加
// @version 2010/03/20 09:00 D&D
// @version 2010/03/20 07:50 フルスクリーンの時タブバー非表示およびツールバーの状態に応じて大きさの調整
// @version 2010/03/20 07:35 2010/03/20 07:30のリグレッション:リサイズ時にタブが見えるように
// @version 2010/03/20 07:30 サイドバー開いたとき
// @version 2010/03/20 07:00 リサイズ時にタブが見えるように
// @version 2010/03/15 00:00 Minefield/3.7a3pre Bug 347930 - Tab strip should be a toolbar instead
// @license The MIT License
if ("_clearDragTransforms" in gBrowser.tabContainer) {
function zzzz_VerticalTabbar(){
// Tab Mix plus
if("tablib" in window) return;
// Tree Style tab
if('TreeStyleTabService' in window) return;
if (!gPrefService)
gPrefService = Components.classes["@mozilla.org/preferences-service;1"]
.getService(Components.interfaces.nsIPrefBranch);
// -- config --
var TABBARWIDTH = 80;
var TABBARLEFTMERGINE = 1;
gPrefService.setIntPref("browser.tabs.tabMaxWidth", 250);
gPrefService.setIntPref("browser.tabs.tabMinWidth", 0);
gPrefService.setIntPref("browser.tabs.tabClipWidth", 40);
// -- config --
var TOOLBARBUTTON_AS_TAB = true;
// xxx Bug 380960 - Implement closing tabs animation
gPrefService.setBoolPref("browser.tabs.animate", false);
gPrefService.setBoolPref("browser.tabs.autoHide", false);
//window['piro.sakura.ne.jp'].stopRendering.stop();
for (var i = 0; i < gBrowser.tabs.length; i++) {
gBrowser.tabs[i].removeAttribute("maxwidth");
}
/*タブ縦置きCSS適用*/
var style = ' \
@namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul); \
\
/*不要なメニュー*/ \
menuitem[command="cmd_ToggleTabsOnTop"], \
menuitem[command="cmd_ToggleTabsOnTop"] + menuseparator \
{ \
visibility:collapse; \
} \
\
#TabsToolbar \
{ \
position:fixed; \
left: 0px; \
right: 0px; \
/*top: 80px; \
bottom: 20px;*/ \
width: {TABBARWIDTH}px; \
overflow-x: hidden; \
overflow-y: hidden; \
} \
\
/*xxx Bug 574434*/ \
#navigator-toolbox[tabsontop="true"] > #toolbar-menubar[autohide="true"] ~ #nav-bar \
{ \
-moz-padding-start: 10em !important; \
} \
#navigator-toolbox[tabsontop="true"] > #toolbar-menubar[autohide="true"] ~ #TabsToolbar \
{ \
-moz-padding-start: 0em !important; \
} \
\
#tabbrowser-tabs > hbox \
{ \
position:fixed; \
left: 0px; \
right: 0px; \
/*top: 80px; \
bottom: 20px;*/ \
width: 5px; \
overflow-x: hidden; \
overflow-y: hidden; \
} \
\
#tabbrowser-tabs \
{ \
/*height: 100% !important;*/ \
width: 100% !important; \
-moz-box-orient: vertical !important; \
/*should delete orient="horizontal"*/ \
overflow-x:hidden; \
} \
\
#tabbrowser-tabs > arrowscrollbox \
{ \
-moz-box-orient: vertical !important; \
/*should delete orient="horizontal"*/ \
} \
\
#tabbrowser-tabs > arrowscrollbox > scrollbox \
{ \
overflow-y: auto; \
-moz-box-orient: vertical !important; \
direction: rtl; /*scroll bar position*/ \
} \
\
#tabbrowser-tabs > arrowscrollbox > scrollbox > box \
{ \
-moz-box-orient: vertical !important; \
direction: ltr; /*scroll bar position*/ \
} \
\
#tabbrowser-tabs > arrowscrollbox > .scrollbutton-up, \
#tabbrowser-tabs > arrowscrollbox > .scrollbutton-down \
{ \
visibility:collapse; \
} \
\
.tabbrowser-tab[pinned], \
.tabbrowser-tab:not([pinned]) \
{ \
min-width: 100% !important; \
max-width: 100% !important; \
} \
\
/*タブのアニメーションoff*/ \
.tabbrowser-tabs[drag=detach] > .tabbrowser-tab[dragged]:not(:only-child) { \
min-width: 100% !important; \
max-width: 100% !important; \
-moz-transition: max-width 0ms ease-out !important; \
} \
\
.tabbrowser-tabs[drag=move] > .tabbrowser-tab[fadein]:not([dragged]) { \
-moz-transition: -moz-transform 0ms ease-out !important; \
} \
\
.tabbrowser-tabs[drag=finish] > .tabbrowser-tab[dragged][fadein] { \
-moz-transition: -moz-transform 0ms ease-out !important; \
} \
\
\
/*フルスクリーン*/ \
#verticalTabToolBox[moz-collapsed="true"], \
#vtb_splitter[moz-collapsed="true"] \
{ \
visibility:collapse; \
} \
\
\
/*ポップアップの時*/ \
#main-window[chromehidden~="extrachrome"] #TabsToolbar, \
#main-window[chromehidden~="extrachrome"] #verticalTabToolBox, \
#main-window[chromehidden~="extrachrome"] #vtb_splitter \
{ \
visibility: collapse; \
} \
\
/*プリントプレビュー*/ \
#print-preview-toolbar[printpreview="true"] ~ #browser #verticalTabToolBox, \
#print-preview-toolbar[printpreview="true"] ~ #browser #vtb_splitter \
{ \
visibility:collapse; \
} \
\
/*default theme要調整*/ \
/* Fx3.7a2*/ \
toolbarbutton:not([id="back-button"]):not([id="forward-button"]) \
{ \
margin-top:0px; //? \
} \
\
.tabbrowser-tab, \
.tabbrowser-tab:not([selected="true"]) \
{ \
-moz-appearance: none !important; \
min-height: 24px; \
max-height: 24px; \
margin: 0 !important; \
padding: 1px 0 2px 0 !important; \
\
border: 1px solid ThreeDShadow; \
border-bottom: 1px solid transparent; \
\
-moz-border-radius-topleft : 0 !important; \
-moz-border-radius-topright : 0 !important; \
-moz-border-radius-bottomleft : 0 !important; \
-moz-border-radius-bottomright : 0 !important; \
\
/*background-image: url("chrome://browser/skin/tabbrowser/tab-bkgnd.png");*/ \
} \
\
.tabbrowser-tab:last-child, \
.tabbrowser-tab:not([selected="true"]):last-child \
{ \
border-bottom: 1px solid ThreeDShadow; \
} \
\
.tabbrowser-tab[selected="true"] \
{ \
padding: 0px 0 2px 0 !important; \
/*background-image: url("chrome://browser/skin/tabbrowser/tab-active-bkgnd.png");*/ \
/*background-color: ThreeDHighlight;*/ \
} \
\
.tabbrowser-tab[pinned] \
{ \
border-color: ThreeDHighlight; \
} \
\
.tabbrowser-tab:not([selected="true"]):hover \
{ \
background-color: ThreeDHighlight; \
} \
\
.tabbrowser-tab[selected="true"]:hover \
{ \
background-color: ThreeDHighlight; \
} \
\
\
\
#TabsToolbar > toolbarbutton[collapsed="true"], \
#TabsToolbar > toolbarbutton[hidden="true"] \
{ \
display:none; \
} \
#TabsToolbar > toolbarbutton \
{ \
height: 18px; \
} \
\
#TabsToolbar > toolbarbutton:hover \
{ \
height: 18px; \
} \
\
';
if (TOOLBARBUTTON_AS_TAB) {
style += ' \
#TabsToolbar > toolbarbutton:not([collapsed="true"]), \
#TabsToolbar > toolbarbutton:not([hidden="true"]) \
{ \
width:100% !important; \
} \
';
}
style = style.replace(/\s+/g, " ")
.replace("{TABBARWIDTH+TABBARLEFTMERGINE}", TABBARWIDTH + TABBARLEFTMERGINE)
.replace(/\{TABBARWIDTH\}/g, TABBARWIDTH);
var sspi = document.createProcessingInstruction(
'xml-stylesheet',
'type="text/css" href="data:text/css,' + encodeURIComponent(style) + '"'
);
document.insertBefore(sspi, document.documentElement);
sspi.getAttribute = function(name) {
return document.documentElement.getAttribute(name);
};
style = ' \
@namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul); \
/* 縦のスクロールバーを細く&背景着色 */ \
#tabbrowser-tabs > arrowscrollbox * scrollbar[orient="vertical"], \
#tabbrowser-tabs > arrowscrollbox * scrollbar[orient="vertical"] * { \
min-width: 12px!important; \
max-width: 12px!important; \
} \
'.replace(/\s+/g, " ");
var uri = "data:text/css;charset=utf-8," + encodeURIComponent(style);
Cc["@mozilla.org/content/style-sheet-service;1"]
.getService(Ci.nsIStyleSheetService)
.loadAndRegisterSheet(Services.io.newURI(uri, null, null), Ci.nsIStyleSheetService.AGENT_SHEET);
var tabsToolbar = document.getElementById('TabsToolbar');
var tabbrowsertabs = gBrowser.mTabContainer;
var indicatorbox = gBrowser.tabContainer._tabDropIndicator.parentNode;
var arrowscrollbox = gBrowser.tabContainer.mTabstrip;
var contents = document.getElementById('content');
var sidebarbox = document.getElementById('sidebar-box');
var sidebarsplitter = document.getElementById('sidebar-splitter');
var navigatortoolbox = document.getElementById('navigator-toolbox');
var browserbottombox = document.getElementById('browser-bottombox');
//prepare for toolbox
var verticalTabToolBox = navigatortoolbox.cloneNode(false);
verticalTabToolBox.setAttribute("id","verticalTabToolBox");
//prepare for splitter
var vtbSplitter = document.createElement("splitter");
vtbSplitter.setAttribute("id", "vtb_splitter");
var grippy = document.createElement("grippy");
vtbSplitter.appendChild(grippy);
document.getElementById("browser").insertBefore(
verticalTabToolBox, document.getElementById("appcontent")
);
document.getElementById("browser").insertBefore(
vtbSplitter, document.getElementById("appcontent")
);
vtbSplitter.setAttribute('collapse', 'before');
tabbrowsertabs.setAttribute('overflow', true);
tabbrowsertabs.removeAttribute('orient');
arrowscrollbox.removeAttribute('orient');
//context menu
tabbrowsertabs.setAttribute("context", "tabContextMenu");
//pinned
gBrowser.tabContainer._positionPinnedTabs = function() {
/*何もしない*/
};
//フルスクリーン
var func = FullScreen.mouseoverToggle.toString();
func = func.replace(
/\{/,
' \
$& \
if (!aShow) { \
verticalTabToolBox.setAttribute("moz-collapsed", "true"); \
vtbSplitter.setAttribute("moz-collapsed", "true"); \
document.getElementById("TabsToolbar").setAttribute("moz-collapsed", "true"); \
} else { \
verticalTabToolBox.removeAttribute("moz-collapsed"); \
vtbSplitter.removeAttribute("moz-collapsed"); \
document.getElementById("TabsToolbar").removeAttribute("moz-collapsed"); \
} \
'
);
eval("FullScreen.mouseoverToggle = " + func);
//sidebar
document.getElementById("sidebar-splitter").setAttribute("resizeafter", "flex");
//xxx context fx4.0b2pre
gBrowser.tabContainer.addEventListener('TabOpen', tabOpened, false);
gBrowser.tabContainer.addEventListener('SSTabRestored', tabOpened, false);
//起動時のタブ状態復元
tabinit(0);
function tabinit(i){
if(i < gBrowser.mTabs.length){
var aTab = gBrowser.mTabs[i];
aTab.setAttribute("context", "tabContextMenu");
}
}
function tabOpened(event) {
var aTab = event.target;
aTab.setAttribute("context", "tabContextMenu");
}
gBrowser.tabContainer.VerticalTabbarTabtimer = null;
gBrowser.tabContainer.VerticalTabbarTabscroll = true;
gBrowser.tabContainer.VerticalTabbarOnDragOver = function(event) {
var tabs = this.childNodes;
if (tabs.length < 1)
return false;
if (!this.VerticalTabbarTabscroll)
return false;
this.VerticalTabbarTabscroll = false;
this.VerticalTabbarTabtimer = setTimeout(function(self){self.VerticalTabbarTabscroll = true;}, 400, this);
var y;
var box = this.mTabstrip;
if (box.boxObject.screenY + 20 > event.screenY) {
y = box.boxObject.screenY - 20;
} else if (box.boxObject.screenY + box.boxObject.height - 13 < event.screenY) {
y = box.boxObject.screenY + box.boxObject.height + 20;
} else {
return false;
}
var tab = null;
for (var i = 0; i < tabs.length; i++) {
if (y >= tabs[i].boxObject.screenY &&
y <= tabs[i].boxObject.screenY + tabs[i].boxObject.height){
tab = tabs[i];
break;
}
}
if (!tab)
if (y <= tabs[0].boxObject.screenY){
tab = tabs[0]
} else if (y > tabs[tabs.length - 1].boxObject.screenY
+ tabs[tabs.length - 1].boxObject.height){
tab = tabs[tabs.length - 1]
}
try{
var mShell = Components.classes["@mozilla.org/inspector/flasher;1"]
.createInstance(Components.interfaces.inIFlasher);
mShell.scrollElementIntoView(tab);
return true;
}catch(e){}
};
//D&Dの調整
var func = gBrowser.tabContainer._handleTabDrag.toString();
/*
func = func.replace(
'{',
'{if ("userChrome_js" in window) userChrome_js.debug("_handleTabDrag");'
)
*/
func = func.replace(
'draggedTab.style.MozTransform = "translate(" + transformX + "px)";',
'draggedTab.style.MozTransform = "";'
)
func = func.replace(
'tab.style.MozTransform = "translate(" + tabWidth + "px)";',
'tab.style.MozTransform = "";'
)
func = func.replace(
'tab.style.MozTransform = "translate(" + -tabWidth + "px)";',
'tab.style.MozTransform = "";'
)
func = func.replace(
'tab.style.MozTransform = "translate(" + - tabWidth + "px)";',
'tab.style.MozTransform = "";'
)
gBrowser.tabContainer._handleTabDrag = new Function(
func.match(/\(([^)]*)/)[1],
func.replace(/[^{]*/, '').replace(/^{/, '').replace(/}$/, '')
);
/*
func = gBrowser.tabContainer._slideTab.toString();
func = func.replace(
'let destination = "translate(" + displacement + "px)";',
'let destination = "translate(0px)";'
)
gBrowser.tabContainer._slideTab = new Function(
func.match(/\(([^)]*)/)[1],
func.replace(/[^{]*/, '').replace(/^{/, '').replace(/}$/, '')
);
*/
func = gBrowser.tabContainer._handleTabDrop.toString();
func = func.replace(
'{',
'{if ("userChrome_js" in window) userChrome_js.debug("_handleTabDrop");'
)
gBrowser.tabContainer._handleTabDrop = new Function(
func.match(/\(([^)]*)/)[1],
func.replace(/[^{]*/, '').replace(/^{/, '').replace(/}$/, '')
);
gBrowser.tabContainer._positionDropIndicator = function _positionDropIndicator(event, scrollOnly) {
var effects = event.dataTransfer ? this._setEffectAllowedForDataTransfer(event) : "";
//debug("effects "+ effects);
var ind = this._tabDropIndicator;
if (effects == "none") {
ind.collapsed = true;
return;
}
event.preventDefault();
event.stopPropagation();
var ind = this._tabDropIndicator;
var tabStrip = this.mTabstrip;
// autoscroll the tab strip if we drag over
//xxx Bug 481904
if (this.VerticalTabbarOnDragOver(event)) {
//return;
}
//debug("scrollOnly " + scrollOnly);
/*
if (scrollOnly) {
ind.collapsed = true;
return;
}
*/
if (effects == "link") {
let tab = this._getDragTargetTab(event);
if (tab) {
if (!this._dragTime)
this._dragTime = Date.now();
if (Date.now() >= this._dragTime + this._dragOverDelay)
this.selectedItem = tab;
ind.collapsed = true;
return;
}
}
var newIndex = this._getDropIndex(event);
//debug("newIndex "+ newIndex);
if (newIndex == null)
return;
var scrollRect = tabStrip.scrollClientRect;
var rect = this.getBoundingClientRect();
var minMargin = scrollRect.left - rect.left;
var maxMargin = Math.min(minMargin + scrollRect.width,
scrollRect.right);
ind.collapsed = false;
var newMargin = 8;
ind.style.MozTransform = "translate(" + Math.round(newMargin) + "px)";
ind.style.MozMarginStart = (-ind.clientWidth) + "px";
if (newIndex < this.childNodes.length)
var _top = (-ind.clientHeight*0.3)
+ (this.childNodes[newIndex].boxObject.screenY
- this.boxObject.screenY);
else
var _top = (-ind.clientHeight*0.3)
+ (this.childNodes[newIndex - 1].boxObject.screenY
+ this.childNodes[newIndex - 1].boxObject.height
- this.boxObject.screenY);
//if (this.boxObject.height > _top + ind.clientHeight)
// ind.style.MozMarginStart = -1000;
ind.style.marginTop = _top + 'px';
ind.removeAttribute('collapsed');
indicatorbox.style.width = '5px';
};
gBrowser.tabContainer._getDragTargetTab = function _getDragTargetTab(event) {
let tab = event.target.localName == "tab" ? event.target : null;
if (tab &&
(event.type == "drop" || event.type == "dragover") &&
event.dataTransfer.dropEffect == "link") {
let boxObject = tab.boxObject;
if (event.screenY < boxObject.screenY + boxObject.height * .25 ||
event.screenY > boxObject.screenY + boxObject.height * .75)
return null;
}
return tab;
};
gBrowser.tabContainer._getDropIndex = function _getDropIndex(event, draggedTab) {
var tabs = this.childNodes;
var index = tabs.length;
for (let i = 0; i < tabs.length; i++){
if (event.screenY >= tabs[i].boxObject.screenY &&
event.screenY <= tabs[i].boxObject.screenY + tabs[i].boxObject.height / 2) {
index = i;
}
if (event.screenY > tabs[i].boxObject.screenY + tabs[i].boxObject.height / 2 &&
event.screenY <= tabs[i].boxObject.screenY + tabs[i].boxObject.height) {
index = i + 1;
}
}
//userChrome_js.debug(index);
return index;
}
if (!("bug489729_onDragOverTimer" in gBrowser.tabContainer)) {
//ここからはタブのデタッチ
gBrowser.tabContainer._onDragEnd = function(event) {
// Note: while this case is correctly handled here, this event
// isn't dispatched when the tab is moved within the tabstrip,
// see bug 460801.
// * mozUserCancelled = the user pressed ESC to cancel the drag
var dt = event.dataTransfer;
if (dt.mozUserCancelled || dt.dropEffect != "none")
return;
// Disable detach within the browser toolbox
var eX = event.screenX;
var wX = window.screenX;
var eY = event.screenY;
var wY = window.screenY;
var tabbar = this.mTabstrip.boxObject;
var contentArea = document.getElementById("appcontent").boxObject;
// xxx Bug 493978 - Disable tab-detach when the tab is dropped very close to the tabbar
const TLERANCE = 15; //15x is enough.
var side = {
"TOP" :contentArea.screenY,
"BOTTOM":contentArea.screenY + contentArea.height,
"LEFT" :contentArea.screenX,
"RIGHT" :contentArea.screenX + contentArea.width
}
if (tabbar.screenY + tabbar.height <= contentArea.screenY)
side["TOP"] += TLERANCE;
else if (tabbar.screenY >= contentArea.screenY + contentArea.height)
side["BOTTOM"] -= TLERANCE;
else if (tabbar.screenX + tabbar.width <= contentArea.screenX)
side["LEFT"] += TLERANCE;
else
side["RIGHT"] -= TLERANCE;
//debug(side["TOP"] + " " + side["BOTTOM"] + " " + side["LEFT"] + " " + side["RIGHT"])
// check if the drop point is not (within contentArea or outside the window)
// eq. dropped too close to the tabbar or toolbox and statusbar(incl. findbar)
if (!(side["TOP"] < eY && eY < side["BOTTOM"] &&
side["LEFT"] < eX && eX < side["RIGHT"] ||
eY < wY || wY + window.outerHeight < eY ||
eX < wX || wX + window.outerWidth < eX )) {
return;
}
let TAB_DROP_TYPE = 'application/x-moz-tabbrowser-tab';
var draggedTab = dt.mozGetDataAt(TAB_DROP_TYPE, 0);
this.tabbrowser.replaceTabWithWindow(draggedTab);
event.stopPropagation();
}
gBrowser.tabContainer.addEventListener("dragend", gBrowser.tabContainer._onDragEnd, true);
}
//ここからは, ツールバーの表示非表示によるタブーバーの位置, 大きさの調整
verticalTabToolBox.style.width = TABBARWIDTH + TABBARLEFTMERGINE + "px";
window.addEventListener('resize', VerticalTabbarOnresized, false);
var skipResize = null;
var resizeTimer = null;
function VerticalTabbarOnresized() {
if (resizeTimer)
clearTimeout(resizeTimer);
resizeTimer = setTimeout(function() {
resized();
skipResize = null;
}, 250);
setTimeout(function() {
skipResize = null;
}, 100);
if (!!skipResize)
return;
resized();
function resized() {
skipResize = true;
tabbrowsertabs.setAttribute('overflow', true);
//幅調整
tabsToolbar.collapsed = vtbSplitter.getAttribute('state') == 'collapsed';
tabsToolbar.style.width = verticalTabToolBox.boxObject.width - TABBARLEFTMERGINE + "px";
//高さ調整
var toolbuttonH = 0;
if (!TOOLBARBUTTON_AS_TAB) {
var newtabbutton = document.getElementById("new-tab-button");
if (newtabbutton)
toolbuttonH = newtabbutton.boxObject.height;
var alltabsbutton = document.getElementById("alltabs-button");
if (alltabsbutton)
toolbuttonH = Math.max(toolbuttonH, alltabsbutton.boxObject.height);
} else {
var toolbutton = tabbrowsertabs.nextSibling;
while (toolbutton) {
if (toolbutton.localName == "toolbarbutton" ||
toolbutton.localName == "toolbarpaletteitem") {
toolbuttonH += toolbutton.boxObject.height;
}
toolbutton = toolbutton.nextSibling;
}
}
tabsToolbar.style.left = sidebarbox.boxObject.width + sidebarsplitter.boxObject.width + "px";
tabsToolbar.style.top = gBrowser.boxObject.y + "px";
tabsToolbar.style.bottom = browserbottombox.boxObject.height + "px";
tabbrowsertabs.style.height = tabsToolbar.boxObject.height - toolbuttonH + "px";
indicatorbox.style.left = sidebarbox.boxObject.width + sidebarsplitter.boxObject.width + "px";
indicatorbox.style.top = -5 + gBrowser.boxObject.y + "px";
indicatorbox.style.bottom = browserbottombox.boxObject.height + "px";
//選択タブが見えるように
ensureVisibleElement(gBrowser.selectedTab);
}
}
VerticalTabbarOnresized();
setTimeout(function(){VerticalTabbarOnresized();}, 250);
/*Print Preview を 抜けたとき*/
zzzz_VerticalTabbar.VerticalTabbarOnresized = VerticalTabbarOnresized;
func = PrintPreviewListener.onExit.toString();
func = func.replace(
/}$/,
'zzzz_VerticalTabbar.VerticalTabbarOnresized(); }'
);
PrintPreviewListener.onExit = new Function(
func.match(/\(([^)]*)/)[1],
func.replace(/[^{]*/, '').replace(/^{/, '').replace(/}$/, '')
);
//window['piro.sakura.ne.jp'].stopRendering.start();
//ここからは, 現在のタブがいつも見えるようにスクロールさせる
gBrowser.tabContainer.addEventListener('TabSelect', ensureVisible, false);
function ensureVisible(event){
if (event.target.selected)
ensureVisibleElement(event.target);
}
function ensureVisibleElement(aTab){
try{
var mShell = Components.classes["@mozilla.org/inspector/flasher;1"]
.createInstance(Components.interfaces.inIFlasher);
mShell.scrollElementIntoView(aTab);
}catch(e){}
}
gBrowser.tabContainer.mTabstrip.ensureElementIsVisible = ensureVisibleElement;
//デバッグ用
function debug(aMsg){
Cc["@mozilla.org/consoleservice;1"]
.getService(Ci.nsIConsoleService)
.logStringMessage(aMsg);
}
}
zzzz_VerticalTabbar();
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化