Initial commit 2
This commit is contained in:
parent
e20a999b2c
commit
e7b1999994
16 changed files with 3235 additions and 1 deletions
BIN
.assets/screenshot.png
Normal file
BIN
.assets/screenshot.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 14 KiB |
34
README.md
34
README.md
|
@ -1,3 +1,35 @@
|
|||
# MSFX
|
||||
Fork of [the MSFX Firefox userChrome](https://github.com/WinClassic/MSFX).
|
||||
![Screenshot of MSFX](.assets/screenshot.png)
|
||||
|
||||
Fork of the MSFX Firefox userChrome
|
||||
## Changes
|
||||
* Uses normal [firefox-scripts](https://github.com/xiaoxiaoflood/firefox-scripts) instead of a stripped down version for greater userscript compatibility
|
||||
* More accurate styles in some places
|
||||
* Bookmarks bar folder menus
|
||||
* All tabs button
|
||||
* Replaced with overflow arrows icon
|
||||
* Scrollbars forced to light theme
|
||||
* Selected address bar forced to light theme
|
||||
* Resize grabber no longer appears when maximized
|
||||
* Autoplay Pending indicator icon replaced
|
||||
* Pinned tabs no longer have extra padding
|
||||
* Internet status bar widget is its own component
|
||||
* Empty boxes have been removed in favor of putting extensions on the status bar
|
||||
* Address bar is no longer forced to the Address toolbar when opening a new window
|
||||
|
||||
## Installation
|
||||
* Set the following keys in `about:config`:
|
||||
* `svg.context-properties.content.enabled` to `true`
|
||||
* `ui.prefersReducedMotion` to `1`
|
||||
* `browser.display.windows.non_native_menus` to `0`
|
||||
* Follow [firefox-scripts](https://github.com/xiaoxiaoflood/firefox-scripts) installation.
|
||||
* Install [Status Bar userscript](https://raw.githubusercontent.com/xiaoxiaoflood/firefox-scripts/master/chrome/status-bar.uc.js).
|
||||
* Merge `chrome` folder from the repo into your profile's `chrome` folder.
|
||||
|
||||
## Recommendations
|
||||
* [Extensions Options Menu](https://raw.githubusercontent.com/xiaoxiaoflood/firefox-scripts/master/chrome/extensionOptionsMenu.uc.js)
|
||||
* More lightweight than the stock extensions menu, which is disabled by the theme anyways
|
||||
* [userChromeJS Manager](https://raw.githubusercontent.com/xiaoxiaoflood/firefox-scripts/master/chrome/rebuild_userChrome.uc.js)
|
||||
* [Save File to](https://raw.githubusercontent.com/xiaoxiaoflood/firefox-scripts/master/extensions/savefileto/savefileto.xpi)
|
||||
* **Requires extensions support in firefox-scripts**
|
||||
* "Replaces" save dialog for hybrid classic theme setup with Windhawk until investigation is done to fix the save dialog on classic enabled programs.
|
||||
|
|
82
chrome/activity_throbber.uc.js
Normal file
82
chrome/activity_throbber.uc.js
Normal file
|
@ -0,0 +1,82 @@
|
|||
// 'Activity throbber' script for Firefox 60+ by Aris
|
||||
|
||||
Components.utils.import("resource:///modules/CustomizableUI.jsm");
|
||||
var { Services } = Components.utils.import(
|
||||
"resource://gre/modules/Services.jsm",
|
||||
{}
|
||||
);
|
||||
var sss = Components.classes[
|
||||
"@mozilla.org/content/style-sheet-service;1"
|
||||
].getService(Components.interfaces.nsIStyleSheetService);
|
||||
|
||||
var at_label = "Activity Throbber";
|
||||
|
||||
var ActivityThrobber = {
|
||||
init: function () {
|
||||
try {
|
||||
document.addEventListener("TabAttrModified", _ActivityThrobber, false);
|
||||
document.addEventListener("TabSelect", _ActivityThrobber, false);
|
||||
document.addEventListener("TabOpen", _ActivityThrobber, false);
|
||||
document.addEventListener("TabClose", _ActivityThrobber, false);
|
||||
document.addEventListener("load", _ActivityThrobber, false);
|
||||
|
||||
// add or remove 'busy' tab from activity item
|
||||
function _ActivityThrobber() {
|
||||
if (gBrowser.selectedTab.hasAttribute("busy")) {
|
||||
document
|
||||
.querySelector("#activity_throbber")
|
||||
.setAttribute("busy", "true");
|
||||
} else
|
||||
document.querySelector("#activity_throbber").removeAttribute("busy");
|
||||
}
|
||||
|
||||
// create a default toolbar button
|
||||
CustomizableUI.createWidget({
|
||||
id: "activity_throbber", // button id
|
||||
defaultArea: CustomizableUI.AREA_NAVBAR,
|
||||
removable: true,
|
||||
label: at_label, // button title
|
||||
tooltiptext: at_label, // tooltip title
|
||||
onCreated: function (button) {
|
||||
return button;
|
||||
},
|
||||
});
|
||||
|
||||
// style button icon / embedded non-animated icon, because there is no image for then inside Fx anymore
|
||||
var uri = Services.io.newURI(
|
||||
"data:text/css;charset=utf-8," +
|
||||
encodeURIComponent(
|
||||
`#activity_throbber {
|
||||
-moz-appearance: none !important;
|
||||
list-style-image: url();
|
||||
width: 16px !important;
|
||||
height: 16px !important;
|
||||
}
|
||||
#activity_throbber *,
|
||||
#activity_throbber:hover * {
|
||||
-moz-appearance: none !important;
|
||||
opacity: 1.0 !important;
|
||||
box-shadow: unset !important;
|
||||
background: unset !important;
|
||||
}
|
||||
#activity_throbber[busy] {
|
||||
list-style-image: url("chrome://global/skin/media/throbber.png");
|
||||
}
|
||||
`
|
||||
),
|
||||
null,
|
||||
null
|
||||
);
|
||||
|
||||
// remove old style sheet, before registering the new one
|
||||
if (sss.sheetRegistered(uri, sss.AGENT_SHEET)) {
|
||||
sss.unregisterSheet(uri, sss.AGENT_SHEET);
|
||||
}
|
||||
sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
|
||||
} catch (e) {
|
||||
Components.utils.reportError(e);
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
document.addEventListener("DOMContentLoaded", ActivityThrobber.init(), false);
|
218
chrome/additional_top_toolbars.uc.js
Normal file
218
chrome/additional_top_toolbars.uc.js
Normal file
|
@ -0,0 +1,218 @@
|
|||
// 'Additional top toolbars' script for Firefox 60+ by Aris
|
||||
// - "number_of_additional_top_toolbars": set the amount of additional top toolbar
|
||||
// - "tb_label": set a toolbar name
|
||||
// - use toolbar[id^="additional_top_toolbar"] {...} to affect all toolbars at once in CSS
|
||||
|
||||
// [!] Fix for WebExtensions with own windows by 黒仪大螃蟹 (for 1-N scripts)
|
||||
//
|
||||
// workaround on Fx 71 to save/restore toolbar visibility
|
||||
// creating an observer array always fails, so observers are created manually atm.
|
||||
|
||||
Components.utils.import("resource:///modules/CustomizableUI.jsm");
|
||||
var { Services } = Components.utils.import(
|
||||
"resource://gre/modules/Services.jsm",
|
||||
{}
|
||||
);
|
||||
var appversion = parseInt(Services.appinfo.version);
|
||||
|
||||
var AdditionalTopToolbars = {
|
||||
init: function () {
|
||||
/* blank tab workaround */
|
||||
try {
|
||||
if (gBrowser.selectedBrowser.getAttribute("blank"))
|
||||
gBrowser.selectedBrowser.removeAttribute("blank");
|
||||
} catch (e) {}
|
||||
|
||||
var number_of_additional_top_toolbars = 1; // max 5 to save toolbar state on Fx 71+ (add additional code at the bottom for more)
|
||||
var tb_label = "Address";
|
||||
|
||||
try {
|
||||
if (document.getElementById("additional_top_toolbar1") == null) {
|
||||
if (
|
||||
number_of_additional_top_toolbars > 0 &&
|
||||
number_of_additional_top_toolbars < 6
|
||||
) {
|
||||
var i = 1;
|
||||
|
||||
while (i <= number_of_additional_top_toolbars) {
|
||||
if (appversion <= 62)
|
||||
var toptoolbar = document.createElement("toolbar");
|
||||
else var toptoolbar = document.createXULElement("toolbar");
|
||||
|
||||
toptoolbar.setAttribute("id", "additional_top_toolbar" + i + "");
|
||||
toptoolbar.setAttribute("toolbarname", tb_label + "");
|
||||
toptoolbar.setAttribute("toolbarname", tb_label + "");
|
||||
toptoolbar.setAttribute("customizable", "true");
|
||||
toptoolbar.setAttribute(
|
||||
"class",
|
||||
"toolbar-primary chromeclass-toolbar browser-toolbar customization-target"
|
||||
);
|
||||
toptoolbar.setAttribute("mode", "icons");
|
||||
toptoolbar.setAttribute("iconsize", "small");
|
||||
toptoolbar.setAttribute("toolboxid", "navigator-toolbox");
|
||||
toptoolbar.setAttribute("context", "toolbar-context-menu");
|
||||
toptoolbar.setAttribute("lockiconsize", "true");
|
||||
toptoolbar.setAttribute("defaultset", "spring");
|
||||
|
||||
document
|
||||
.querySelector("#navigator-toolbox")
|
||||
.appendChild(toptoolbar);
|
||||
|
||||
CustomizableUI.registerArea("additional_top_toolbar" + i + "", {
|
||||
legacy: true,
|
||||
});
|
||||
if (appversion >= 65)
|
||||
CustomizableUI.registerToolbarNode(toptoolbar);
|
||||
|
||||
// top toolbars 'collapsed' on startup
|
||||
//setToolbarVisibility(toptoolbar, false);
|
||||
|
||||
try {
|
||||
Services.prefs
|
||||
.getDefaultBranch("browser.additional_top_toolbar" + i + ".")
|
||||
.setBoolPref("enabled", true);
|
||||
setToolbarVisibility(
|
||||
document.getElementById("additional_top_toolbar" + i + ""),
|
||||
Services.prefs
|
||||
.getBranch("browser.additional_top_toolbar" + i + ".")
|
||||
.getBoolPref("enabled")
|
||||
);
|
||||
} catch (e) {}
|
||||
|
||||
i++;
|
||||
}
|
||||
}
|
||||
|
||||
// CSS
|
||||
var sss = Components.classes[
|
||||
"@mozilla.org/content/style-sheet-service;1"
|
||||
].getService(Components.interfaces.nsIStyleSheetService);
|
||||
|
||||
var uri = Services.io.newURI(
|
||||
"data:text/css;charset=utf-8," +
|
||||
encodeURIComponent(
|
||||
'\
|
||||
\
|
||||
toolbar[id^="additional_top_toolbar"] { \
|
||||
-moz-appearance: none !important; \
|
||||
background-color: var(--toolbar-bgcolor); \
|
||||
background-image: var(--toolbar-bgimage); \
|
||||
background-clip: padding-box; \
|
||||
color: var(--toolbar-color, inherit); \
|
||||
} \
|
||||
#main-window[customizing] toolbar[id^="additional_top_toolbar"] { \
|
||||
outline: 1px dashed !important; \
|
||||
outline-offset: -2px !important; \
|
||||
} \
|
||||
\
|
||||
'
|
||||
),
|
||||
null,
|
||||
null
|
||||
);
|
||||
|
||||
sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
|
||||
}
|
||||
|
||||
if (number_of_additional_top_toolbars >= 1) {
|
||||
var observer1 = new MutationObserver(function (mutations) {
|
||||
mutations.forEach(function (mutation) {
|
||||
Services.prefs
|
||||
.getBranch("browser.additional_top_toolbar1.")
|
||||
.setBoolPref(
|
||||
"enabled",
|
||||
!document.querySelector("#additional_top_toolbar1").collapsed
|
||||
);
|
||||
});
|
||||
});
|
||||
observer1.observe(document.querySelector("#additional_top_toolbar1"), {
|
||||
attributes: true,
|
||||
childList: true,
|
||||
characterData: true,
|
||||
});
|
||||
}
|
||||
if (number_of_additional_top_toolbars >= 2) {
|
||||
var observer2 = new MutationObserver(function (mutations) {
|
||||
mutations.forEach(function (mutation) {
|
||||
Services.prefs
|
||||
.getBranch("browser.additional_top_toolbar2.")
|
||||
.setBoolPref(
|
||||
"enabled",
|
||||
!document.querySelector("#additional_top_toolbar2").collapsed
|
||||
);
|
||||
});
|
||||
});
|
||||
observer2.observe(document.querySelector("#additional_top_toolbar2"), {
|
||||
attributes: true,
|
||||
childList: true,
|
||||
characterData: true,
|
||||
});
|
||||
}
|
||||
if (number_of_additional_top_toolbars >= 3) {
|
||||
var observer3 = new MutationObserver(function (mutations) {
|
||||
mutations.forEach(function (mutation) {
|
||||
Services.prefs
|
||||
.getBranch("browser.additional_top_toolbar3.")
|
||||
.setBoolPref(
|
||||
"enabled",
|
||||
!document.querySelector("#additional_top_toolbar3").collapsed
|
||||
);
|
||||
});
|
||||
});
|
||||
observer3.observe(document.querySelector("#additional_top_toolbar3"), {
|
||||
attributes: true,
|
||||
childList: true,
|
||||
characterData: true,
|
||||
});
|
||||
}
|
||||
if (number_of_additional_top_toolbars >= 4) {
|
||||
var observer4 = new MutationObserver(function (mutations) {
|
||||
mutations.forEach(function (mutation) {
|
||||
Services.prefs
|
||||
.getBranch("browser.additional_top_toolbar4.")
|
||||
.setBoolPref(
|
||||
"enabled",
|
||||
!document.querySelector("#additional_top_toolbar4").collapsed
|
||||
);
|
||||
});
|
||||
});
|
||||
observer4.observe(document.querySelector("#additional_top_toolbar4"), {
|
||||
attributes: true,
|
||||
childList: true,
|
||||
characterData: true,
|
||||
});
|
||||
}
|
||||
if (number_of_additional_top_toolbars >= 5) {
|
||||
var observer5 = new MutationObserver(function (mutations) {
|
||||
mutations.forEach(function (mutation) {
|
||||
Services.prefs
|
||||
.getBranch("browser.additional_top_toolbar5.")
|
||||
.setBoolPref(
|
||||
"enabled",
|
||||
!document.querySelector("#additional_top_toolbar5").collapsed
|
||||
);
|
||||
});
|
||||
});
|
||||
observer5.observe(document.querySelector("#additional_top_toolbar5"), {
|
||||
attributes: true,
|
||||
childList: true,
|
||||
characterData: true,
|
||||
});
|
||||
}
|
||||
} catch (e) {}
|
||||
},
|
||||
};
|
||||
|
||||
/* initialization delay workaround */
|
||||
document.addEventListener(
|
||||
"DOMContentLoaded",
|
||||
AdditionalTopToolbars.init(),
|
||||
false
|
||||
);
|
||||
|
||||
// not needed anymore, but just in case someone prefers initialization that way
|
||||
/*
|
||||
setTimeout(function(){
|
||||
AdditionalTopToolbars.init();
|
||||
},500);
|
||||
*/
|
42
chrome/change-toolbar-icon-values.uc.js
Normal file
42
chrome/change-toolbar-icon-values.uc.js
Normal file
|
@ -0,0 +1,42 @@
|
|||
function waitForElm(selector) {
|
||||
return new Promise(resolve => {
|
||||
if (document.querySelector(selector)) {
|
||||
return resolve(document.querySelector(selector));
|
||||
}
|
||||
|
||||
const observer = new MutationObserver(mutations => {
|
||||
if (document.querySelector(selector)) {
|
||||
resolve(document.querySelector(selector));
|
||||
observer.disconnect();
|
||||
}
|
||||
});
|
||||
|
||||
observer.observe(document.body, {
|
||||
childList: true,
|
||||
subtree: true
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
waitForElm('#find-button').then((elm) => {
|
||||
var find = document.querySelector("#find-button label.toolbarbutton-text");
|
||||
find.setAttribute("value", "Search");
|
||||
});
|
||||
|
||||
setTimeout(function () {
|
||||
waitForElm('#nav-bar').then((elm) => {
|
||||
var library = document.querySelector("#bookmarks-menu-button label.toolbarbutton-text");
|
||||
library.setAttribute("value", "Favorites");
|
||||
});
|
||||
}, 0);
|
||||
|
||||
waitForElm('#bookmarksMenu').then((elm) => {
|
||||
var bookmarksmenu = document.querySelector("#bookmarksMenu label.menubar-text");
|
||||
bookmarksmenu.setAttribute("value", "Favorites");
|
||||
bookmarksmenu.setAttribute("accesskey", "a");
|
||||
});
|
||||
|
||||
waitForElm('#bookmarksMenu').then((elm) => {
|
||||
var bookmarksmenu = document.querySelector("#bookmarksMenu");
|
||||
bookmarksmenu.setAttribute("accesskey", "a");
|
||||
});
|
69
chrome/create_internet_on_status_bar.uc.js
Normal file
69
chrome/create_internet_on_status_bar.uc.js
Normal file
|
@ -0,0 +1,69 @@
|
|||
Components.utils.import("resource:///modules/CustomizableUI.jsm");
|
||||
var { Services } = Components.utils.import(
|
||||
"resource://gre/modules/Services.jsm",
|
||||
{}
|
||||
);
|
||||
var sss = Components.classes[
|
||||
"@mozilla.org/content/style-sheet-service;1"
|
||||
].getService(Components.interfaces.nsIStyleSheetService);
|
||||
|
||||
var IE6StatusBar = {
|
||||
init: function () {
|
||||
try {
|
||||
// create a default toolbar button
|
||||
CustomizableUI.createWidget({
|
||||
id: "ie6_statusbar", // button id
|
||||
defaultArea: CustomizableUI.AREA_NAVBAR,
|
||||
removable: true,
|
||||
label: "Internet", // button title
|
||||
tooltiptext: "", // tooltip title
|
||||
onCreated: function (button) {
|
||||
return button;
|
||||
},
|
||||
});
|
||||
|
||||
// style button icon / embedded non-animated icon, because there is no image for then inside Fx anymore
|
||||
var uri = Services.io.newURI(
|
||||
"data:text/css;charset=utf-8," +
|
||||
encodeURIComponent(
|
||||
`#ie6_statusbar {
|
||||
display: flex;
|
||||
width: 151px;
|
||||
height: 18px;
|
||||
box-shadow: inset -1px -1px 0 ThreeDHighlight, inset 1px 1px 0 ThreeDShadow;
|
||||
}
|
||||
|
||||
#ie6_statusbar::before {
|
||||
content: "";
|
||||
display: inline-block;
|
||||
width: 16px;
|
||||
height: 16px;
|
||||
margin-right: 3px;
|
||||
background-image: url("");
|
||||
}
|
||||
|
||||
#ie6_statusbar::after {
|
||||
content: "Internet";
|
||||
display: inline-block;
|
||||
text-shadow: none !important;
|
||||
}
|
||||
#ie6_statusbar > .toolbarbutton-icon {
|
||||
display: none;
|
||||
}`
|
||||
),
|
||||
null,
|
||||
null
|
||||
);
|
||||
|
||||
// remove old style sheet, before registering the new one
|
||||
if (sss.sheetRegistered(uri, sss.AGENT_SHEET)) {
|
||||
sss.unregisterSheet(uri, sss.AGENT_SHEET);
|
||||
}
|
||||
sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
|
||||
} catch (e) {
|
||||
Components.utils.reportError(e);
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
document.addEventListener("DOMContentLoaded", IE6StatusBar.init(), false);
|
69
chrome/favicon_in_urlbar.uc.js
Normal file
69
chrome/favicon_in_urlbar.uc.js
Normal file
|
@ -0,0 +1,69 @@
|
|||
// 'Favicon in urlbars identity box' script for Firefox 92+ by Aris
|
||||
//
|
||||
// This script restores current pages favicon inside urlbar (aka location bar, address bar or awesome bar).
|
||||
// [!] If a page does not offer a favicon, browser branches default icon is shown.
|
||||
// [!] In a multi-window environment pages without favicons might show wrong icons.
|
||||
// option: set icon for pages without favicon
|
||||
|
||||
var i_icon = 'chrome://global/skin/icons/info.svg';
|
||||
var sheet = 'chrome://global/skin/icons/Portrait.png';
|
||||
var brand = '';
|
||||
var globe = 'chrome://global/skin/icons/defaultFavicon.svg';
|
||||
|
||||
var icon_for_pages_without_favicon = brand; // i_icon, sheet, globe or brand (colorized Fx channel icon)
|
||||
|
||||
var favicon_click_opens_page_info_window = false;
|
||||
|
||||
var FaviconInUrlbar = {
|
||||
init: function() {
|
||||
try {
|
||||
|
||||
var favimginurlbar = document.createXULElement("image");
|
||||
favimginurlbar.setAttribute("id","favimginurlbar");
|
||||
|
||||
if(favicon_click_opens_page_info_window)
|
||||
favimginurlbar.setAttribute("onclick","gIdentityHandler.handleMoreInfoClick(event);");
|
||||
|
||||
favimginurlbar.style.width = "16px";
|
||||
favimginurlbar.style.height = "16px";
|
||||
favimginurlbar.style.marginLeft = "3px";
|
||||
favimginurlbar.style.marginRight = "3px";
|
||||
favimginurlbar.style.marginTop = "3px";
|
||||
favimginurlbar.style.marginBottom = "3px";
|
||||
|
||||
//document.getElementById('identity-box').insertBefore(favimginurlbar,document.getElementById('identity-box').firstChild);
|
||||
document.getElementById('identity-box').appendChild(favimginurlbar);
|
||||
|
||||
// update script every time tab attributes get modified (switch/open tabs/windows)
|
||||
document.addEventListener("TabAttrModified", updateIcon, false);
|
||||
document.addEventListener('TabSelect', updateIcon, false);
|
||||
document.addEventListener('TabOpen', updateIcon, false);
|
||||
document.addEventListener('TabClose', updateIcon, false);
|
||||
document.addEventListener('load', updateIcon, false);
|
||||
document.addEventListener("DOMContentLoaded", updateIcon, false);
|
||||
|
||||
|
||||
function updateIcon() {
|
||||
|
||||
setTimeout(function(){ // timeout fixes wrong icon detection in some cases
|
||||
|
||||
// get current tabs favicon
|
||||
var favicon_in_urlbar = gBrowser.selectedTab.image;
|
||||
|
||||
// if current tab offers no icon, use selected icon (icon_for_pages_without_favicon)
|
||||
if(!gBrowser.selectedTab.image || gBrowser.selectedTab.image == null)
|
||||
if(!icon_for_pages_without_favicon) favicon_in_urlbar = brand;
|
||||
else favicon_in_urlbar = icon_for_pages_without_favicon;
|
||||
|
||||
document.querySelector('#favimginurlbar').style.listStyleImage = "url("+favicon_in_urlbar+")";
|
||||
|
||||
},1);
|
||||
|
||||
}
|
||||
|
||||
} catch(e) {}
|
||||
}
|
||||
};
|
||||
|
||||
// initiate script after DOM/browser content is loaded
|
||||
document.addEventListener("DOMContentLoaded", FaviconInUrlbar.init(), false);
|
BIN
chrome/go.png
Normal file
BIN
chrome/go.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 257 B |
41
chrome/go_button.uc.js
Normal file
41
chrome/go_button.uc.js
Normal file
|
@ -0,0 +1,41 @@
|
|||
(function () {
|
||||
try {
|
||||
Components.utils.import("resource:///modules/CustomizableUI.jsm");
|
||||
var { Services } = Components.utils.import(
|
||||
"resource://gre/modules/Services.jsm",
|
||||
{}
|
||||
);
|
||||
var sss = Components.classes[
|
||||
"@mozilla.org/content/style-sheet-service;1"
|
||||
].getService(Components.interfaces.nsIStyleSheetService);
|
||||
var appversion = parseInt(Services.appinfo.version);
|
||||
|
||||
var button_label = "Go";
|
||||
|
||||
CustomizableUI.createWidget({
|
||||
id: "go-button", // button id
|
||||
defaultArea: CustomizableUI.AREA_NAVBAR,
|
||||
removable: true,
|
||||
label: button_label, // button title
|
||||
tooltiptext: button_label, // tooltip title
|
||||
onClick: function (event) {
|
||||
var cancelQuit = Components.classes[
|
||||
"@mozilla.org/supports-PRBool;1"
|
||||
].createInstance(Components.interfaces.nsISupportsPRBool);
|
||||
var observerSvc = Components.classes[
|
||||
"@mozilla.org/observer-service;1"
|
||||
].getService(Components.interfaces.nsIObserverService);
|
||||
|
||||
if (event.button == "0") {
|
||||
// left/middle-click - restart
|
||||
gURLBar.handleCommand(event);
|
||||
}
|
||||
},
|
||||
onCreated: function (button) {
|
||||
return button;
|
||||
},
|
||||
});
|
||||
} catch (e) {
|
||||
Components.utils.reportError(e);
|
||||
}
|
||||
})();
|
83
chrome/move_bars.uc.js
Normal file
83
chrome/move_bars.uc.js
Normal file
|
@ -0,0 +1,83 @@
|
|||
// 'MoveUrlbar' script for Firefox 60+ by Aris
|
||||
// option: place urlbar on a different toolbar
|
||||
// option: place back button on a different toolbar
|
||||
// option: place back button on a different toolbar
|
||||
|
||||
var { CustomizableUI } = Components.utils.import(
|
||||
"resource:///modules/CustomizableUI.jsm",
|
||||
{}
|
||||
);
|
||||
|
||||
var navigation = CustomizableUI.AREA_NAVBAR;
|
||||
var tabs = CustomizableUI.AREA_TABSTRIP;
|
||||
var menu = CustomizableUI.AREA_MENUBAR;
|
||||
var bookmarks = CustomizableUI.AREA_BOOKMARKS;
|
||||
|
||||
/* [target toolbar of item]
|
||||
menu = 'menubar'
|
||||
tabs = 'tabs toolbar'
|
||||
bookmarks = 'bookmarks toolbar'
|
||||
navigation='navigation toolbar' */
|
||||
var backbutton_on_toolbar = navigation;
|
||||
var forwardbutton_on_toolbar = navigation;
|
||||
var urlbar_on_toolbar = navigation;
|
||||
|
||||
/* [target position of item]
|
||||
0 = 1st
|
||||
1 = 2nd
|
||||
2 = 3rd
|
||||
...
|
||||
x = xth */
|
||||
var backbutton_on_toolbar_position = 0;
|
||||
var forwardbutton_on_toolbar_position = 1;
|
||||
var urlbar_on_toolbar_position = 0;
|
||||
|
||||
var MoveUrlbar = {
|
||||
init: function () {
|
||||
try {
|
||||
document.getElementById("back-button").setAttribute("removable", "true");
|
||||
document
|
||||
.getElementById("forward-button")
|
||||
.setAttribute("removable", "true");
|
||||
document
|
||||
.getElementById("urlbar-container")
|
||||
.setAttribute("removable", "true");
|
||||
document
|
||||
.getElementById("additional_top_toolbar1")
|
||||
.setAttribute("fullscreentoolbar", "true");
|
||||
} catch (e) {}
|
||||
|
||||
/*CustomizableUI.addWidgetToArea("back-button", backbutton_on_toolbar);
|
||||
CustomizableUI.moveWidgetWithinArea(
|
||||
"back-button",
|
||||
backbutton_on_toolbar_position
|
||||
);
|
||||
CustomizableUI.addWidgetToArea("forward-button", forwardbutton_on_toolbar);
|
||||
CustomizableUI.moveWidgetWithinArea(
|
||||
"forward-button",
|
||||
forwardbutton_on_toolbar_position
|
||||
);
|
||||
CustomizableUI.addWidgetToArea(
|
||||
"urlbar-container",
|
||||
"additional_top_toolbar1"
|
||||
);
|
||||
CustomizableUI.moveWidgetWithinArea(
|
||||
"urlbar-container",
|
||||
urlbar_on_toolbar_position
|
||||
);*/
|
||||
|
||||
document
|
||||
.getElementById("navigator-toolbox")
|
||||
.appendChild(document.getElementById("TabsToolbar"));
|
||||
|
||||
/*
|
||||
try {
|
||||
document.getElementById('back-button').setAttribute('removable','false');
|
||||
document.getElementById('forward-button').setAttribute('removable','false');
|
||||
document.getElementById('urlbar-container').setAttribute('removable','false');
|
||||
} catch(e){}
|
||||
*/
|
||||
},
|
||||
};
|
||||
|
||||
document.addEventListener("DOMContentLoaded", MoveUrlbar.init(), false);
|
143
chrome/scrollbar.uc.js
Normal file
143
chrome/scrollbar.uc.js
Normal file
|
@ -0,0 +1,143 @@
|
|||
(function () {
|
||||
var css = `@media all and (-moz-overlay-scrollbars) {
|
||||
scrollbar[root="true"] {
|
||||
position: relative;
|
||||
z-index: 9999999;
|
||||
}
|
||||
|
||||
scrollbar:not([active="true"]),
|
||||
scrollbar[disabled="true"] {
|
||||
visibility: hidden;
|
||||
}
|
||||
}
|
||||
|
||||
scrollbar
|
||||
{
|
||||
color-scheme: light !important;
|
||||
-moz-appearance: none;
|
||||
-moz-binding: url("chrome://global/content/bindings/scrollbar.xml#scrollbar");
|
||||
cursor: default;
|
||||
min-width: 16px !important;
|
||||
background: url("") repeat !important;
|
||||
}
|
||||
|
||||
thumb
|
||||
{
|
||||
color-scheme: light !important;
|
||||
-moz-appearance: none !important;
|
||||
position: relative !important;
|
||||
background-color: -moz-Dialog !important;
|
||||
min-height: 8px !important;
|
||||
pointer-events: auto !important;
|
||||
border: 0 !important;
|
||||
box-shadow: inset -1px -1px 0 rgb(0, 0, 0), inset 1px 1px 0 -moz-Dialog, inset -2px -2px 0 ThreeDShadow, inset 2px 2px 0 ThreeDHighlight !important;
|
||||
}
|
||||
|
||||
thumb[orient="horizontal"] {
|
||||
-moz-appearance: none;
|
||||
min-height: 16px !important;
|
||||
min-width: 8px !important;
|
||||
max-width: 100% !important;
|
||||
background-repeat: no-repeat !important;
|
||||
}
|
||||
|
||||
scrollbarbutton
|
||||
{
|
||||
color-scheme: light !important;
|
||||
min-width: 16px !important;
|
||||
min-height: 16px !important;
|
||||
-moz-default-appearance: none !important;
|
||||
background-color: -moz-Dialog !important;
|
||||
box-shadow: inset -1px -1px 0 rgb(0, 0, 0), inset 1px 1px 0 -moz-Dialog, inset -2px -2px 0 ThreeDShadow, inset 2px 2px 0 ThreeDHighlight !important;
|
||||
}
|
||||
|
||||
scrollbarbutton:not(.disabled):hover:active
|
||||
{
|
||||
background-color: -moz-dialog !important;
|
||||
border: 1px solid ThreeDShadow !important;
|
||||
box-shadow: none !important;
|
||||
}
|
||||
|
||||
slider,
|
||||
slider[orient="vertical"]
|
||||
{
|
||||
color-scheme: light !important;
|
||||
-moz-appearance: none;
|
||||
}
|
||||
|
||||
scrollcorner
|
||||
{
|
||||
color-scheme: light !important;
|
||||
-moz-appearance: none !important;
|
||||
-moz-binding: url(chrome://global/content/bindings/scrollbar.xml#scrollbar-base);
|
||||
width: 16px;
|
||||
cursor: default;
|
||||
background-color: -moz-dialog; !important;
|
||||
}
|
||||
|
||||
scrollbarbutton[type="increment"]
|
||||
{
|
||||
-moz-appearance: none;
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("") !important;
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbar[orient="vertical"] > scrollbarbutton[type="increment"]
|
||||
{
|
||||
-moz-appearance: none;
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("") !important;
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbarbutton[type="decrement"]
|
||||
{
|
||||
-moz-appearance: none;
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("") !important;
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbar[orient="vertical"] > scrollbarbutton[type="decrement"]
|
||||
{
|
||||
-moz-appearance: none;
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("") !important;
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbarbutton[type="increment"][disabled="true"]
|
||||
{
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("");
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbar[orient="vertical"] > scrollbarbutton[type="increment"][disabled="true"]
|
||||
{
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("");
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbarbutton[type="decrement"][disabled="true"]
|
||||
{
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("");
|
||||
background-position: center center !important;
|
||||
}
|
||||
|
||||
scrollbar[orient="vertical"] > scrollbarbutton[type="decrement"][disabled="true"]
|
||||
{
|
||||
background-repeat: no-repeat !important;
|
||||
background-image: url("") !important;
|
||||
background-position: center !important;
|
||||
}`;
|
||||
var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(
|
||||
Ci.nsIStyleSheetService
|
||||
);
|
||||
var uri = makeURI("data:text/css;charset=UTF=8," + encodeURIComponent(css));
|
||||
|
||||
sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
|
||||
})();
|
181
chrome/space_and_separator_restorer.uc.js
Normal file
181
chrome/space_and_separator_restorer.uc.js
Normal file
|
@ -0,0 +1,181 @@
|
|||
// Restore 'Space & Separator' items script for Firefox 60+ by Aris
|
||||
//
|
||||
// Default browser scripts always remove spaces and separators from default palette, so
|
||||
// because of that they are added to an own toolbar now.
|
||||
//
|
||||
// - spaces and separators can be moved to any toolbar
|
||||
// - to remove spaces or separators move them into palette
|
||||
// - configuration toolbar behaves like a default toolbar, items and buttons can be placed on it
|
||||
// - configuration toolbar is not visible outside customizing mode
|
||||
// - default "Flexible Space" item is hidden from palette and added to configuration toolbar
|
||||
// [!] BUG: do not move spaces, flexible spaces or separator to configuration toolbar or it will cause glitches
|
||||
// [!] BUG: do not move main 'space'-item to palette or it will be hidden until customizing mode gets reopened
|
||||
|
||||
// [!] Fix for WebExtensions with own windows by 黒仪大螃蟹 (for 1-N scripts)
|
||||
|
||||
|
||||
Components.utils.import("resource:///modules/CustomizableUI.jsm");
|
||||
var {Services} = Components.utils.import("resource://gre/modules/Services.jsm", {});
|
||||
var appversion = parseInt(Services.appinfo.version);
|
||||
|
||||
var AddSeparator = {
|
||||
init: function() {
|
||||
|
||||
if (appversion >= 76 && location != 'chrome://browser/content/browser.xhtml')
|
||||
return;
|
||||
|
||||
/* blank tab workaround */
|
||||
try {
|
||||
if(gBrowser.selectedBrowser.getAttribute('blank')) gBrowser.selectedBrowser.removeAttribute('blank');
|
||||
} catch(e) {}
|
||||
|
||||
var tb_config_label = "Configuration Toolbar";
|
||||
var tb_spacer_label = "Space";
|
||||
var tb_sep_label = "Separator";
|
||||
var tb_spring_label = "Flexible Space";
|
||||
|
||||
try {
|
||||
if(document.getElementById('configuration_toolbar') == null) {
|
||||
|
||||
if(appversion <= 62) var tb_config = document.createElement("toolbar");
|
||||
else var tb_config = document.createXULElement("toolbar");
|
||||
tb_config.setAttribute("id","configuration_toolbar");
|
||||
tb_config.setAttribute("customizable","true");
|
||||
tb_config.setAttribute("class","toolbar-primary chromeclass-toolbar browser-toolbar customization-target");
|
||||
tb_config.setAttribute("mode","icons");
|
||||
tb_config.setAttribute("iconsize","small");
|
||||
tb_config.setAttribute("toolboxid","navigator-toolbox");
|
||||
tb_config.setAttribute("lockiconsize","true");
|
||||
tb_config.setAttribute("ordinal","1005");
|
||||
tb_config.setAttribute("defaultset","toolbarspacer,toolbarseparator");
|
||||
|
||||
document.querySelector('#navigator-toolbox').appendChild(tb_config);
|
||||
|
||||
CustomizableUI.registerArea("configuration_toolbar", {legacy: true});
|
||||
if(appversion >= 65) CustomizableUI.registerToolbarNode(tb_config);
|
||||
|
||||
if(appversion <= 62) var tb_label = document.createElement("label");
|
||||
else var tb_label = document.createXULElement("label");
|
||||
tb_label.setAttribute("label", tb_config_label+": ");
|
||||
tb_label.setAttribute("value", tb_config_label+": ");
|
||||
tb_label.setAttribute("id","tb_config_tb_label");
|
||||
tb_label.setAttribute("removable","false");
|
||||
|
||||
tb_config.appendChild(tb_label);
|
||||
|
||||
|
||||
if(appversion <= 62) var tb_spacer = document.createElement("toolbarspacer");
|
||||
else var tb_spacer = document.createXULElement("toolbarspacer");
|
||||
tb_spacer.setAttribute("id","spacer");
|
||||
tb_spacer.setAttribute("class","chromeclass-toolbar-additional");
|
||||
tb_spacer.setAttribute("customizableui-areatype","toolbar");
|
||||
tb_spacer.setAttribute("removable","false");
|
||||
tb_spacer.setAttribute("label", tb_spacer_label);
|
||||
|
||||
tb_config.appendChild(tb_spacer);
|
||||
|
||||
|
||||
if(appversion <= 62) var tb_sep = document.createElement("toolbarseparator");
|
||||
else var tb_sep = document.createXULElement("toolbarseparator");
|
||||
tb_sep.setAttribute("id","separator");
|
||||
tb_sep.setAttribute("class","chromeclass-toolbar-additional");
|
||||
tb_sep.setAttribute("customizableui-areatype","toolbar");
|
||||
tb_sep.setAttribute("removable","false");
|
||||
tb_sep.setAttribute("label", tb_sep_label);
|
||||
|
||||
tb_config.appendChild(tb_sep);
|
||||
|
||||
|
||||
if(appversion <= 62) var tb_spring = document.createElement("toolbarspring");
|
||||
else var tb_spring = document.createXULElement("toolbarspring");
|
||||
tb_spring.setAttribute("id","spring");
|
||||
tb_spring.setAttribute("class","chromeclass-toolbar-additional");
|
||||
tb_spring.setAttribute("customizableui-areatype","toolbar");
|
||||
tb_spring.setAttribute("removable","false");
|
||||
tb_spring.setAttribute("flex","1");
|
||||
tb_spring.setAttribute("label", tb_spring_label);
|
||||
|
||||
tb_config.appendChild(tb_spring);
|
||||
|
||||
// CSS
|
||||
var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService);
|
||||
|
||||
var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\
|
||||
\
|
||||
#configuration_toolbar { \
|
||||
-moz-appearance: none !important; \
|
||||
background-color: var(--toolbar-bgcolor); \
|
||||
background-image: var(--toolbar-bgimage); \
|
||||
background-clip: padding-box; \
|
||||
color: var(--toolbar-color, inherit); \
|
||||
} \
|
||||
#main-window:not([customizing]) #configuration_toolbar { \
|
||||
visibility: collapse; \
|
||||
}\
|
||||
#main-window[customizing] #configuration_toolbar #tb_config_tb_label { \
|
||||
font-weight: bold !important; \
|
||||
}\
|
||||
#main-window[customizing] #configuration_toolbar :-moz-any(#spacer,#separator,#spring) { \
|
||||
-moz-margin-start: 20px; \
|
||||
}\
|
||||
#main-window[customizing] #configuration_toolbar :-moz-any(#wrapper-spacer,#wrapper-separator,#wrapper-spring) .toolbarpaletteitem-label { \
|
||||
display: block !important; \
|
||||
-moz-margin-end: 20px; \
|
||||
}\
|
||||
#main-window[customizing] #wrapper-spacer #spacer { \
|
||||
margin: 2px 0 !important; \
|
||||
}\
|
||||
#main-window[customizing] #configuration_toolbar #wrapper-spring #spring { \
|
||||
margin: -1px 0 !important; \
|
||||
min-width: 80px !important; \
|
||||
}\
|
||||
#main-window[customizing] #configuration_toolbar > * { \
|
||||
padding: 10px !important; \
|
||||
}\
|
||||
#main-window[customizing] #configuration_toolbar > :-moz-any(#wrapper-spacer,#wrapper-separator,#wrapper-spring) { \
|
||||
border: 1px dotted !important; \
|
||||
-moz-margin-start: 2px !important; \
|
||||
-moz-margin-end: 2px !important; \
|
||||
}\
|
||||
#main-window[customizing] toolbarspacer { \
|
||||
border: 1px solid !important; \
|
||||
}\
|
||||
toolbar[orient="vertical"] toolbarseparator { \
|
||||
-moz-appearance: none !important; \
|
||||
border-top: 1px solid rgba(15,17,38, 0.5) !important; \
|
||||
border-bottom: 1px solid rgba(255,255,255, 0.3) !important; \
|
||||
margin: 2px 2px !important; \
|
||||
height: 1px !important; \
|
||||
width: 18px !important; \
|
||||
}\
|
||||
toolbar[orient="vertical"] toolbarspacer { \
|
||||
-moz-appearance: none !important; \
|
||||
height: 18px !important; \
|
||||
width: 18px !important; \
|
||||
}\
|
||||
#customization-palette toolbarpaletteitem[id^="wrapper-customizableui-special-spring"], \
|
||||
#customization-palette-container :-moz-any(#spring,#wrapper-spring) { \
|
||||
display: none !important; \
|
||||
}\
|
||||
#main-window:not([customizing]) toolbar:not(#configuration_toolbar) toolbarspring {\
|
||||
max-width: 100% !important; \
|
||||
}\
|
||||
\
|
||||
'), null, null);
|
||||
|
||||
sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET);
|
||||
}
|
||||
} catch(e){}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/* initialization delay workaround */
|
||||
document.addEventListener("DOMContentLoaded", AddSeparator.init(), false);
|
||||
/* Use the below code instead of the one above this line, if issues occur */
|
||||
/*
|
||||
setTimeout(function(){
|
||||
AddSeparator.init();
|
||||
},2000);
|
||||
*/
|
23
chrome/toolbar-label-under-icon.css
Normal file
23
chrome/toolbar-label-under-icon.css
Normal file
|
@ -0,0 +1,23 @@
|
|||
:root[uidensity="touch"] #nav-bar toolbarbutton:not(#nav-bar-overflow-button):not(#PanelUI-menu-button) .toolbarbutton-text {
|
||||
display: unset !important;
|
||||
}
|
||||
|
||||
:root[uidensity="touch"] #nav-bar {
|
||||
height: 42px !important;
|
||||
}
|
||||
|
||||
:root[uidensity="touch"] #nav-bar toolbarbutton:not(#nav-bar-overflow-button):not(#PanelUI-menu-button) {
|
||||
min-width: 58px !important;
|
||||
padding-top: 2px !important;
|
||||
}
|
||||
|
||||
:root[uidensity="touch"] #nav-bar toolbarbutton {
|
||||
-moz-box-orient: vertical;
|
||||
|
||||
}
|
||||
|
||||
:root[uidensity="touch"] #nav-bar .toolbarbutton-1 .toolbarbutton-text {
|
||||
margin-top: 3px !important;
|
||||
padding-left: 0 !important;
|
||||
padding-right: 0 !important;
|
||||
}
|
BIN
chrome/toolbar.png
Normal file
BIN
chrome/toolbar.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.2 KiB |
BIN
chrome/toolbar_large.png
Normal file
BIN
chrome/toolbar_large.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.4 KiB |
2251
chrome/userChrome.css
Normal file
2251
chrome/userChrome.css
Normal file
File diff suppressed because one or more lines are too long
Loading…
Reference in a new issue