{ 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.default = "DuckDuckGo"; search.force = true; 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; }; }