firefox-scriptsuserChromeJS / autoconfig.js and extensions
userChromeJS
Tested on Firefox Developer Edition 93.0b6, Windows 10
Instructions
Video running installation steps below: https://youtu.be/_4fdUdp3G4o
→ For Linux and macOS paths, read this and this.
-
Download this zip file and extract its content to Firefox installation folder (usually C:\Program Files\Mozilla Firefox).
-
Click Firefox menu button (☰) -> Help -> More troubleshooting information or simply open about:support. Find "Profile Folder", then click "Open folder". In there, create a new folder called chrome.
-
Download one of the files below and extract its content in chrome folder.
Now, if you're only interested in extensions, you can skip to step 6.
-
Save the desired userChromeJS scripts into chrome. Read below the description of some of them.
-
If you want a button to manage your scripts, including the ability to disable/enable scripts without needing to restart¹ Firefox or Thunderbird, save rebuild_userChrome.uc.js into chrome.
-
Open about:support and click "Clear startup cache…" to force Firefox to load userChromeJS on the next startup.
-
Restart Firefox.
¹: Not all scripts are restartless. These have @shutdown
at the beginning of the code. Almost all scripts on this page were written by me to be restartless, but almost all scripts you get from other sources are not.
userChromeJS scripts
ᵀᴮ: also compatible with Thunderbird
(click to expand)
BeQuiet
The main purpose of this script is to control media without having to select the tab playing it. So I can play/pause a YouTube video or skip to the next song in Deezer while browsing Reddit, for example. Three hotkeys are defined by this script: Ctrl+Alt+S to play/pause, Ctrl+Alt+D to next song and Ctrl+Alt+A to previous song.Besides that, no more than one tab should play audio at the same time. Each tab paused by another tab that starts playing is added to a stack. So if I open a new YouTube video while there's already one playing, the new tab starts playing and the other is paused. When the video ends or when I pause it, the first YouTube tab resumes playing.
As for now, I only added support for a few sites, like Deezer, Spotify and YouTube. I chose not to support next/previous in YouTube, only play/pause.
Enter Selects
Have you ever been frustrated because you wanted, for example, that Firefox autofills "https://www.youtube.com/feed/subscriptions" when you type "youtube" in location bar? That's because Firefox only autofills domains, so it will never go further than just "https://www.youtube.com/". Also because of this, Firefox will never autofill "https://www.reddit.com/r/firefox/" when you type "firefox", no matter how many times you've visited that page.I don't like this. Firefox should be smart to always prioritize the page with higher "visit score" in browser history. That's what this script fixes. It preselects the first suggestion from address bar. For instance, if this page is the first suggestion when you type "xiaoxiaoflood", you don't need to press down arrow key before Enter.
Pages you usually visit will always rise to the first position, so accessing any frequent page will be as easy as typing no more than three chars + Enter, like just "you" + Enter to load YouTube Feed directly instead of YouTube homepage. It's even possible to teach Firefox to selects YouTube Feed with "y" and YouTube Homepage with "yo", it's just a matter of practice.
This script replaces urlbar autocomplete, so browser.urlbar.autoFill
is disabled on install. If at any time you miss domain autofill, you still sort of can achieve that by pressing Tab IF the domain of first suggestion matches what you've typed so far. Example: you typed "git" and the first suggestion is from github.com. Pressing Tab key will autocomplete the domain even if the first suggestion is not just github.com - it may be github.com/whatever. But if the typed input doesn't match the domain of the first suggestion, then Tab key will have default behavior of selecting next suggestion just like down arrow key.
Extension Options Menu
A single toolbar button to manage all your extensions. It opens a menu listing each extension. Left-click to open Options from the hovered addon, right-click to enable/disable, Ctrl + right-click to uninstall. Hover anywhere on the menu to see more.Screenshot:
Extensions Update Checker
Firefox checks for available updates every 24 hours. You can disable autoinstall updates, but then you'll only know there are available updates if you manually open Add-ons Manager. This script:- Disables autoinstall updates for every addon.
- Just after the daily check, if there's an update available it will open Add-ons Manager directly in "Available Updates" view, so that you can track changes before updating (you can click on the extension, then click "Release Notes" button).
- You can fill
ignoreList
if you are deliberately using an outdated version of an extension and don't want to be notified that an update is available.
ᵀᴮ Master Password+
Locks Firefox with password. This will prompt the password on browser startup or anytime when you lock it with Ctrl+Alt+Shift+W.You need to set a master password in Firefox Options > Privacy & Security > [×] Use a Primary Password.
MinMaxClose Button
Toolbar button to replace native window buttons (minimize, maximize and close). I'm a Windows user and use Tree Style Tab with hidden titlebar, so I need this.-
Left-click to minimize (so I can't close it accidentally).
-
Right-click to close.
-
Middleclick restores to fixed position/size (edit script code with your preferred values). If you want to restore to previous position/size, use Shift + Middleclick.
Mouse Gestures
More powerful than any mouse gestures WebExtensions. But it doesn't have user interface and I have only included actions I use, so unless the default set of actions suits you, knowledge in JavaScript is required to write extra actions. However, it's easy to change gestures for available actions. You can view default gestures at the beginning of the code (search forGESTURES:
). Some of them:
- Hold right-click, then roll mouse wheel up or down to switch to next/previous tab.
- Hold right-click, move down and release to scroll to bottom of the page (or move up to go the top). If the cursor was over an image, moving down will open a new tab for reverse image Google search instead of scrolling to bottom.
- Hold right-click, then left-click to switch to the last selected tab.
- Hold left-click, then right-click to reload current tab.
- Hold right-click, then middle-click (wheel button) to close current tab.
- Hold right-click, move left and release to copy URL of link or media under the cursor.
- Hold right-click, move right and release to open a new tab with the link or media under the cursor.
- Hold middle-click, move left and release to copy selected text or image under the cursor.
- Hold middle-click, move right and release to paste.
- Hold left-click, then press forward button (for mouse with extra buttons) to switch to next group (specific compatibility with Tiled Tab Groups extension).
Gestures are cumulative if possible, so right-click (hold) + left-click + left-click + left-click will toggle between the two most recently used tabs.
Advantages over existing extensions:
- Extensions can't run over Firefox interface, so gestures don't work over Firefox toolbars.
- Extensions can't run on privileged pages like about:config and view-source.
- Extensions need the page to start loading to run, causing gestures to fail sometimes.
- Extensions can't set gestures for 4th and 5th mouse buttons (Back and Forward).
- UserChromeJS has unlimited power, so you can do almost whatever you want if you write code for that. For example, I have a gesture that forces an extension (Tiled Tab Groups) to execute part of its own code that is not exposed to other addons by an API.
multifoxContainer
When Firefox introduced containers, I created this script to get some features that I missed from Multifox, the legacy addon that implemented "containers" years before Firefox having this feature by default. Since then, Firefox has added some things this script had, so I removed them. But I still use it for two things:-
New tabs (Ctrl+T or New Tab button) inherits the container of current tab (except for Private Tabs).
-
The label in urlbar serves as menubutton to reopen current tab in other container. With left click, current tab is replaced. With middleclick, a new tab is opened without closing the other one.
Open in Unloaded Tab
Creates an item in contextmenu to open links/bookmarks/history in unloaded tabs, i.e., the tab is created, but it will only load when selected. Just like unloaded tabs when you restore previous session. So you can, for example, open multiple related YouTube videos and load them one by one. Or open an entire bookmark folder in tabs without freezing the browser, since tab content will load on demand.PrivateTab
Fx 77 blocked the ability to open private tabs in non-private windows, previously possible with Private Tab addon. So I decided to write this script as a replacement. You can change some minor settings at the beginning of the code.Redirector
Requires basic JS skills to write rules using regex.The main difference between this and extensions like Redirector it that these Firefox extensions record both pre-redirect and final URLs in history. I want it to record just the final URL.
This script can also do more complex things like running a JS function with regex results.
Finally, the main reason why I wrote this was to integrate it with Link Status Redux. When I point the mouse to a link that I've already visited, LSR displays the time of last visit. This is extremely useful for me to know if I have already visited the page and to track changes since last visit.
LSR uses Redirector rules to replace links directly in page (Redirector extension doesn't do this, it redirects only when you try to load the URL). And many URLs have gibberish at the end, so I have rules to remove them, then the URL remains clean and LST can track last visit correctly (because the gibberish is different every time, generating different URLs).
Note: the list of rules in the script is just an example, mine is much bigger.
Status Bar
Brings back the good old status bar (also known as Addon Bar) at the bottom, with status text plus any buttons you want.Screenshots:
ᵀᴮ StyloaiX
UserStyle manager to reskin Firefox window and websites. Replacement for legacy Stylish. More convenient than userChrome.css and userContent.css, as it has a powerful editor with instant preview, error checking, code autocomplete and you can enable/disable individual styles without restarting Firefox.Screenshots (yes, I'm using the old Stylish icon):
Auto Plain Text Links
Firefox's default context menu will allow you to open plain text links if you select them first. This small addon automatically detects simple http and ftp plain text links when you right-click without needing you to select them first, then passes that URL on to the default Firefox menu items for opening them.Context to Search
With this script, when you choose Search from the context menu (with text selected), instead of immediately searching it will just put the selected text in the search bar so you can edit it and choose the search engine before searching.Restore browser.newtab.url
Pref to about:config
(by TheRealPSV)
This script restores the browser.newtab.url
preference to about:config
. Using this preference, you can set whatever you like as your New Tab page, including things like file://
URLs that don't work with new tab override extensions. Once you install the script, just set the preference in about:config
and it should work automatically. Make sure you don't have any other new tab extensions, or it might not work.
(Written by TheRealPSV)
Removed pages
about:config
The new about:config
is way worse than the classic page. Although the new version was introduced in Fx 71, the old one was still accessible for a while via direct URL, but it was removed in Fx 87. To continue using it, save all three files from the link below, then bookmark the following URL:
chrome://userchromejs/content/aboutconfig/aboutconfig.xhtml
Password Manager
I don't like the new password manager and the old one was removed in Fx 77. I'm still using it. If you want it too, save all three files from the link below, so that you can access the old password manager using the following URL (bookmark it):chrome://userchromejs/content/passwordmgr/passwordManager.xhtml