summaryrefslogtreecommitdiff
path: root/home
diff options
context:
space:
mode:
Diffstat (limited to 'home')
-rw-r--r--home/apps/alacritty.nix97
-rw-r--r--home/apps/astal.nix39
-rw-r--r--home/apps/default.nix13
-rw-r--r--home/apps/hyprlock.nix104
-rw-r--r--home/apps/kitty.nix79
-rw-r--r--home/apps/mako.nix33
-rw-r--r--home/apps/waybar/default.nix85
-rw-r--r--home/apps/waybar/style.nix107
-rw-r--r--home/apps/wofi/default.nix27
-rw-r--r--home/apps/wofi/style.nix73
-rw-r--r--home/browsers/default.nix6
-rw-r--r--home/browsers/firefox/default.nix37
-rw-r--r--home/browsers/firefox/extensions.nix44
-rw-r--r--home/browsers/firefox/mozilla.cfg21
-rw-r--r--home/browsers/firefox/policies.nix127
-rw-r--r--home/browsers/firefox/prefs.nix128
-rw-r--r--home/browsers/firefox/userChrome.css23
-rw-r--r--home/browsers/zen.nix32
-rw-r--r--home/default.nix195
-rw-r--r--home/desktops/default.nix81
-rw-r--r--home/desktops/hyprland/binds.nix139
-rw-r--r--home/desktops/hyprland/default.nix33
-rw-r--r--home/desktops/hyprland/env.nix14
-rw-r--r--home/desktops/hyprland/idle.nix35
-rw-r--r--home/desktops/hyprland/plugins.nix40
-rw-r--r--home/desktops/hyprland/settings.nix125
-rw-r--r--home/desktops/hyprland/wallpaper.nix11
-rw-r--r--home/desktops/sway/binds.nix89
-rw-r--r--home/desktops/sway/config.nix122
-rw-r--r--home/desktops/sway/default.nix28
-rw-r--r--home/desktops/sway/idle.nix25
-rw-r--r--home/development.nix48
-rw-r--r--home/gaming/default.nix6
-rw-r--r--home/gaming/homestuck.nix16
-rw-r--r--home/gaming/minecraft.nix15
-rw-r--r--home/git.nix24
-rw-r--r--home/gpg.nix36
-rw-r--r--home/gtk/default.nix21
-rw-r--r--home/neovim/config.nix12
-rw-r--r--home/neovim/default.nix120
-rw-r--r--home/ssh/default.nix12
-rw-r--r--home/starship.nix68
-rw-r--r--home/tmux/default.nix14
-rw-r--r--home/zsh/default.nix29
-rw-r--r--home/zsh/zshrc3
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