diff options
Diffstat (limited to 'home')
45 files changed, 2150 insertions, 286 deletions
diff --git a/home/apps/alacritty.nix b/home/apps/alacritty.nix new file mode 100644 index 0000000..5c47f65 --- /dev/null +++ b/home/apps/alacritty.nix @@ -0,0 +1,97 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf; + cfg = config.apps.alacritty; +in { + config = mkIf cfg.enable { + default.terminal = lib.mkDefault "alacritty"; + + programs.alacritty = { + enable = true; + + settings = { + # Font + font = { + size = 11; + bold = { + style = "Bold"; + }; + bold_italic = { + style = "Bold Italic"; + }; + italic = { + style = "Italic"; + }; + normal = { + family = config.theme.font.monospace; + style = "Regular"; + }; + offset = { + x = 0; + y = 0; + }; + }; + + # Window + window = { + decorations = "full"; + dynamic_title = true; + padding = { + x = config.theme.outerGap; + y = config.theme.outerGap; + }; + opacity = config.theme.opacity; + }; + + # Colors + colors = { + normal = lib.attrsets.mapAttrs (name: color: "${color}") { + inherit + (config.theme.colors.normal) + black + red + green + yellow + blue + magenta + cyan + white + ; + }; + + bright = lib.attrsets.mapAttrs (name: color: "${color}") { + inherit + (config.theme.colors.bright) + black + red + green + yellow + blue + magenta + cyan + white + ; + }; + + cursor = { + background = "CellForeground"; + text = "CellBackground"; + }; + + selection = { + background = "CellForeground"; + text = "CellBackground"; + }; + + primary = { + foreground = "#${config.theme.colors.text}"; + background = "#${config.theme.colors.base}"; + }; + }; + }; + }; + }; +} diff --git a/home/apps/astal.nix b/home/apps/astal.nix new file mode 100644 index 0000000..0427e61 --- /dev/null +++ b/home/apps/astal.nix @@ -0,0 +1,39 @@ +{ + lib, + config, + pkgs, + inputs, + ... +}: let + astal = inputs.self.packages.${pkgs.system}; + inherit (lib) mkIf; + cfg = config.apps.astal; +in { + config = mkIf cfg.enable { + default.appLauncher = lib.mkDefault "astal-launcher"; + + home.packages = [ + astal.astal.shell + astal.astal.launcher + ]; + + systemd.user.services.astal = { + Install = { + WantedBy = [config.default.session "tray.target"]; + }; + + Unit = { + ConditionEnvironment = "WAYLAND_DISPLAY"; + Description = "astal"; + After = [config.default.session]; + PartOf = [config.default.session "tray.target"]; + }; + + Service = { + ExecStart = "${astal.astal.shell}/bin/astal-shell"; + Restart = "always"; + RestartSec = "10"; + }; + }; + }; +} diff --git a/home/apps/default.nix b/home/apps/default.nix new file mode 100644 index 0000000..d755a12 --- /dev/null +++ b/home/apps/default.nix @@ -0,0 +1,13 @@ +{lib, ...}: let + inherit (lib) mkEnableOption; +in { + imports = [ + ./waybar + ./wofi + ./alacritty.nix + ./astal.nix + ./hyprlock.nix + ./kitty.nix + ./mako.nix + ]; +} diff --git a/home/apps/hyprlock.nix b/home/apps/hyprlock.nix new file mode 100644 index 0000000..6a0119f --- /dev/null +++ b/home/apps/hyprlock.nix @@ -0,0 +1,104 @@ +{ + config, + lib, + ... +}: let + text = "rgb(${config.theme.colors.text})"; + base = "rgb(${config.theme.colors.base})"; + error = "rgb(${config.theme.colors.error})"; + trans = "rgba(0,0,0,0)"; + + inherit (lib) mkIf optionals; + cfg = config.apps.hyprlock; +in { + config = mkIf cfg.enable { + default.lockScreen = lib.mkDefault "hyprlock"; + + programs.hyprlock = { + enable = true; + + settings = { + auth = { + "pam:enabled" = true; + "fingerprint:enabled" = config.fingerprint; + }; + + animations = { + enabled = true; + animation = [ + "fadeIn, 0" + "fadeOut, 0" + ]; + }; + + background = { + path = config.theme.lockscreen; + color = base; + blur_passes = 0; + blur_size = 2; + noise = 0; + contrast = 0; + brightness = 0; + vibrancy = 0; + vibrancy_darkness = 0.0; + }; + + # Password Input + input-field = { + size = "300, 50"; + outline_thickness = 0; + dots_size = 0.25; + dots_spacing = 0.55; + dots_center = true; + dots_rounding = -1; + outer_color = trans; + inner_color = trans; + font_color = text; + fade_on_empty = false; + placeholder_text = + "Enter Password" + + ( + if config.fingerprint + then " or Touch Fingerprint" + else "" + ); + hide_input = false; + check_color = error; + fail_color = error; + capslock_color = trans; + numlock_color = trans; + bothlock_color = trans; + invert_numlock = false; + swap_font_color = false; + font_family = config.theme.font.regular; + position = "0, 50"; + halign = "center"; + valign = "bottom"; + }; + + label = [ + # Date + { + text = "cmd[update:1000] echo \"$(date +\"%A, %B %d\")\""; + color = text; + font_size = 20; + font_family = config.theme.font.header; + position = "0, -100"; + halign = "center"; + valign = "top"; + } + # Clock + { + text = "cmd[update:1000] echo \"$(date +\"%k:%M:%S\")\""; + color = text; + font_size = 90; + font_family = config.theme.font.header; + position = "0, -130"; + halign = "center"; + valign = "top"; + } + ]; + }; + }; + }; +} diff --git a/home/apps/kitty.nix b/home/apps/kitty.nix new file mode 100644 index 0000000..4253446 --- /dev/null +++ b/home/apps/kitty.nix @@ -0,0 +1,79 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf; + cfg = config.apps.kitty; +in { + config = mkIf cfg.enable { + default.terminal = lib.mkDefault "kitty"; + + programs.kitty = { + enable = true; + environment = {}; + extraConfig = ""; + + settings = { + # Font + font_family = config.theme.font.monospace; + font_size = 11; + bold_font = "auto"; + italic_font = "auto"; + bold_italic_font = "auto"; + + # Scrollback + scrollback_lines = 10000; + scrollback_pager_history_size = 300; # MB + + # Urls + detect_urls = true; + show_hyperlink_targets = false; + + # Window + window_padding_width = config.theme.outerGap; + window_border_width = 0; + draw_minimal_borders = true; + background_opacity = config.theme.opacity; + + # Disable audio + enable_audio_bell = false; + + # Disable close prompt + confirm_os_window_close = 0; + + # selection + selection_background = "#${config.theme.colors.surface}"; + selection_foreground = "none"; + + # cursor + url_color = "#${config.theme.colors.bright.yellow}"; + cursor = "#${config.theme.colors.text}"; + + # colors + background = "#${config.theme.colors.base}"; + foreground = "#${config.theme.colors.text}"; + + # normal + color0 = "#${config.theme.colors.normal.black}"; + color1 = "#${config.theme.colors.normal.red}"; + color2 = "#${config.theme.colors.normal.green}"; + color3 = "#${config.theme.colors.normal.yellow}"; + color4 = "#${config.theme.colors.normal.blue}"; + color5 = "#${config.theme.colors.normal.magenta}"; + color6 = "#${config.theme.colors.normal.cyan}"; + color7 = "#${config.theme.colors.normal.white}"; + + # bright + color8 = "#${config.theme.colors.bright.black}"; + color9 = "#${config.theme.colors.bright.red}"; + color10 = "#${config.theme.colors.bright.green}"; + color11 = "#${config.theme.colors.bright.yellow}"; + color12 = "#${config.theme.colors.bright.blue}"; + color13 = "#${config.theme.colors.bright.magenta}"; + color14 = "#${config.theme.colors.bright.cyan}"; + color15 = "#${config.theme.colors.bright.white}"; + }; + }; + }; +} diff --git a/home/apps/mako.nix b/home/apps/mako.nix new file mode 100644 index 0000000..52e7762 --- /dev/null +++ b/home/apps/mako.nix @@ -0,0 +1,33 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf; + cfg = config.apps.mako; +in { + config = mkIf cfg.enable { + services.mako = { + enable = false; # now using astal + + settings = { + font = "${config.theme.font.monospace} 11"; + + margin = toString config.theme.outerGap; + padding = toString config.theme.innerGap; + + background-color = "#${config.theme.colors.base}"; + progress-color = "#${config.theme.colors.primary}"; + text-color = "#${config.theme.colors.text}"; + + border-color = "#${config.theme.colors.text}"; + border-size = config.theme.borderWidth; + border-radius = config.theme.outerRadius; + + default-timeout = 5000; + layer = "overlay"; + icons = true; + }; + }; + }; +} diff --git a/home/apps/waybar/default.nix b/home/apps/waybar/default.nix new file mode 100644 index 0000000..25acb8f --- /dev/null +++ b/home/apps/waybar/default.nix @@ -0,0 +1,85 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf; + cfg = config.apps.waybar; +in { + config = mkIf cfg.enable { + programs.waybar = { + enable = true; + + settings = [ + { + height = 24; + layer = "top"; + position = "top"; + spacing = 4; + + modules-left = [ + "hyprland/workspaces" + ]; + modules-center = [ + "clock" + ]; + modules-right = [ + "battery" + "wireplumber" + "network" + "tray" + ]; + + "hyprland/workspaces" = { + disable-scroll = true; + all-outputs = true; + format = "{name}"; + }; + + battery = { + interval = 1; + states = { + warning = 30; + critical = 15; + }; + format = " {capacity}%"; + format-charging = " {capacity}%"; + format-plugged = " {capacity}%"; + format-full = " {capacity}%"; + format-warning = " {capacity}%"; + format-critical = " {capacity}%"; + }; + + wireplumber = { + format = " {volume}%"; + format-bluetooth = " {volume}%"; + format-muted = " muted"; + scroll-step = 1; + on-click = "pavucontrol"; + ignored-sinks = ["Easy Effects Sink"]; + }; + + network = { + format = " disconnected"; + format-wifi = " {essid}"; + format-ethernet = " {ipaddr}/{cidr}"; + format-disconnected = " disconnected"; + max-length = 50; + on-click = "nm-connection-editor"; + }; + + clock = { + interval = 1; + format = "{:%Y-%m-%d %a %H:%M:%S}"; + }; + + tray = { + spacing = config.theme.outerGap; + }; + } + ]; + + style = import ./style.nix {theme = config.theme;}; + }; + }; +} diff --git a/home/apps/waybar/style.nix b/home/apps/waybar/style.nix new file mode 100644 index 0000000..21a8de5 --- /dev/null +++ b/home/apps/waybar/style.nix @@ -0,0 +1,107 @@ +{theme}: let + text = "#${theme.colors.text}"; + base = "#${theme.colors.base}"; + surface = "#${theme.colors.surface}"; + primary = "#${theme.colors.primary}"; + success = "#${theme.colors.success}"; + warning = "#${theme.colors.warning}"; + error = "#${theme.colors.error}"; + fontSize = "${toString theme.font.size}px"; + outerGap = "${toString theme.outerGap}px"; + innerGap = "${toString theme.innerGap}px"; + outerRadius = "${toString theme.outerRadius}px"; + innerRadius = "${toString theme.innerRadius}px"; + borderWidth = "${toString theme.borderWidth}px"; +in '' + /** Base */ + + * { + all: unset; + } + + window#waybar { + font-family: "${theme.font.regular}", "${theme.font.icon}", "${theme.font.monospace}"; + font-size: ${fontSize}; + color: ${text}; + background-color: ${base}; + } + + /** Workspaces */ + + #workspaces { + margin-left: ${outerGap}; + } + + #workspaces button { + border-radius: ${innerRadius}; + margin: 4px 2px; + padding: 0px 7px; + background: ${surface}; + color: ${text}; + } + + #workspaces button.focused, + #workspaces button.active { + background: ${primary}; + color: ${base}; + } + + #workspaces button.urgent { + background: ${error}; + } + + /** Tray */ + + #tray { + border: none; + margin-right: ${outerGap}; + } + + #tray > .passive { + -gtk-icon-effect: dim; + } + + #tray > .needs-attention { + -gtk-icon-effect: highlight; + } + + /** Right modules */ + + #battery, + #wireplumber, + #network { + padding: 0 ${outerGap}; + } + + /** Battery */ + + #battery.charging { + color: ${success}; + } + + #battery.warning:not(.charging) { + color: ${warning}; + } + + #battery.critical:not(.charging) { + color: ${error}; + } + + /** Wireplumber */ + + #wireplumber.muted { + color: ${error}; + } + + /** Network */ + + #network.wifi, + #network.ethernet { + color: ${success}; + } + + #network.disconnected { + color: ${error}; + } + +'' diff --git a/home/apps/wofi/default.nix b/home/apps/wofi/default.nix new file mode 100644 index 0000000..2de9f45 --- /dev/null +++ b/home/apps/wofi/default.nix @@ -0,0 +1,27 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf; + cfg = config.apps.wofi; +in { + config = mkIf cfg.enable { + default.appLauncher = lib.mkDefault "wofi --show drun --prompt 'Seach Programs'"; + + programs.wofi = { + enable = true; + + settings = { + key_expand = "Tab"; + term = "kitty"; + matching = "multi-contains"; + insensitive = true; + gtk_dark = true; + hide_scroll = true; + }; + + style = import ./style.nix {theme = config.theme;}; + }; + }; +} diff --git a/home/apps/wofi/style.nix b/home/apps/wofi/style.nix new file mode 100644 index 0000000..75a0a21 --- /dev/null +++ b/home/apps/wofi/style.nix @@ -0,0 +1,73 @@ +{theme}: let + text = "#${theme.colors.text}"; + base = "#${theme.colors.base}"; + surface = "#${theme.colors.surface}"; + primary = "#${theme.colors.primary}"; + fontSize = "${toString theme.font.size}px"; + outerGap = "${toString theme.outerGap}px"; + innerGap = "${toString theme.innerGap}px"; + outerRadius = "${toString theme.outerRadius}px"; + innerRadius = "${toString theme.innerRadius}px"; + borderWidth = "${toString theme.borderWidth}px"; +in '' + * { + font-family: ${theme.font.monospace}; + font-size: ${fontSize}; + } + + /* Window */ + window { + margin: 0px; + border: ${borderWidth} solid ${primary}; + border-radius: ${outerRadius}; + background-color: ${base}; + } + + /* Outer Box */ + #outer-box { + padding: ${outerGap}; + } + + /* Scroll */ + #scroll { + margin: 0px; + padding: ${innerGap}; + border: none; + } + + /* Input */ + #input { + margin: ${innerGap}; + padding: ${innerGap}; + border: none; + color: ${text}; + background-color: ${surface}; + border-radius: ${outerRadius}; + } + + #input:focus, + #input:active { + border: ${borderWidth} solid ${primary}; + box-shadow: none; + outline: none; + } + + /* Text */ + #text { + margin: ${innerGap}; + padding: ${innerGap}; + border: none; + color: ${text}; + } + + /* Selected Entry */ + #entry:selected { + background-color: ${primary}; + border-radius: ${outerRadius}; + } + + #entry:selected #text { + color: ${base}; + } + +'' diff --git a/home/browsers/default.nix b/home/browsers/default.nix new file mode 100644 index 0000000..dc74460 --- /dev/null +++ b/home/browsers/default.nix @@ -0,0 +1,6 @@ +{...}: { + imports = [ + ./firefox + ./zen.nix + ]; +} diff --git a/home/browsers/firefox/default.nix b/home/browsers/firefox/default.nix new file mode 100644 index 0000000..608d4c5 --- /dev/null +++ b/home/browsers/firefox/default.nix @@ -0,0 +1,37 @@ +{ + config, + lib, + pkgs, + ... +}: let + extraPrefs = lib.fileContents ./mozilla.cfg; + userChrome = lib.fileContents ./userChrome.css; + my-firefox = pkgs.firefox.override { + extraPrefs = extraPrefs; + }; + + inherit (lib) mkIf; + cfg = config.browsers.firefox; +in { + config = mkIf cfg.enable { + default.browser = lib.mkDefault "firefox"; + + programs.firefox = { + enable = true; + package = my-firefox; + + # import configuration + policies = import ./policies.nix; + + # create profile for me :3 + profiles.${config.user} = { + search = { + force = true; + default = "ddg"; + }; + + userChrome = userChrome; + }; + }; + }; +} diff --git a/home/browsers/firefox/extensions.nix b/home/browsers/firefox/extensions.nix new file mode 100644 index 0000000..e8d6e2c --- /dev/null +++ b/home/browsers/firefox/extensions.nix @@ -0,0 +1,44 @@ +{ + # extensions to be auto downloaded into + # firefox + + # dont allow extensions to be installed though + # firefox, they must be described here! + "*".installation_mode = "blocked"; + + # uBlock Origin + "uBlock0@raymondhill.net" = { + install_url = "https://addons.mozilla.org/firefox/downloads/latest/ublock-origin/latest.xpi"; + installation_mode = "force_installed"; + }; + + # Bitwarden + "{446900e4-71c2-419f-a6a7-df9c091e268b}" = { + install_url = "https://addons.mozilla.org/firefox/downloads/latest/bitwarden-password-manager/latest.xpi"; + installation_mode = "force_installed"; + }; + + # SponsorBlock + "sponsorBlocker@ajay.app" = { + install_url = "https://addons.mozilla.org/firefox/downloads/latest/sponsorblock/latest.xpi"; + installation_mode = "force_installed"; + }; + + # Privacy Badger + "jid1-MnnxcxisBPnSXQ@jetpack" = { + install_url = "https://addons.mozilla.org/firefox/downloads/latest/privacy-badger17/latest.xpi"; + installation_mode = "force_installed"; + }; + + # Redirector + "redirector@einaregilsson.com" = { + install_url = "https://addons.mozilla.org/firefox/downloads/latest/redirector/latest.xpi"; + installation_mode = "force_installed"; + }; + + # Enhancer for Youtube + "enhancerforyoutube@maximerf.addons.mozilla.org" = { + install_url = "https://www.mrfdev.com/downloads/enhancer_for_youtube-2.0.130.1.xpi"; + installation_mode = "force_installed"; + }; +} diff --git a/home/browsers/firefox/mozilla.cfg b/home/browsers/firefox/mozilla.cfg new file mode 100644 index 0000000..5e2334e --- /dev/null +++ b/home/browsers/firefox/mozilla.cfg @@ -0,0 +1,21 @@ +// +// extra preferences that cannot be +// set normally but have to instead +// set in mozilla.cfg + +// Automatically click cookiebanners although uBlock Origin might block them +lockPref("cookiebanners.bannerClicking.enabled", true); +lockPref("cookiebanners.service.mode", 2); +lockPref("cookiebanners.service.mode.privateBrowsing", 2); + +// DNT although PrivacyBadger from policy handles this +lockPref("privacy.donottrackheader.enabled", true); +lockPref("privacy.donottrackheader.value", 1); + +// New sidebar +lockPref("sidebar.revamp", true); +lockPref("sidebar.verticalTabs", true); +lockPref("sidebar.visibility", "always-show"); +lockPref("sidebar.main.tools", "history,bookmarks"); + +// diff --git a/home/browsers/firefox/policies.nix b/home/browsers/firefox/policies.nix new file mode 100644 index 0000000..243cd9a --- /dev/null +++ b/home/browsers/firefox/policies.nix @@ -0,0 +1,127 @@ +{ + # policies to be set in firefox + # see: https://mozilla.github.io/policy-templates/ + + ExtensionSettings = import ./extensions.nix; + Preferences = import ./prefs.nix; + + EnableTrackingProtection = { + Value = true; + Locked = true; + Cryptomining = true; + Fingerprinting = true; + EmailTracking = true; + }; + + # Certificates + Certificates = { + ImportEnterpriseRoots = true; + }; + + # Cookies + Cookies = { + Behavior = "reject-foreign"; + BehaviorPrivateBrowsing = "reject-foreign"; + Locked = true; + }; + + # DNS + DNSOverHTTPS = { + Enabled = false; + Locked = true; + }; + + # Disable Bad + DisableAppUpdate = true; + DisableAccounts = true; + DisableFirefoxAccounts = true; + DisableFirefoxScreenshots = true; + DisableFirefoxStudies = true; + DisablePocket = true; + DisableTelemetry = true; + AutofillAddressEnabled = false; + AutofillCreditCardEnabled = false; + + # Disable Certain Messages + UserMessaging = { + WhatsNew = false; + ExtensionRecommendations = false; + FeatureRecommendations = false; + UrlbarInterventions = false; + SkipOnboarding = true; + MoreFromMozilla = false; + Labs = false; + Locked = true; + }; + + # Disable Password Manager + DisableMasterPasswordCreation = true; + PasswordManagerEnabled = false; + PrimaryPassword = false; + OfferToSaveLogins = false; + + # Remove Special Pages + OverrideFirstRunPage = ""; + OverridePostUpdatePage = ""; + + # Start Page + Homepage = { + StartPage = "previous-session"; + Locked = true; + }; + + # Home Page + FirefoxHome = { + Search = true; + TopSites = false; + SponsoredTopSites = false; + Highlights = false; + Pocket = false; + SponsoredPocket = false; + Snippets = false; + Locked = true; + }; + + # Search Suggestions + SearchSuggestEnabled = true; + FirefoxSuggest = { + WebSuggestions = false; + SponsoredSuggestions = false; + ImproveSuggest = false; + Locked = true; + }; + + # Save All on Shutdown + SanitizeOnShutdown = false; + + # Popups + PopupBlocking = { + Default = true; + Locked = true; + }; + + # Allow Bypasses + DisableSecurityBypass = { + InvalidCertificate = false; + SafeBrowsing = false; + }; + + # PictureInPicure + PictureInPicture = { + Enabled = true; + Locked = true; + }; + + # Topbar + SearchBar = "unified"; + DisplayMenuBar = "default-off"; + DisplayBookmarksToolbar = "newtab"; + NoDefaultBookmarks = true; + + # Miscellaneous + HttpsOnlyMode = "force_enabled"; + HardwareAcceleration = true; + DontCheckDefaultBrowser = true; + PromptForDownloadLocation = false; + PrivateBrowsingModeAvailability = 0; +} diff --git a/home/browsers/firefox/prefs.nix b/home/browsers/firefox/prefs.nix new file mode 100644 index 0000000..73d2781 --- /dev/null +++ b/home/browsers/firefox/prefs.nix @@ -0,0 +1,128 @@ +let + # quick variables to specify + # locked true/false + lock-false = { + Value = false; + Status = "locked"; + }; + lock-true = { + Value = true; + Status = "locked"; + }; +in { + # about:config Preferences + # ... set policies that cannot be set using policies.json directly + + # allow userChrom.css + "toolkit.legacyUserProfileCustomizations.stylesheets" = lock-true; + + # dark theme + "extensions.activeThemeID" = { + Value = "firefox-compact-dark@mozilla.org"; + Status = "locked"; + }; + "layout.css.prefers-color-scheme.content-override" = { + Value = 0; + Status = "locked"; + }; + + # homepage + "browser.startup.homepage" = { + Value = "about:home"; + Status = "locked"; + }; + "browser.newtabpage.enabed" = lock-true; + "browser.newtabpage.url" = { + Value = "about:home"; + Status = "locked"; + }; + + # autofill + "browser.autofill.enabled" = lock-false; + "browser.formfill.enable" = lock-false; + + # search enable + "browser.urlbar.suggest.recentsearches" = lock-true; + "browser.urlbar.suggest.bookmark" = lock-true; + "browser.urlbar.suggest.clipboard" = lock-true; + "browser.urlbar.suggest.history" = lock-true; + + # search disable + "browser.urlbar.suggest.addons" = lock-false; + "browser.urlbar.suggest.calculator" = lock-false; + "browser.urlbar.suggest.engines" = lock-false; + "browser.urlbar.suggest.fakespot" = lock-false; + "browser.urlbar.suggest.mdn" = lock-false; + "browser.urlbar.suggest.openpage" = lock-false; + "browser.urlbar.suggest.pocket" = lock-false; + "browser.urlbar.suggest.remotetab" = lock-false; + "browser.urlbar.suggest.topsites" = lock-false; + "browser.urlbar.suggest.trending" = lock-false; + "browser.urlbar.suggest.weather" = lock-false; + "browser.urlbar.suggest.yelp" = lock-false; + + # privacy + "privacy.globalprivacycontrol.enabled" = lock-true; + + # security + "security.OCSP.enabled" = { + Value = 0; + Status = "locked"; + }; + "browser.contentblocking.category" = { + Value = "strict"; + Status = "locked"; + }; + "xpinstall.whitelist.required" = lock-true; + "signon.management.page.breach-alerts.enabled" = lock-false; + + # graphics + "dom.webgpu.enabled" = lock-true; + "media.eme.enabled" = lock-true; + + # user messaging + # ... disable shit that is annoying + "browser.newtabpage.activity-stream.feeds.section.topstories" = lock-false; + "browser.newtabpage.activity-stream.feeds.snippets" = lock-false; + "browser.newtabpage.activity-stream.section.highlights.includePocket" = lock-false; + "browser.newtabpage.activity-stream.section.highlights.includeBookmarks" = lock-false; + "browser.newtabpage.activity-stream.section.highlights.includeDownloads" = lock-false; + "browser.newtabpage.activity-stream.section.highlights.includeVisited" = lock-false; + "browser.newtabpage.activity-stream.showSponsored" = lock-false; + "browser.newtabpage.activity-stream.system.showSponsored" = lock-false; + "browser.newtabpage.activity-stream.showSponsoredTopSites" = lock-false; + "browser.newtabpage.activity-stream.showWeather" = lock-false; + "browser.newtabpage.activity-stream.newtabWallpapers.enabled" = lock-false; + "browser.newtabpage.activity-stream.newtabWallpapers.v2.enabled" = lock-false; + "browser.newtabpage.activity-stream.default.sites" = { + Value = ""; + Status = "locked"; + }; + + # safebrowsing + "browser.safebrowsing.malware.enabled" = lock-true; + "browser.safebrowsing.phishing.enabled" = lock-true; + "browser.safebrowsing.downloads.enabled" = lock-true; + "browser.safebrowsing.downloads.remote.block_uncommon" = lock-false; + "browser.safebrowsing.downloads.remote.block_potentially_unwanted" = lock-false; + + # sidebar + "browser.tabs.inTitlebar" = { + Value = 0; + Status = "locked"; + }; + "browser.tabs.warnOnClose" = lock-true; + "browser.tabs.firefox-view" = lock-false; + "browser.tabs.closeTabByDblclick" = lock-true; + "ui.key.menuAccessKeyFocuses" = lock-false; + + # general settings + "general.autoScroll" = lock-false; + "general.smoothScroll" = lock-true; + "widget.gtk.overlay-scrollbars.enabled" = lock-false; + "accessibility.browsewithcaret" = lock-false; + "accessibility.typeaheadfind" = lock-false; + "media.hardwaremediakeys.enabled" = lock-true; + "browser.crashReports.unsubmittedCheck.autoSubmit2" = lock-false; + "browser.aboutConfig.showWarning" = lock-false; +} diff --git a/home/browsers/firefox/userChrome.css b/home/browsers/firefox/userChrome.css new file mode 100644 index 0000000..e630632 --- /dev/null +++ b/home/browsers/firefox/userChrome.css @@ -0,0 +1,23 @@ + +/* sidebar hack to flip contents the way i want them (arrows on the left) */ +#nav-bar-customization-target { + flex-direction: row-reverse; +} + +/* remove broken padding from sidebar hack */ +#unified-extensions-button { + padding-left: 0 !important; +} + +/* remove padding beside search bar */ +toolbarspring { + display: none !important; +} + +/* remove overflow menu and everything in it */ +#nav-bar-overflow-button, +#firefox-view-button, +#alltabs-button { + visibility: collapse; +} + diff --git a/home/browsers/zen.nix b/home/browsers/zen.nix new file mode 100644 index 0000000..3797a64 --- /dev/null +++ b/home/browsers/zen.nix @@ -0,0 +1,32 @@ +{ + config, + lib, + inputs, + ... +}: let + inherit (lib) mkIf; + cfg = config.browsers.zen; +in { + #imports = [ + # inputs.zen-browser.homeModules.default + #]; + + #config = mkIf cfg.enable { + # default.browser = lib.mkDefault "zen"; + + # programs.zen-browser = { + # enable = true; + + # # import configuration + # policies = import ./firefox/policies.nix; + + # # create profile for me :3 + # profiles.${config.user} = { + # search = { + # force = true; + # default = "ddg"; + # }; + # }; + # }; + #}; +} diff --git a/home/default.nix b/home/default.nix index 1b4f909..6ea1b04 100644 --- a/home/default.nix +++ b/home/default.nix @@ -3,138 +3,123 @@ config, pkgs, inputs, - system, ... }: let inherit (lib) optionals; in { imports = [ - inputs.home-manager.nixosModules.home-manager + ./apps + ./browsers + ./desktops ./gtk ./neovim ./ssh ./tmux ./zsh + ./development.nix ./git.nix ./gpg.nix ./starship.nix ]; - # use system packages in home manager - home-manager.useGlobalPkgs = true; + home.username = config.user; + home.homeDirectory = config.homePath; + home.stateVersion = config.stateVersion; - # install user packages to /etc/profiles and not home directory - home-manager.useUserPackages = true; + news.display = "silent"; + fonts.fontconfig.enable = true; - home-manager.users.root = { - home.stateVersion = config.stateVersion; - }; - - home-manager.users.${config.user} = { - home.username = config.user; - home.homeDirectory = config.homePath; - home.stateVersion = config.stateVersion; - - news.display = "silent"; - fonts.fontconfig.enable = true; + home.packages = + (with pkgs; [ + home-manager + pfetch-rs + yt-dlp + ]) + ++ [ + inputs.talc.packages.${pkgs.system}.talc + ] + ++ (with pkgs; + optionals config.desktops.enable [ + # social + discord + element-desktop + gajim + thunderbird-latest + # programs + brightnessctl + easyeffects + filezilla + gimp3 + imv + mpv + pavucontrol + vlc + zathura + # media + ffmpeg + imagemagick + ]); - home.packages = - (with pkgs; [ - home-manager - pfetch-rs - yt-dlp - ]) - ++ [ - inputs.talc.packages.${system}.talc - ] - ++ (with pkgs; - optionals config.desktops.enable [ - # social - discord - element-desktop - gajim - thunderbird-latest - # programs - brightnessctl - easyeffects - filezilla - gimp3 - imv - mpv - pavucontrol - vlc - zathura - # media - ffmpeg - imagemagick - ]); - - xdg.configFile = { - "aacs/keydb.cfg" = { - source = ../files/keys/bluray.cfg; - }; + xdg.configFile = { + "aacs/keydb.cfg" = { + source = ../files/keys/bluray.cfg; }; + }; - xdg.dataFile = { - fonts = { - source = ../files/fonts; - recursive = true; - }; + xdg.dataFile = { + fonts = { + source = ../files/fonts; + recursive = true; }; + }; - xdg.mimeApps = { - enable = true; - defaultApplications = { - # web - "text/html" = "firefox.desktop"; - "x-scheme-handler/http" = "firefox.desktop"; - "x-scheme-handler/https" = "firefox.desktop"; - "x-scheme-handler/about" = "firefox.desktop"; - "x-scheme-handler/unknown" = "firefox.desktop"; - - # images - "image/png" = "imv.desktop"; - "image/jpeg" = "imv.desktop"; - "image/webp" = "imv.desktop"; - "image/tga" = "imv.desktop"; - "image/bmp" = "imv.desktop"; - "image/gif" = "imv.desktop"; - - # audio video - "video/mp4" = "mpv.desktop"; - "video/x-msvideo" = "mpv.desktop"; - "video/mkv" = "mpv.desktop"; - "video/webm" = "mpv.desktop"; - "audio/mp3" = "mpv.desktop"; - "audio/wav" = "mpv.desktop"; + xdg.mimeApps = { + enable = true; + defaultApplications = { + # web + "text/html" = "firefox.desktop"; + "x-scheme-handler/http" = "firefox.desktop"; + "x-scheme-handler/https" = "firefox.desktop"; + "x-scheme-handler/about" = "firefox.desktop"; + "x-scheme-handler/unknown" = "firefox.desktop"; - # other - "application/pdf" = "org.pwmt.zathura.desktop"; - "x-scheme-handler/mspa" = "unofficial-homestuck-collection.desktop"; - "x-scheme-handler/discord" = "discord.desktop"; - "x-scheme-handler/roblox-player" = "org.vinegarhq.Sober.desktop"; - }; - }; + # images + "image/png" = "imv.desktop"; + "image/jpeg" = "imv.desktop"; + "image/webp" = "imv.desktop"; + "image/tga" = "imv.desktop"; + "image/bmp" = "imv.desktop"; + "image/gif" = "imv.desktop"; - xdg.userDirs = { - enable = true; - createDirectories = false; + # audio video + "video/mp4" = "mpv.desktop"; + "video/x-msvideo" = "mpv.desktop"; + "video/mkv" = "mpv.desktop"; + "video/webm" = "mpv.desktop"; + "audio/mp3" = "mpv.desktop"; + "audio/wav" = "mpv.desktop"; - desktop = "${config.homePath}/desktop"; - documents = "${config.homePath}/documents"; - download = "${config.homePath}/downloads"; - music = "${config.homePath}/music"; - pictures = "${config.homePath}/pictures"; - publicShare = "${config.homePath}"; - templates = "${config.homePath}"; - videos = "${config.homePath}/videos"; + # other + "application/pdf" = "org.pwmt.zathura.desktop"; + "x-scheme-handler/mspa" = "unofficial-homestuck-collection.desktop"; + "x-scheme-handler/discord" = "discord.desktop"; + "x-scheme-handler/roblox-player" = "org.vinegarhq.Sober.desktop"; }; + }; - gtk = { - enable = true; - gtk3.extraConfig.gtk-application-prefer-dark-theme = 1; - }; + xdg.userDirs = { + enable = true; + createDirectories = false; - programs.home-manager.enable = true; + desktop = "${config.homePath}/desktop"; + documents = "${config.homePath}/documents"; + download = "${config.homePath}/downloads"; + music = "${config.homePath}/music"; + pictures = "${config.homePath}/pictures"; + publicShare = "${config.homePath}"; + templates = "${config.homePath}"; + videos = "${config.homePath}/videos"; }; + + programs.home-manager.enable = true; } diff --git a/home/desktops/default.nix b/home/desktops/default.nix new file mode 100644 index 0000000..9c17bb0 --- /dev/null +++ b/home/desktops/default.nix @@ -0,0 +1,81 @@ +{ + lib, + config, + pkgs, + inputs, + ... +}: let + inherit (lib) mkEnableOption mkIf optionals; + cfg = config.desktops; +in { + imports = [ + ./hyprland + ./sway + ]; + + config = mkIf cfg.enable { + # desktop specific programs + home.packages = + (with pkgs; [ + # gtk + adwaita-icon-theme + # codecs + libaacs + libavif + libbluray + libjxl + # wayland + cage + grimblast + wl-clipboard + wl-clip-persist + wl-mirror + # xdg + libnotify + # fonts + corefonts + dejavu_fonts + fira-code + fira-code-symbols + jetbrains-mono + material-icons + nerd-fonts.fira-code + noto-fonts + noto-fonts-cjk-sans + noto-fonts-emoji + twemoji-color-font + vistafonts + ]) + ++ (with inputs.apple-fonts.packages.${pkgs.system}; [ + # apple fonts + sf-pro + sf-mono + sf-compact + ]); + + fonts.fontconfig = { + enable = true; + defaultFonts = { + serif = [ + "Twemoji" + "DejaVu Serif" + ]; + sansSerif = [ + "Twemoji" + "DejaVu Sans" + ]; + monospace = [ + "Fira Code" + "FiraCode Nerd Font Mono" + "Font Awesome 6 Pro Regular" + "Twemoji" + "DejaVu Sans Mono" + ]; + emoji = [ + "Twemoji" + "Noto Color Emoji" + ]; + }; + }; + }; +} diff --git a/home/desktops/hyprland/binds.nix b/home/desktops/hyprland/binds.nix new file mode 100644 index 0000000..94e0f39 --- /dev/null +++ b/home/desktops/hyprland/binds.nix @@ -0,0 +1,139 @@ +{config, ...}: { + wayland.windowManager.hyprland.settings = { + # Keybinds + "$mod" = "SUPER"; + bind = [ + # Launch programs + + "$mod, W, exec, ${config.default.browser}" + "$mod, D, exec, ${config.default.appLauncher}" + "$mod, L, exec, ${config.default.lockScreen}" + "$mod, Return, exec, ${config.default.terminal}" + ", Print, exec, grimblast copy area" + + # Misc + + "$mod SHIFT, L, exit" + "$mod, tab, hyprexpo:expo, toggle" + + # Window operations + + "$mod SHIFT, Q, killactive" + "$mod SHIFT, SPACE, togglefloating" + "$mod, F, fullscreen" + "$mod, J, togglesplit" + + # Move focus with mod + arrow keys + + "$mod, left, movefocus, l" + "$mod, right, movefocus, r" + "$mod, up, movefocus, u" + "$mod, down, movefocus, d" + + # Move window across workspace with mod + arrow keys + + "$mod SHIFT, left, hy3:movewindow, l" + "$mod SHIFT, right, hy3:movewindow, r" + "$mod SHIFT, up, hy3:movewindow, u" + "$mod SHIFT, down, hy3:movewindow, d" + + # Switch workspaces with mod + [0-9] + + "$mod, 1, workspace, 1" + "$mod, 2, workspace, 2" + "$mod, 3, workspace, 3" + "$mod, 4, workspace, 4" + "$mod, 5, workspace, 5" + "$mod, 6, workspace, 6" + "$mod, 7, workspace, 7" + "$mod, 8, workspace, 8" + "$mod, 9, workspace, 9" + + # Move active window to a workspace with mod + SHIFT + [0-9] + + "$mod SHIFT, 1, movetoworkspacesilent, 1" + "$mod SHIFT, 2, movetoworkspacesilent, 2" + "$mod SHIFT, 3, movetoworkspacesilent, 3" + "$mod SHIFT, 4, movetoworkspacesilent, 4" + "$mod SHIFT, 5, movetoworkspacesilent, 5" + "$mod SHIFT, 6, movetoworkspacesilent, 6" + "$mod SHIFT, 7, movetoworkspacesilent, 7" + "$mod SHIFT, 8, movetoworkspacesilent, 8" + "$mod SHIFT, 9, movetoworkspacesilent, 9" + "$mod SHIFT, 0, movetoworkspacesilent, 10" + + # Move to tab + + "LALT, 1, hy3:focustab, index, 01" + "LALT, 2, hy3:focustab, index, 02" + "LALT, 3, hy3:focustab, index, 03" + "LALT, 4, hy3:focustab, index, 04" + "LALT, 5, hy3:focustab, index, 05" + "LALT, 6, hy3:focustab, index, 06" + "LALT, 7, hy3:focustab, index, 07" + "LALT, 8, hy3:focustab, index, 08" + "LALT, 9, hy3:focustab, index, 09" + "LALT, 0, hy3:focustab, index, 10" + + "$mod SHIFT, B, hy3:makegroup, h" + "$mod SHIFT, V, hy3:makegroup, v" + "$mod SHIFT, C, hy3:changegroup, toggletab" + + # Scroll through existing workspaces with mod + scroll + + "$mod, mouse_down, workspace, e+1" + "$mod, mouse_up, workspace, e-1" + ]; + + bindn = [ + # Focus windows with scroll wheel or middle click + + ", mouse:272, hy3:focustab, mouse" + ", mouse_down, hy3:focustab, l, require_hovered" + ", mouse_up, hy3:focustab, r, require_hovered" + ]; + + bindm = [ + # Move/resize windows with mod + LMB/RMB and dragging + + "$mod, mouse:272, movewindow" + "$mod, mouse:273, resizewindow" + ]; + + binde = [ + # Audio + + # raise volume + ", XF86AudioRaiseVolume, exec, wpctl set-volume -l 1.5 @DEFAULT_AUDIO_SINK@ 5%+" + # lower volume + ", XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-" + # mute speaker + ", XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle" + # mute mic + ", XF86AudioMicMute, exec, wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle" + + # Media + + # play + ", XF86AudioPlay, exec, playerctl play-pause" + # next + ", XF86AudioNext, exec, playerctl next" + # prev + ", XF86AudioPrev, exec, playerctl previous" + + # Backlight + + ", XF86MonBrightnessDown, exec, brightnessctl set 5%-" + ", XF86MonBrightnessUp, exec, brightnessctl set 5%+" + ]; + + bindl = let + monitor = builtins.elemAt config.monitors 0; + cfg = "highres, auto, ${toString monitor.scale}, bitdepth, ${toString monitor.bitdepth}"; + in [ + # Laptops when docked + ", switch:on:Lid, exec, hyprctl keyword monitor \"${monitor.name}, disable\"" + ", switch:off:Lid, exec, hyprctl keyword monitor \"${monitor.name}, ${cfg}\"" + ]; + }; +} diff --git a/home/desktops/hyprland/default.nix b/home/desktops/hyprland/default.nix new file mode 100644 index 0000000..53a1d2a --- /dev/null +++ b/home/desktops/hyprland/default.nix @@ -0,0 +1,33 @@ +{ + inputs, + config, + pkgs, + lib, + ... +}: let + inherit (lib) mkIf mkDefault; + cfg = config.desktops.hyprland; +in { + imports = [ + ./binds.nix + ./env.nix + ./idle.nix + ./plugins.nix + ./settings.nix + ./wallpaper.nix + ]; + + config = mkIf cfg.enable { + home.packages = [ + inputs.rose-pine-hyprcursor.packages.${pkgs.system}.default + ]; + + wayland.windowManager.hyprland = { + enable = true; + package = inputs.hyprland.packages.${pkgs.system}.hyprland; + + xwayland.enable = true; + systemd.enable = true; + }; + }; +} diff --git a/home/desktops/hyprland/env.nix b/home/desktops/hyprland/env.nix new file mode 100644 index 0000000..620efd9 --- /dev/null +++ b/home/desktops/hyprland/env.nix @@ -0,0 +1,14 @@ +{config, ...}: { + wayland.windowManager.hyprland.settings = { + env = [ + "XDG_CURRENT_DESKTOP,Hyprland" + "XDG_SESSION_TYPE,wayland" + "XDG_SESSION_DESKTOP,Hyprland" + "MOZ_ENABLE_WAYLAND,1" + "NIXOS_OZONE_WL,1" + + "HYPRCURSOR_THEME,rose-pine-hyprcursor" + "HYPRCURSOR_SIZE,24" + ]; + }; +} diff --git a/home/desktops/hyprland/idle.nix b/home/desktops/hyprland/idle.nix new file mode 100644 index 0000000..0a2b951 --- /dev/null +++ b/home/desktops/hyprland/idle.nix @@ -0,0 +1,35 @@ +{config, ...}: { + services.hypridle = { + enable = config.desktops.hyprland.enable; + systemdTarget = "hyprland-session.target"; + + settings = { + general = { + lock_cmd = "pidof ${config.default.lockScreen} || ${config.default.lockScreen}"; + before_sleep_cmd = "loginctl lock-session"; + after_sleep_cmd = "hyprctl dispatch dpms on"; + ignore_dbus_inhibit = false; + }; + + listener = [ + # dim screen + { + timeout = 150; + on-timeout = "brightnessctl -s set 10"; + on-resume = "brightnessctl -r"; + } + # lock + { + timeout = 300; + on-timeout = "loginctl lock-session"; + } + # turn off screen + { + timeout = 350; + on-timeout = "hyprctl dispatch dpms off"; + on-resume = "hyprctl dispatch dpms on"; + } + ]; + }; + }; +} diff --git a/home/desktops/hyprland/plugins.nix b/home/desktops/hyprland/plugins.nix new file mode 100644 index 0000000..0440e12 --- /dev/null +++ b/home/desktops/hyprland/plugins.nix @@ -0,0 +1,40 @@ +{ + inputs, + config, + pkgs, + ... +}: { + wayland.windowManager.hyprland = { + plugins = [ + inputs.hyprland-plugins.packages.${pkgs.system}.hyprexpo + inputs.hy3.packages.${pkgs.system}.hy3 + ]; + + settings.plugin = { + # hy3 + hy3 = { + tabs = { + height = 24; + text_height = 9; + text_padding = 10; + padding = 2; + render_text = true; + text_font = "monospace"; + radius = config.theme.outerRadius; + border_width = config.theme.borderWidth; + + "col.active" = "rgb(${config.theme.colors.base})"; + "col.active.border" = "rgb(${config.theme.colors.primary})"; + "col.active.text" = "rgb(${config.theme.colors.text})"; + "col.inactive" = "rgb(${config.theme.colors.base})"; + "col.inactive.border" = "rgb(${config.theme.colors.surface})"; + "col.inactive.text" = "rgb(${config.theme.colors.text})"; + }; + + autotile = { + enable = true; + }; + }; + }; + }; +} diff --git a/home/desktops/hyprland/settings.nix b/home/desktops/hyprland/settings.nix new file mode 100644 index 0000000..daaf749 --- /dev/null +++ b/home/desktops/hyprland/settings.nix @@ -0,0 +1,125 @@ +{ + config, + pkgs, + lib, + inputs, + ... +}: { + wayland.windowManager.hyprland = { + importantPrefixes = [ + "bezier" + "enabled" + "output" + ]; + + settings = { + # Monitors + monitorv2 = + map (monitor: { + output = monitor.name; + mode = "highres"; + scale = toString monitor.scale; + bitdepth = toString monitor.bitdepth; + }) + config.monitors; + + # Autostart + exec-once = config.autoRun; + + # General + general = { + gaps_in = config.theme.innerGap; + gaps_out = config.theme.outerGap; + layout = "hy3"; + resize_on_border = "yes"; + extend_border_grab_area = 20; + border_size = config.theme.borderWidth; + "col.active_border" = "rgb(${config.theme.colors.primary})"; + "col.inactive_border" = "rgb(${config.theme.colors.surface})"; + }; + + # Gestures + gestures = { + workspace_swipe = true; + workspace_swipe_fingers = 3; + workspace_swipe_forever = true; + workspace_swipe_cancel_ratio = 0.15; + }; + + # Decoration + decoration = { + rounding = config.theme.outerRadius; + shadow.enabled = false; + blur = { + enabled = config.theme.blur; + size = 4; + passes = 2; + noise = 0.008; + contrast = 0.8916; + brightness = 0.8; + }; + }; + + animations = { + enabled = true; + + bezier = [ + "windowIn, 0.06, 0.71, 0.25, 1" + "windowResize, 0.04, 0.67, 0.38, 1" + ]; + + animation = [ + "windowsIn, 1, 3, windowIn, slide #popin 20%" + "windowsOut, 1, 3, windowIn, slide #popin 70%" + "windowsMove, 1, 2.5, windowResize" + "border, 1, 10, default" + "borderangle, 1, 8, default" + "fade, 1, 3, default" + "workspaces, 1, 6, default" + "layers, 1, 5, windowIn, slide" + ]; + }; + + # Input + input = { + kb_layout = "us"; + kb_variant = ""; + kb_model = ""; + kb_options = "gtp:alt_shift_toggle, compose:ralt"; + kb_rules = ""; + follow_mouse = 1; + touchpad = { + natural_scroll = "yes"; + }; + sensitivity = 0; + }; + + # XWayland + xwayland = { + force_zero_scaling = "true"; + use_nearest_neighbor = "false"; + }; + + # Misc + misc = { + disable_hyprland_logo = true; + disable_splash_rendering = true; + key_press_enables_dpms = true; + mouse_move_enables_dpms = true; + enable_anr_dialog = false; + vrr = 1; + }; + + # Ecosystem + ecosystem = { + no_update_news = true; + no_donation_nag = true; + }; + + # Experimental + experimental = { + xx_color_management_v4 = true; + }; + }; # end settings + }; # end hyprland +} diff --git a/home/desktops/hyprland/wallpaper.nix b/home/desktops/hyprland/wallpaper.nix new file mode 100644 index 0000000..e8fc861 --- /dev/null +++ b/home/desktops/hyprland/wallpaper.nix @@ -0,0 +1,11 @@ +{config, ...}: { + services.hyprpaper = { + enable = config.desktops.hyprland.enable; + + settings = { + preload = config.theme.wallpaper; + wallpaper = ",${config.theme.wallpaper}"; + splash = false; + }; + }; +} diff --git a/home/desktops/sway/binds.nix b/home/desktops/sway/binds.nix new file mode 100644 index 0000000..d35f0a7 --- /dev/null +++ b/home/desktops/sway/binds.nix @@ -0,0 +1,89 @@ +{config, ...}: let + mod = "Mod4"; +in { + wayland.windowManager.sway = { + config = { + keybindings = { + # apps + "${mod}+Return" = "exec ${config.default.terminal}"; + "${mod}+l" = "exec ${config.default.lockScreen}"; + "${mod}+d" = "exec ${config.default.appLauncher}"; + "${mod}+w" = "exec ${config.default.browser}"; + + # exit + "${mod}+Shift+l" = "exit"; + # kill focused window + "${mod}+Shift+q" = "kill"; + # reload sway + "${mod}+F5" = "reload"; + + # audio + "XF86AudioRaiseVolume" = "exec, wpctl set-volume -l 1.5 @DEFAULT_AUDIO_SINK@ 5%+"; + "XF86AudioLowerVolume" = "exec wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"; + "XF86AudioMute" = "exec wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"; + "XF86AudioMicMute" = "exec wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle"; + + # media + "XF86AudioPlay" = "exec playerctl play-pause"; + "XF86AudioNext" = "exec playerctl next"; + "XF86AudioPrev" = "exec playerctl previous"; + + # backlight + "XF86MonBrightnessDown" = "exec brightnessctl set 5%-"; + "XF86MonBrightnessUp" = "exec brightnessctl set 5%+"; + + # screenshot + "Print" = "exec grimblast copy area"; + + # move focus + "${mod}+Left" = "focus left"; + "${mod}+Down" = "focus down"; + "${mod}+Up" = "focus up"; + "${mod}+Right" = "focus right"; + + # move focused window + "${mod}+Shift+Left" = "move left"; + "${mod}+Shift+Down" = "move down"; + "${mod}+Shift+Up" = "move up"; + "${mod}+Shift+Right" = "move right"; + + # switch workspace + "${mod}+1" = "workspace number 1"; + "${mod}+2" = "workspace number 2"; + "${mod}+3" = "workspace number 3"; + "${mod}+4" = "workspace number 4"; + "${mod}+5" = "workspace number 5"; + "${mod}+6" = "workspace number 6"; + "${mod}+7" = "workspace number 7"; + "${mod}+8" = "workspace number 8"; + "${mod}+9" = "workspace number 9"; + + # move focused container to workspace + "${mod}+Shift+1" = "move container to workspace number 1"; + "${mod}+Shift+2" = "move container to workspace number 2"; + "${mod}+Shift+3" = "move container to workspace number 3"; + "${mod}+Shift+4" = "move container to workspace number 4"; + "${mod}+Shift+5" = "move container to workspace number 5"; + "${mod}+Shift+6" = "move container to workspace number 6"; + "${mod}+Shift+7" = "move container to workspace number 7"; + "${mod}+Shift+8" = "move container to workspace number 8"; + "${mod}+Shift+9" = "move container to workspace number 9"; + + # layout + "${mod}+Shift+d" = "layout default"; + "${mod}+Shift+b" = "layout splith"; + "${mod}+Shift+v" = "layout splitv"; + "${mod}+Shift+c" = "layout tabbed"; + + # fullscreen + "${mod}+f" = "fullscreen"; + # float + "${mod}+Shift+space" = "floating toggle"; + # focus + "${mod}+space" = "focus mode_toggle"; + # parent + "${mod}+a" = "focus parent"; + }; + }; + }; +} diff --git a/home/desktops/sway/config.nix b/home/desktops/sway/config.nix new file mode 100644 index 0000000..b3d07d4 --- /dev/null +++ b/home/desktops/sway/config.nix @@ -0,0 +1,122 @@ +{config, ...}: { + wayland.windowManager.sway = { + config = { + # monitors + output = + (builtins.listToAttrs (map (mon: { + name = mon.name; + value = { + dpms = "on"; + scale = toString mon.scale; + render_bit_depth = toString mon.bitdepth; + }; + }) + config.monitors)) + // { + # wallpaper + "*" = { + bg = "${config.theme.wallpaper} fill"; + }; + }; + + # inputs + input = { + "*" = { + xkb_layout = "us"; + xkb_options = "compose:ralt"; + xkb_numlock = "enable"; + }; + + "type:touchpad" = { + tap = "enabled"; + natural_scroll = "enabled"; + middle_emulation = "enabled"; + }; + }; + + startup = + # autostart apps + builtins.map (command: { + inherit command; + always = false; + }) + config.autoRun; + + # colors + colors = let + base = "#${config.theme.colors.base}"; + surface = "#${config.theme.colors.surface}"; + primary = "#${config.theme.colors.primary}"; + text = "#${config.theme.colors.text}"; + white = "#${config.theme.colors.bright.white}"; + error = "#${config.theme.colors.error}"; + in rec { + background = base; + + focused = { + border = primary; + background = base; + text = text; + indicator = white; + childBorder = primary; + }; + + focusedInactive = { + border = surface; + background = base; + text = text; + indicator = surface; + childBorder = surface; + }; + + unfocused = focusedInactive; + + urgent = { + border = error; + background = error; + text = text; + indicator = error; + childBorder = error; + }; + + placeholder = unfocused; + }; + + window = { + titlebar = false; + border = config.theme.borderWidth; + }; + + floating = { + titlebar = false; + border = config.theme.borderWidth; + modifier = "Mod4 normal"; + }; + + gaps = { + inner = config.theme.innerGap; + outer = config.theme.outerGap; + }; + + modes = {}; + bars = []; + }; + + extraConfig = '' + # gestures + bindgesture swipe:right workspace prev + bindgesture swipe:left workspace next + + # swayfx + corner_radius ${toString config.theme.outerRadius} + smart_corner_radius ${toString config.theme.outerRadius} + blur ${ + if config.theme.blur + then "enabled" + else "disabled" + } + blur_radius 10 + blur_passes 3 + ''; + }; +} diff --git a/home/desktops/sway/default.nix b/home/desktops/sway/default.nix new file mode 100644 index 0000000..3553c4a --- /dev/null +++ b/home/desktops/sway/default.nix @@ -0,0 +1,28 @@ +{ + lib, + config, + pkgs, + ... +}: let + inherit (lib) mkIf mkDefault; + cfg = config.desktops.sway; +in { + imports = [ + ./binds.nix + ./config.nix + ./idle.nix + ]; + + config = mkIf cfg.enable { + wayland.windowManager.sway = { + enable = true; + package = pkgs.swayfx; + + # TODO: get swayfx to work with check config + checkConfig = false; + + xwayland = true; + systemd.enable = true; + }; + }; +} diff --git a/home/desktops/sway/idle.nix b/home/desktops/sway/idle.nix new file mode 100644 index 0000000..1af4a6a --- /dev/null +++ b/home/desktops/sway/idle.nix @@ -0,0 +1,25 @@ +{config, ...}: { + services.swayidle = { + enable = config.desktops.sway.enable; + systemdTarget = "sway-session.target"; + + timeouts = [ + { + timeout = 300; + command = "${config.default.lockScreen}"; + } + { + timeout = 300; + command = "swaymsg \"output * power off\""; + resumeCommand = "swaymsg \"output * power on\""; + } + ]; + + events = [ + { + event = "before-sleep"; + command = "${config.default.lockScreen}"; + } + ]; + }; +} diff --git a/home/development.nix b/home/development.nix new file mode 100644 index 0000000..bf59e8e --- /dev/null +++ b/home/development.nix @@ -0,0 +1,48 @@ +{ + lib, + config, + pkgs, + ... +}: let + inherit (lib) mkEnableOption optionals; + cfg = config.development; +in { + config = { + home.packages = with pkgs; + (optionals cfg.c.enable [ + clang-tools + gcc + gdb + gnumake + nasm + pkg-config + ]) + ++ (optionals cfg.lua.enable [ + lua-language-server + ]) + ++ (optionals cfg.rust.enable [ + rustc + rustfmt + rust-analyzer + cargo + clippy + ]) + ++ (optionals cfg.java.enable [ + gradle + jdk + jdt-language-server + kotlin + kotlin-language-server + maven + ]) + ++ (optionals cfg.web.enable [ + phpactor + sassc + typescript-language-server + ]) + ++ (optionals cfg.zig.enable [ + zig + zls + ]); + }; +} diff --git a/home/gaming/default.nix b/home/gaming/default.nix new file mode 100644 index 0000000..6e06904 --- /dev/null +++ b/home/gaming/default.nix @@ -0,0 +1,6 @@ +{...}: { + imports = [ + ./homestuck.nix + ./minecraft.nix + ]; +} diff --git a/home/gaming/homestuck.nix b/home/gaming/homestuck.nix new file mode 100644 index 0000000..20cc2f7 --- /dev/null +++ b/home/gaming/homestuck.nix @@ -0,0 +1,16 @@ +{ + lib, + config, + inputs, + pkgs, + ... +}: let + inherit (lib) mkIf; + cfg = config.gaming.homesuck; +in { + config = mkIf cfg.enable { + home.packages = [ + inputs.self.packages.${pkgs.system}.unofficial-homestuck-collection + ]; + }; +} diff --git a/home/gaming/minecraft.nix b/home/gaming/minecraft.nix new file mode 100644 index 0000000..0b02981 --- /dev/null +++ b/home/gaming/minecraft.nix @@ -0,0 +1,15 @@ +{ + lib, + config, + pkgs, + ... +}: let + inherit (lib) mkIf; + cfg = config.gaming.minecraft; +in { + config = mkIf cfg.enable { + home.packages = with pkgs; [ + prismlauncher + ]; + }; +} diff --git a/home/git.nix b/home/git.nix index 5c6a73a..08c85fd 100644 --- a/home/git.nix +++ b/home/git.nix @@ -1,19 +1,17 @@ {config, ...}: { - home-manager.users.${config.user} = { - programs.git = { - enable = true; - userName = config.fullName; - userEmail = config.email; + programs.git = { + enable = true; + userName = config.fullName; + userEmail = config.email; - signing = { - format = "openpgp"; - key = "D9AF0A4209B7C2DE11A884BFACBC553660D9993D"; - signByDefault = true; - }; + signing = { + format = "openpgp"; + key = "D9AF0A4209B7C2DE11A884BFACBC553660D9993D"; + signByDefault = true; + }; - extraConfig = { - init.defaultBranch = "main"; - }; + extraConfig = { + init.defaultBranch = "main"; }; }; } diff --git a/home/gpg.nix b/home/gpg.nix index d17611a..a1d286d 100644 --- a/home/gpg.nix +++ b/home/gpg.nix @@ -2,28 +2,26 @@ config, lib, pkgs, - self, + inputs, ... }: { - home-manager.users.${config.user} = { - # install keys into gpg keyring - programs.gpg = { - enable = true; + # install keys into gpg keyring + programs.gpg = { + enable = true; - publicKeys = - map (path: { - source = path; - trust = 5; - }) - self.lib.gpgKeys; - }; + publicKeys = + map (path: { + source = path; + trust = 5; + }) + inputs.self.lib.gpgKeys; + }; - # global gpg agent - services.gpg-agent = { - enable = true; - enableExtraSocket = true; - enableSshSupport = true; - pinentry.package = pkgs.pinentry-curses; - }; + # global gpg agent + services.gpg-agent = { + enable = true; + enableExtraSocket = true; + enableSshSupport = true; + pinentry.package = pkgs.pinentry-curses; }; } diff --git a/home/gtk/default.nix b/home/gtk/default.nix index 086f8d1..b7ce33b 100644 --- a/home/gtk/default.nix +++ b/home/gtk/default.nix @@ -33,18 +33,17 @@ cat ${./gtk.css} >>$out ''; in { - home-manager.users.${config.user} = { - gtk = { - enable = true; - theme = { - package = pkgs.adw-gtk3; - name = "adw-gtk3"; - }; + gtk = { + enable = true; + theme = { + package = pkgs.adw-gtk3; + name = "adw-gtk3"; }; + gtk3.extraConfig.gtk-application-prefer-dark-theme = 1; + }; - xdg.configFile = { - "gtk-3.0/gtk.css".source = finalCss; - "gtk-4.0/gtk.css".source = finalCss; - }; + xdg.configFile = { + "gtk-3.0/gtk.css".source = finalCss; + "gtk-4.0/gtk.css".source = finalCss; }; } diff --git a/home/neovim/config.nix b/home/neovim/config.nix index b775e77..be86c9b 100644 --- a/home/neovim/config.nix +++ b/home/neovim/config.nix @@ -53,14 +53,14 @@ in }; # list of lsp servers to load lsps = - optionalAttrs config.development.c { + optionalAttrs config.development.c.enable { clangd = {}; } - // optionalAttrs config.development.java { + // optionalAttrs config.development.java.enable { jdtls = {}; kotlin_language_server = {}; } - // optionalAttrs config.development.lua { + // optionalAttrs config.development.lua.enable { lua_ls = { Lua = { diagnostics = { @@ -69,14 +69,14 @@ in }; }; } - // optionalAttrs config.development.rust { + // optionalAttrs config.development.rust.enable { rust_analyzer = {}; } - // optionalAttrs config.development.web { + // optionalAttrs config.development.web.enable { ts_ls = {}; phpactor = {}; } - // optionalAttrs config.development.zig { + // optionalAttrs config.development.zig.enable { zls = {}; }; highlight = { diff --git a/home/neovim/default.nix b/home/neovim/default.nix index 66d2625..36e1575 100644 --- a/home/neovim/default.nix +++ b/home/neovim/default.nix @@ -7,70 +7,68 @@ lua_cfg = import ./config.nix {inherit lib config;}; lua = builtins.readFile ./init.lua; in { - environment.variables.EDITOR = "nvim"; + home.sessionVariables.EDITOR = "nvim"; - home-manager.users.${config.user} = { - programs.neovim = { - enable = true; - viAlias = true; - vimAlias = true; + programs.neovim = { + enable = true; + viAlias = true; + vimAlias = true; - extraLuaConfig = '' - local config = ${lua_cfg} + extraLuaConfig = '' + local config = ${lua_cfg} - ${lua} - ''; + ${lua} + ''; - plugins = with pkgs.vimPlugins; [ - # Dependencies - vim-devicons - nvim-web-devicons - plenary-nvim - # Colorscheme - base16-nvim - # Mode line - lualine-nvim - # Buffer line - bufferline-nvim - # File browser - nvim-tree-lua - # Undo tree - undotree - # Trouble (error menu) - trouble-nvim - # Telescope (buffers/find/grep/help) - telescope-nvim - # Snippets - vim-vsnip - vim-vsnip-integ - friendly-snippets - # Completion - cmp-buffer - cmp-nvim-lsp - cmp-vsnip - nvim-cmp - # Sourround delimiters - nvim-surround - # Comment functions - nerdcommenter - # Treesitter - nvim-treesitter.withAllGrammars - # Syntax hilighting - vim-illuminate - vim-table-mode - nvim-highlight-colors - colorful-menu-nvim - # Todo comments - todo-comments-nvim - # Lsp server - nvim-lspconfig - # Notifications - fidget-nvim - # Auto indentation - indent-o-matic - # 80 column width - virt-column-nvim - ]; - }; + plugins = with pkgs.vimPlugins; [ + # Dependencies + vim-devicons + nvim-web-devicons + plenary-nvim + # Colorscheme + base16-nvim + # Mode line + lualine-nvim + # Buffer line + bufferline-nvim + # File browser + nvim-tree-lua + # Undo tree + undotree + # Trouble (error menu) + trouble-nvim + # Telescope (buffers/find/grep/help) + telescope-nvim + # Snippets + vim-vsnip + vim-vsnip-integ + friendly-snippets + # Completion + cmp-buffer + cmp-nvim-lsp + cmp-vsnip + nvim-cmp + # Sourround delimiters + nvim-surround + # Comment functions + nerdcommenter + # Treesitter + nvim-treesitter.withAllGrammars + # Syntax hilighting + vim-illuminate + vim-table-mode + nvim-highlight-colors + colorful-menu-nvim + # Todo comments + todo-comments-nvim + # Lsp server + nvim-lspconfig + # Notifications + fidget-nvim + # Auto indentation + indent-o-matic + # 80 column width + virt-column-nvim + ]; }; } diff --git a/home/ssh/default.nix b/home/ssh/default.nix index c884bf4..efee063 100644 --- a/home/ssh/default.nix +++ b/home/ssh/default.nix @@ -4,12 +4,10 @@ ... }: { # ssh config - home-manager.users.${config.user} = { - programs.ssh = { - enable = true; - enableDefaultConfig = false; - matchBlocks."*" = {}; - extraConfig = lib.fileContents ./config; - }; + programs.ssh = { + enable = true; + enableDefaultConfig = false; + matchBlocks."*" = {}; + extraConfig = lib.fileContents ./config; }; } diff --git a/home/starship.nix b/home/starship.nix index 74fd28a..8f0a5f6 100644 --- a/home/starship.nix +++ b/home/starship.nix @@ -3,46 +3,44 @@ lib, ... }: { - home-manager.users.${config.user} = { - programs.starship = { - enable = true; + programs.starship = { + enable = true; - settings = { - format = lib.concatStrings [ - "╭─ " - "$username" - "$hostname" - "$git_branch" - "$directory" - "$line_break" - "╰─ " - ]; + settings = { + format = lib.concatStrings [ + "╭─ " + "$username" + "$hostname" + "$git_branch" + "$directory" + "$line_break" + "╰─ " + ]; - username = { - style_user = "bold cyan"; - style_root = "bold red"; - format = "[$user]($style) "; - disabled = false; - show_always = true; - }; + username = { + style_user = "bold cyan"; + style_root = "bold red"; + format = "[$user]($style) "; + disabled = false; + show_always = true; + }; - hostname = { - ssh_only = false; - format = "on [$hostname](bold blue) "; - disabled = false; - }; + hostname = { + ssh_only = false; + format = "on [$hostname](bold blue) "; + disabled = false; + }; - directory = { - format = "[$path]($style)[$read_only]($read_only_style) "; - truncation_length = -1; - truncate_to_repo = false; - truncation_symbol = "…/"; - }; + directory = { + format = "[$path]($style)[$read_only]($read_only_style) "; + truncation_length = -1; + truncate_to_repo = false; + truncation_symbol = "…/"; + }; - git_branch = { - style = "bold purple"; - format = "at [$symbol$branch(:$remote_branch)]($style) "; - }; + git_branch = { + style = "bold purple"; + format = "at [$symbol$branch(:$remote_branch)]($style) "; }; }; }; diff --git a/home/tmux/default.nix b/home/tmux/default.nix index c7ce7db..ea8e525 100644 --- a/home/tmux/default.nix +++ b/home/tmux/default.nix @@ -3,14 +3,12 @@ pkgs, ... }: { - home-manager.users.${config.user} = { - home.packages = [ - pkgs.tmux - ]; + home.packages = [ + pkgs.tmux + ]; - home.file = { - ".tmux.conf".source = ./tmux.conf; - ".local/bin/tmux_window".source = ./tmux_window; - }; + home.file = { + ".tmux.conf".source = ./tmux.conf; + ".local/bin/tmux_window".source = ./tmux_window; }; } diff --git a/home/zsh/default.nix b/home/zsh/default.nix index 8bb12db..2df01ef 100644 --- a/home/zsh/default.nix +++ b/home/zsh/default.nix @@ -1,30 +1,23 @@ { config, - pkgs, + lib, ... }: { programs.zsh = { enable = true; enableCompletion = true; - enableGlobalCompInit = false; - autosuggestions.enable = true; + autosuggestion = { + enable = true; + highlight = "fg=#${config.theme.colors.subtext}"; + }; syntaxHighlighting.enable = true; - histSize = 10000; + history.size = 10000; + profileExtra = lib.fileContents ./zprofile; + envExtra = lib.fileContents ./zshrc; }; - home-manager.users.${config.user} = { - home.file = { - ".zshrc".source = ./zshrc; - ".zprofile".source = ./zprofile; - ".nixenv".source = pkgs.writeText "nixenv" '' - # nix shell env auto generated file - export ZSH_AUTOSUGGEST_HIGHLIGHT_STYLE='fg=#${config.theme.colors.subtext}' - ''; - }; - - programs.zoxide = { - enable = true; - enableZshIntegration = true; - }; + programs.zoxide = { + enable = true; + enableZshIntegration = true; }; } diff --git a/home/zsh/zshrc b/home/zsh/zshrc index 0dd2904..6a366a0 100644 --- a/home/zsh/zshrc +++ b/home/zsh/zshrc @@ -72,6 +72,3 @@ bindkey "\e\d" undo # gpg export GPG_TTY=$(tty) export SSH_AUTH_SOCK=$(gpgconf --list-dirs agent-ssh-socket) - -# nixos -source ~/.nixenv |