nixos/modules/desktop/browsers/firefox/default.nix

346 lines
13 KiB
Nix

{
options,
config,
lib,
pkgs,
...
}: let
cfg = config.modules.desktop.browsers.firefox;
in {
options.modules.desktop.browsers.firefox = {
enable = lib.mkEnableOption false;
};
# TODO add this
# https://github.com/Dook97/firefox-qutebrowser-userchrome
config = lib.mkIf cfg.enable {
programs.firefox = {
enable = true;
preferences = {
"toolkit.legacyUserProfileCustomizations.stylesheets" = true;
"browser.compactmode.show" = true;
};
};
home-manager.users.sako = {
programs.firefox = {
enable = true;
profiles = {
"user" = {
id = 0;
isDefault = true;
userChrome = ''
:root {
--tab-active-bg-color: #057;
--tab-inactive-bg-color: #333;
--tab-active-fg-fallback-color: #eee; /* color of text in an active tab without a container */
--tab-inactive-fg-fallback-color: #888; /* color of text in an inactive tab without a container */
--urlbar-focused-bg-color: #41404c;
--urlbar-not-focused-bg-color: #1c1b22;
--toolbar-bgcolor: #2b2a33 !important;
--tab-font: 'Jetbrains Mono';
--urlbar-font: 'Jetbrains Mono';
/* try increasing if you encounter problems */
--urlbar-height-setting: 24px;
--tab-min-height: 16px !important;
/* I don't recommend you touch this unless you know what you're doing */
--arrowpanel-menuitem-padding: 2px !important;
--arrowpanel-border-radius: 0px !important;
--arrowpanel-menuitem-border-radius: 0px !important;
--toolbarbutton-border-radius: 0px !important;
--toolbarbutton-inner-padding: 0px 2px !important;
--toolbar-field-focus-background-color: var(--urlbar-focused-bg-color) !important;
--toolbar-field-background-color: var(--urlbar-not-focused-bg-color) !important;
--toolbar-field-focus-border-color: transparent !important;
}
/* --- GENERAL DEBLOAT ---------------------------------- */
/* Bottom left page loading status or url preview */
#statuspanel { display: none !important; }
/* remove radius from right-click popup */
menupopup, panel { --panel-border-radius: 0px !important; }
menu, menuitem, menucaption { border-radius: 0px !important; }
/* no stupid large buttons in right-click menu */
menupopup > #context-navigation { display: none !important; }
menupopup > #context-sep-navigation { display: none !important; }
/* --- DEBLOAT NAVBAR ----------------------------------- */
#back-button { display: none; }
#forward-button { display: none; }
#reload-button { display: none; }
#stop-button { display: none; }
#home-button { display: none; }
#library-button { display: none; }
#fxa-toolbar-menu-button { display: none; }
/* empty space before and after the url bar */
#customizableui-special-spring1, #customizableui-special-spring2 { display: none; }
/* --- STYLE NAVBAR ------------------------------------ */
/* remove padding between toolbar buttons */
toolbar .toolbarbutton-1 { padding: 0 0 !important; }
/* add it back to the downloads button, otherwise it's too close to the urlbar */
#downloads-button {
margin-left: 2px !important;
}
/* add padding to the right of the last button so that it doesn't touch the edge of the window */
#PanelUI-menu-button {
padding: 0px 4px 0px 0px !important;
}
#urlbar-container {
--urlbar-container-height: var(--urlbar-height-setting) !important;
margin-left: 0 !important;
margin-right: 0 !important;
padding-top: 0 !important;
padding-bottom: 0 !important;
font-family: var(--urlbar-font, 'monospace');
font-size: 11px;
}
#urlbar {
--urlbar-height: var(--urlbar-height-setting) !important;
--urlbar-toolbar-height: var(--urlbar-height-setting) !important;
min-height: var(--urlbar-height-setting) !important;
border-color: var(--lwt-toolbar-field-border-color, hsla(240,5%,5%,.25)) !important;
}
#urlbar-input {
margin-left: 0.8em !important;
margin-right: 0.4em !important;
}
#navigator-toolbox {
border: none !important;
}
/* keep pop-up menus from overlapping with navbar */
#widget-overflow { margin: 0 !important; }
#appMenu-popup { margin: 0 !important; }
#customizationui-widget-panel { margin: 0 !important; }
#unified-extensions-panel { margin: 0 !important; }
/* make browser dialog boxes not overlap the navbar */
:not(.content-prompt-dialog) > .dialogOverlay > .dialogBox:not(.spotlightBox) {
margin-top: 0px !important;
}
/* --- UNIFIED EXTENSIONS BUTTON ------------------------ */
/* make extension icons smaller */
#unified-extensions-view {
--uei-icon-size: 16px;
}
/* hide bloat */
.unified-extensions-item-message-deck,
#unified-extensions-view > .panel-header,
#unified-extensions-view > toolbarseparator,
#unified-extensions-manage-extensions {
display: none !important;
}
/* add 3px padding on the top and the bottom of the box */
.panel-subview-body {
padding: 3px 0px !important;
}
#unified-extensions-view .toolbarbutton-icon {
padding: 0 !important;
}
.unified-extensions-item-contents {
line-height: 1 !important;
white-space: nowrap !important;
}
#unified-extensions-panel .unified-extensions-item {
margin-block: 0 !important;
}
.toolbar-menupopup :is(menu, menuitem), .subview-subheader, panelview
.toolbarbutton-1, .subviewbutton, .widget-overflow-list .toolbarbutton-1 {
padding: 4px !important;
}
/* --- DEBLOAT URLBAR ----------------------------------- */
#identity-box { display: none; }
#pageActionButton { display: none; }
#pocket-button { display: none; }
#urlbar-zoom-button { display: none; }
#tracking-protection-icon-container { display: none !important; }
#reader-mode-button{ display: none !important; }
#star-button { display: none; }
#star-button-box:hover { background: inherit !important; }
/* Go to arrow button at the end of the urlbar when searching */
#urlbar-go-button { display: none; }
/* remove container indicator from urlbar */
#userContext-label, #userContext-indicator { display: none !important;}
/* --- STYLE TAB TOOLBAR -------------------------------- */
#titlebar {
--proton-tab-block-margin: 0px !important;
--tab-block-margin: 0px !important;
}
#TabsToolbar, .tabbrowser-tab {
max-height: var(--tab-min-height) !important;
font-size: 11px !important;
}
/* Change color of normal tabs */
tab:not([selected="true"]) {
background-color: var(--tab-inactive-bg-color) !important;
color: var(--identity-icon-color, var(--tab-inactive-fg-fallback-color)) !important;
}
tab {
font-family: var(--tab-font, monospace);
font-weight: bold;
border: none !important;
}
/* safari style tab width */
.tabbrowser-tab[fadein] {
max-width: 100vw !important;
border: none
}
/* Hide close button on tabs */
#tabbrowser-tabs .tabbrowser-tab .tab-close-button { display: none !important; }
/* disable favicons in tab */
/* .tab-icon-stack:not([pinned]) { display: none !important; } */
.tabbrowser-tab {
/* remove border between tabs */
padding-inline: 0px !important;
/* reduce fade effect of tab text */
--tab-label-mask-size: 1em !important;
/* fix pinned tab behaviour on overflow */
overflow-clip-margin: 0px !important;
}
/* Tab: selected colors */
#tabbrowser-tabs .tabbrowser-tab[selected] .tab-content {
background: var(--tab-active-bg-color) !important;
color: var(--identity-icon-color, var(--tab-active-fg-fallback-color)) !important;
}
/* Tab: hovered colors */
#tabbrowser-tabs .tabbrowser-tab:hover:not([selected]) .tab-content {
background: var(--tab-active-bg-color) !important;
}
/* hide window controls */
.titlebar-buttonbox-container { display: none; }
/* remove titlebar spacers */
.titlebar-spacer { display: none !important; }
/* disable tab shadow */
#tabbrowser-tabs:not([noshadowfortests]) .tab-background:is([selected], [multiselected]) {
box-shadow: none !important;
}
/* remove dark space between pinned tab and first non-pinned tab */
#tabbrowser-tabs[haspinnedtabs]:not([positionpinnedtabs]) >
#tabbrowser-arrowscrollbox >
.tabbrowser-tab:nth-child(1 of :not([pinned], [hidden])) {
margin-inline-start: 0px !important;
}
/* remove dropdown menu button which displays all tabs on overflow */
#alltabs-button { display: none !important }
/* fix displaying of pinned tabs on overflow */
#tabbrowser-tabs:not([secondarytext-unsupported]) .tab-label-container {
height: var(--tab-min-height) !important;
}
/* remove overflow scroll buttons */
#scrollbutton-up, #scrollbutton-down { display: none !important; }
/* remove new tab button */
#tabs-newtab-button {
display: none !important;
}
/* hide private browsing indicator */
#private-browsing-indicator-with-label {
display: none;
}
/* --- AUTOHIDE NAVBAR ---------------------------------- */
/* hide navbar unless focused */
#nav-bar {
min-height: 0 !important;
max-height: 0 !important;
height: 0 !important;
}
/* show on focus - uncomment the line below this if you want cursor hover
* events to trigger the navbar */
/* #titlebar:hover ~ .browser-toolbar, #nav-bar:hover, */
#nav-bar:focus-within {
max-height: var(--urlbar-height-setting) !important;
height: var(--urlbar-height-setting) !important;
min-height: var(--urlbar-height-setting) !important;
}
'';
search.engines = {
"Nix Packages" = {
urls = [
{
template = "https://search.nixos.org/packages?channel=unstable";
params = [
{
name = "query";
value = "{searchTerms}";
}
];
}
];
icon = "${pkgs.nixos-icons}/share/icons/hicolor/scalable/apps/nix-snowflake.svg";
definedAliases = ["@nixpkgs"];
};
"Nix Options" = {
definedAliases = ["@nixopts"];
icon = "${pkgs.nixos-icons}/share/icons/hicolor/scalable/apps/nix-snowflake.svg";
urls = [
{
template = "https://search.nixos.org/options?channel=unstable";
params = [
{
name = "query";
value = "{searchTerms}";
}
];
}
];
};
};
};
};
};
};
programs.browserpass.enable = true;
};
}