From f07257ab6db130b2cdd81751410aabe8c6d7e086 Mon Sep 17 00:00:00 2001 From: Fabian Montero Date: Sun, 8 Sep 2024 15:23:22 -0600 Subject: [PATCH] add desktop platform --- .../fabian@posixlycorrect/accounts.nix | 82 ++++ .../allowUnfreeWhitelist.nix | 23 + .../fabian@posixlycorrect/apps/default.nix | 17 + .../fabian@posixlycorrect/apps/library.nix | 55 +++ .../apps/steam/default.nix | 19 + .../apps/steam/package.nix | 9 + .../apps/terminal/default.nix | 35 ++ .../apps/terminal/kitty.conf.nix | 87 ++++ .../apps/virtmanager.nix | 16 + home/platforms/fabian@posixlycorrect/cli.nix | 54 ++ .../fabian@posixlycorrect/default.nix | 66 +++ .../fabian@posixlycorrect/gui/autorandr.nix | 17 + .../fabian@posixlycorrect/gui/default.nix | 51 ++ .../fabian@posixlycorrect/gui/fonts.nix | 18 + .../fabian@posixlycorrect/gui/gtk.nix | 17 + .../fabian@posixlycorrect/gui/i3.nix | 110 +++++ .../fabian@posixlycorrect/gui/polybar.nix | 464 ++++++++++++++++++ .../fabian@posixlycorrect/gui/startx.nix | 26 + .../fabian@posixlycorrect/isolation.nix | 22 + .../fabian@posixlycorrect/options.nix | 30 ++ .../platforms/posixlycorrect.nix | 42 ++ .../platforms/thinkpad.nix | 25 + .../fabian@posixlycorrect/shenvs/c.nix | 13 + .../fabian@posixlycorrect/shenvs/python.nix | 11 + .../fabian@posixlycorrect/systemd/default.nix | 10 + .../platforms/fabian@posixlycorrect/zshrc.nix | 136 +++++ sys/platforms/posixlycorrect/default.nix | 106 ++++ .../posixlycorrect/hardware-configuration.nix | 43 ++ 28 files changed, 1604 insertions(+) create mode 100644 home/platforms/fabian@posixlycorrect/accounts.nix create mode 100644 home/platforms/fabian@posixlycorrect/allowUnfreeWhitelist.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/default.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/library.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/steam/default.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/steam/package.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/terminal/default.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/terminal/kitty.conf.nix create mode 100644 home/platforms/fabian@posixlycorrect/apps/virtmanager.nix create mode 100644 home/platforms/fabian@posixlycorrect/cli.nix create mode 100644 home/platforms/fabian@posixlycorrect/default.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/autorandr.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/default.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/fonts.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/gtk.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/i3.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/polybar.nix create mode 100644 home/platforms/fabian@posixlycorrect/gui/startx.nix create mode 100644 home/platforms/fabian@posixlycorrect/isolation.nix create mode 100644 home/platforms/fabian@posixlycorrect/options.nix create mode 100644 home/platforms/fabian@posixlycorrect/platforms/posixlycorrect.nix create mode 100644 home/platforms/fabian@posixlycorrect/platforms/thinkpad.nix create mode 100644 home/platforms/fabian@posixlycorrect/shenvs/c.nix create mode 100644 home/platforms/fabian@posixlycorrect/shenvs/python.nix create mode 100644 home/platforms/fabian@posixlycorrect/systemd/default.nix create mode 100644 home/platforms/fabian@posixlycorrect/zshrc.nix create mode 100644 sys/platforms/posixlycorrect/default.nix create mode 100644 sys/platforms/posixlycorrect/hardware-configuration.nix diff --git a/home/platforms/fabian@posixlycorrect/accounts.nix b/home/platforms/fabian@posixlycorrect/accounts.nix new file mode 100644 index 0000000..97e7647 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/accounts.nix @@ -0,0 +1,82 @@ +{ + lib, + config, + ... +}: +with lib; { + config = mkIf (!config.home.isolation.active) { + accounts.email.maildirBasePath = "${config.home.homeDirectory}/mail"; + accounts.email.accounts = { + "default" = { + address = "fabian@posixlycorrect.com"; + userName = "fabianmontero@fastmail.com"; + realName = "fabian"; + primary = true; + flavor = "fastmail.com"; + + smtp = { + host = "smtp.fastmail.com"; + port = 465; + }; + imap = { + host = "imap.fastmail.com"; + port = 993; + tls.enable = true; + }; + + passwordCommand = "gpg -d ${config.home.homeDirectory}/secrets/fastmail.password.gpg 2> /dev/null"; + + gpg = { + encryptByDefault = true; + signByDefault = true; + key = "7AA277E604A4173916BBB4E91FFAC35E1798174F"; + }; + + thunderbird = { + enable = true; + settings = id: { + "mail.openpgp.allow_external_gnupg" = true; + }; + }; + neomutt = { + enable = true; + }; + + mbsync = { + enable = true; + create = "both"; + expunge = "both"; + remove = "both"; + }; + }; + }; + + programs = { + mbsync.enable = true; + thunderbird = { + enable = true; + profiles = { + "default" = { + isDefault = true; + }; + }; + }; + neomutt = { + enable = true; + sort = "date-received"; + vimKeys = true; + sidebar = { + enable = true; + }; + #settings = { + # maildir_check_cur = "yes"; + #}; + extraConfig = '' + mailboxes `find ~/mail/ -type d -name cur -printf '%h '` + timeout-hook 'echo `mbsync -a`' + startup-hook 'echo `mbsync -a`' + ''; + }; + }; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/allowUnfreeWhitelist.nix b/home/platforms/fabian@posixlycorrect/allowUnfreeWhitelist.nix new file mode 100644 index 0000000..a71519f --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/allowUnfreeWhitelist.nix @@ -0,0 +1,23 @@ +{ + pkgs, + config, + lib, + ... +}: +with lib; { + nixpkgs.config.allowUnfreePredicate = pkg: + builtins.elem (lib.getName pkg) [ + "discord" + "pycharm-professional" + "rar" + "spotify" + "spotify-unwrapped" + "steam" + "steam-original" + "steam-run" + "teams" + "vscode-extension-ms-vscode-cpptools" + "vmware-horizon-client" + "zoom" + ]; +} diff --git a/home/platforms/fabian@posixlycorrect/apps/default.nix b/home/platforms/fabian@posixlycorrect/apps/default.nix new file mode 100644 index 0000000..9155e3a --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/default.nix @@ -0,0 +1,17 @@ +{ + config, + lib, + pkgs, + ... +}: +with lib; let + cfg = config.local.apps; +in { + options.local.apps.enable = mkEnableOption "Applications and tools"; + imports = [ + ./library.nix + ./steam + ./terminal + ./virtmanager.nix + ]; +} diff --git a/home/platforms/fabian@posixlycorrect/apps/library.nix b/home/platforms/fabian@posixlycorrect/apps/library.nix new file mode 100644 index 0000000..ffc3f5b --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/library.nix @@ -0,0 +1,55 @@ +{ + config, + lib, + pkgs, + ... +}: +with lib; let + cfg = config.local.apps.defaultApps; +in { + options.local.apps.defaultApps.enable = mkEnableOption "Default app library"; + config = mkIf cfg.enable { + home.packages = with pkgs; [ + chromium + darktable + deluge + discord + element-desktop + firefox + gperftools + gwenview + helix + libreoffice-fresh + lutris + mpv + neovim + obs-studio + openrct2 + pavucontrol + pdfarranger + prismlauncher + qpdfview + runelite + spotify + tdesktop + vlc + vpsfree-client + vscodium-fhs + zola + zoom-us + ]; + + xdg.mimeApps.defaultApplications = { + "application/x-extension-htm" = ["firefox.desktop"]; + "application/x-extension-html" = ["firefox.desktop"]; + "application/x-extension-shtml" = ["firefox.desktop"]; + "application/x-extension-xht" = ["firefox.desktop"]; + "application/x-extension-xhtml" = ["firefox.desktop"]; + "application/xhtml+xml" = ["firefox.desktop"]; + "text/html" = ["firefox.desktop"]; + "x-scheme-handler/http" = ["firefox.desktop"]; + "x-scheme-handler/https" = ["firefox.desktop"]; + "application/pdf" = ["qpdfview.desktop"]; + }; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/apps/steam/default.nix b/home/platforms/fabian@posixlycorrect/apps/steam/default.nix new file mode 100644 index 0000000..534d4ae --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/steam/default.nix @@ -0,0 +1,19 @@ +{ + pkgs, + lib, + config, + ... +}: +with lib; let + cfg = config.local.apps.steam; +in { + options.local.apps.steam.enable = mkEnableOption "Steam"; + config = mkIf cfg.enable { + home.packages = [ + (pkgs.callPackage ./package.nix {}) + pkgs.protonup + pkgs.winetricks + pkgs.protontricks + ]; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/apps/steam/package.nix b/home/platforms/fabian@posixlycorrect/apps/steam/package.nix new file mode 100644 index 0000000..19f241f --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/steam/package.nix @@ -0,0 +1,9 @@ +{ + writeShellScriptBin, + steam-run, + steam, + ... +}: +writeShellScriptBin "steam" '' + exec ${steam-run}/bin/steam-run ${steam}/bin/steam -console +'' diff --git a/home/platforms/fabian@posixlycorrect/apps/terminal/default.nix b/home/platforms/fabian@posixlycorrect/apps/terminal/default.nix new file mode 100644 index 0000000..a32486d --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/terminal/default.nix @@ -0,0 +1,35 @@ +{ + config, + lib, + pkgs, + ... +}: +with lib; let + cfg = config.local.apps.terminal; +in { + options.local.apps.terminal.enable = mkEnableOption "Terminal emulator settings"; + config.programs = mkIf cfg.enable { + kitty = { + enable = true; + extraConfig = import ./kitty.conf.nix; + }; + + tmux = { + enable = true; + aggressiveResize = true; + clock24 = true; + escapeTime = 10; + terminal = "xterm-256color"; + keyMode = "emacs"; + + extraConfig = '' + set -g mouse on + set -ga update-environment " LIFT_PID" + set -g set-titles on + set -g renumber-windows on + set -sa terminal-overrides ',xterm-termite:RGB' + set -g status-right "#{?window_bigger,[#{window_offset_x}#,#{window_offset_y}] ,} %H:%M %d-%b-%y" + ''; + }; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/apps/terminal/kitty.conf.nix b/home/platforms/fabian@posixlycorrect/apps/terminal/kitty.conf.nix new file mode 100644 index 0000000..82904a9 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/terminal/kitty.conf.nix @@ -0,0 +1,87 @@ +'' + # Fonts + font_family JetBrains Mono Medium + bold_font JetBrains Mono Bold + italic_font JetBrains Mono Italic + bold_italic_font JetBrains Mono Bold Italic + + font_size 15 + disable_ligatures cursor + + initial_window_width 1200 + initial_window_height 600 + + # Cursor + cursor_shape beam + cursor_beam_thickness 1.9 + cursor_stop_blinking_after 0 + + # Audio + enable_audio_bell no + + # Tabs + tab_bar_style separator + tab_separator " | " + tab_title_template "{index}: {title}" + + # Color + # special + foreground #ffffff + foreground_bold #ffffff + cursor #ffffff + background #000000 + background_opacity 1 + + # Shortcuts + map ctrl+shift+c copy_to_clipboard + map ctrl+shift+v paste_from_clipboard + map ctrl+shift+s paste_from_selection + map shift+insert paste_from_selection + + map ctrl+shift+up scroll_line_up + map ctrl+shift+down scroll_line_down + map ctrl+shift+page_up scroll_page_up + map ctrl+shift+page_down scroll_page_down + map ctrl+shift+home scroll_home + map ctrl+shift+end scroll_end + + map ctrl+shift+enter new_window + map ctrl+alt+enter launch --cwd=current + map ctrl+shift+w close_window + map ctrl+shift+] next_window + map ctrl+shift+[ previous_window + map ctrl+shift+1 first_window + map ctrl+shift+2 second_window + map ctrl+shift+3 third_window + map ctrl+shift+4 fourth_window + map ctrl+shift+5 fifth_window + map ctrl+shift+6 sixth_window + map ctrl+shift+7 seventh_window + map ctrl+shift+8 eighth_window + map ctrl+shift+9 ninth_window + map ctrl+shift+0 tenth_window + + map ctrl+shift+right next_tab + map ctrl+shift+left previous_tab + map ctrl+shift+t new_tab + map ctrl+shift+q close_tab + map ctrl+shift+. move_tab_forward + map ctrl+shift+, move_tab_backward + map ctrl+shift+alt+t set_tab_title + map ctrl+alt+1 goto_tab 1 + map ctrl+alt+2 goto_tab 2 + map ctrl+alt+3 goto_tab 3 + map ctrl+alt+4 goto_tab 4 + map ctrl+alt+5 goto_tab 5 + map ctrl+alt+6 goto_tab 6 + map ctrl+alt+7 goto_tab 7 + map ctrl+alt+8 goto_tab 8 + map ctrl+alt+9 goto_tab 9 + map ctrl+alt+0 goto_tab 10 + + map ctrl+shift+equal change_font_size all +1.0 + map ctrl+shift+minus change_font_size all -1.0 + map ctrl+shift+backspace change_font_size all 0 + + map ctrl+shift+delete clear_terminal reset active +'' diff --git a/home/platforms/fabian@posixlycorrect/apps/virtmanager.nix b/home/platforms/fabian@posixlycorrect/apps/virtmanager.nix new file mode 100644 index 0000000..cca4dd7 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/apps/virtmanager.nix @@ -0,0 +1,16 @@ +{ + config, + lib, + pkgs, + ... +}: +with lib; let + cfg = config.local.apps.virtmanager; +in { + options.local.apps.virtmanager.enable = mkEnableOption "Virtmanager"; + config = mkIf cfg.enable { + home.packages = with pkgs; [ + virt-manager + ]; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/cli.nix b/home/platforms/fabian@posixlycorrect/cli.nix new file mode 100644 index 0000000..c2ac1f4 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/cli.nix @@ -0,0 +1,54 @@ +{ + config, + lib, + pkgs, + ... +}: +with lib; { + programs = { + ## talvez esto debería moverse a base + zsh = { + enable = true; + syntaxHighlighting.enable = true; + initExtra = import ./zshrc.nix pkgs; + }; + git = { + enable = true; + userEmail = "fabian@posixlycorrect.com"; + userName = "Fabian Montero"; + signing = { + key = "7AA277E604A4173916BBB4E91FFAC35E1798174F"; + signByDefault = true; + }; + }; + gpg = { + enable = true; + settings = { + default-key = "7AA277E604A4173916BBB4E91FFAC35E1798174F"; + }; + }; + }; + + services.gpg-agent = { + enable = true; + enableZshIntegration = true; + pinentryPackage = pkgs.pinentry-emacs; + }; + + home.packages = with pkgs; [ + calc + file + gcc + htop + killall + man-pages + man-pages-posix + neovim + rar + tree + units + unzip + usbutils + zip + ]; +} diff --git a/home/platforms/fabian@posixlycorrect/default.nix b/home/platforms/fabian@posixlycorrect/default.nix new file mode 100644 index 0000000..03fef94 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/default.nix @@ -0,0 +1,66 @@ +{ + self, + nixpkgs, + unstable, + hm-isolation, + nixGL, +}: { + config, + pkgs, + lib, + ... +}: +with lib; { + imports = [ + (hm-isolation.homeManagerModule) + ./accounts.nix + ./apps + ./allowUnfreeWhitelist.nix + ./gui + ./isolation.nix + ./options.nix + ./cli.nix + ./systemd + ]; + + nixpkgs.overlays = [self.overlay nixGL.overlay]; + + services.ssh-agent.enable = true; + + home = { + stateVersion = "21.11"; # No tocar esto + username = "fabian"; + homeDirectory = "/home/fabian"; + sessionVariables = { + "EDITOR" = "nvim"; + "TERMINAL" = "kitty"; + }; + keyboard = { + layout = "us"; + variant = "altgr-intl"; + }; + }; + + xdg.enable = true; + + nix.registry = { + "system".to = { + type = "path"; + path = "/home/fabian/nix"; + }; + + "nixpkgs".flake = nixpkgs; + "unstable".flake = unstable; + }; + + programs.home-manager.enable = true; + + local = { + apps.enable = mkDefault (!config.home.isolation.active); + + gui = { + enable = mkDefault true; + desktop = mkDefault (!config.home.isolation.active); + }; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/gui/autorandr.nix b/home/platforms/fabian@posixlycorrect/gui/autorandr.nix new file mode 100644 index 0000000..c01ffe1 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/gui/autorandr.nix @@ -0,0 +1,17 @@ +{ + config, + pkgs, + lib, + ... +}: +with lib; let + cfg = config.local.gui.autorandr; +in { + options.local.gui.autorandr.enable = mkEnableOption "Autorandr"; + config = mkIf cfg.enable { + programs.autorandr = { + enable = true; + profiles."${config.local.platform}" = config.local.display.autorandrProfile; + }; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/gui/default.nix b/home/platforms/fabian@posixlycorrect/gui/default.nix new file mode 100644 index 0000000..1b297a3 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/gui/default.nix @@ -0,0 +1,51 @@ +{ + config, + pkgs, + lib, + ... +}: +with lib; let + cfg = config.local.gui; +in { + options.local.gui = { + enable = mkEnableOption "GUI settings and programs"; + desktop = mkEnableOption "i3 desktop envirorment"; + }; + + imports = [ + ./autorandr.nix + ./fonts.nix + ./gtk.nix + ./i3.nix + ./polybar.nix + ./startx.nix + ]; + + config = mkIf cfg.enable { + local.gui = { + fonts.enable = mkDefault true; + gtk.enable = mkDefault true; + + autorandr.enable = mkDefault cfg.desktop; + i3.enable = mkDefault cfg.desktop; + polybar.enable = mkDefault cfg.desktop; + startx.enable = mkDefault cfg.desktop; + }; + + services = mkIf cfg.desktop { + picom = { + enable = true; + }; + + dunst = { + enable = true; + }; + + betterlockscreen = { + enable = true; + }; + }; + + xdg.mimeApps.enable = true; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/gui/fonts.nix b/home/platforms/fabian@posixlycorrect/gui/fonts.nix new file mode 100644 index 0000000..7c38dbe --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/gui/fonts.nix @@ -0,0 +1,18 @@ +{ + config, + pkgs, + lib, + ... +}: +with lib; let + cfg = config.local.gui.fonts; +in { + options.local.gui.fonts.enable = mkEnableOption "Font management"; + config = mkIf cfg.enable { + fonts.fontconfig.enable = true; + + home.packages = with pkgs; [ + jetbrains-mono + ]; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/gui/gtk.nix b/home/platforms/fabian@posixlycorrect/gui/gtk.nix new file mode 100644 index 0000000..0f14af6 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/gui/gtk.nix @@ -0,0 +1,17 @@ +{ + config, + lib, + pkgs, + ... +}: +with lib; let + cfg = config.local.gui.gtk; +in { + options.local.gui.gtk.enable = mkEnableOption "GTK related programs"; + config = mkIf cfg.enable { + home.packages = with pkgs; [ + gruvbox-dark-icons-gtk + libsForQt5.breeze-gtk + ]; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/gui/i3.nix b/home/platforms/fabian@posixlycorrect/gui/i3.nix new file mode 100644 index 0000000..687d6c6 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/gui/i3.nix @@ -0,0 +1,110 @@ +{ + config, + pkgs, + lib, + ... +}: +with lib; let + cfg = config.local.gui.i3; +in { + options.local.gui.i3.enable = mkEnableOption "i3 window manager"; + config = mkIf cfg.enable { + xsession.windowManager.i3 = { + enable = true; + package = pkgs.i3-gaps; + + config = let + mod = "Mod4"; + in { + modifier = mod; + # revisar luego si config.bars tiene un default danino + + fonts = { + names = ["JetBrains Mono"]; + style = "Regular"; + size = 8.0; + }; + + gaps = { + inner = 10; + outer = -10; + }; + + window = { + hideEdgeBorders = "both"; + }; + + colors = { + focused = { + background = "#222222"; + border = "#4c7899"; + childBorder = "#222222"; + indicator = "#292d2e"; + text = "#888888"; + }; + }; + + # mkOptionDefault hace que se ponga la config por default + # y se sobreescriba las cosas que pongo acA + # NO QUITARLO. ver man home-configuration.nix + keybindings = mkOptionDefault { + "${mod}+Return" = "exec ${pkgs.kitty}/bin/kitty ${pkgs.tmux}/bin/tmux"; + "${mod}+Tab" = "focus right"; + "${mod}+Shift+Tab" = "focus left"; + "${mod}+Shift+s" = "exec ${pkgs.maim}/bin/maim -s -u | ${pkgs.xclip}/bin/xclip -selection clipboard -t image/png -i"; + "${mod}+Shift+w" = "move workspace to output right"; + "${mod}+l" = "exec ${pkgs.betterlockscreen}/bin/betterlockscreen -l"; + }; + + startup = [ + { + command = "${pkgs.xss-lock}/bin/xss-lock --transfer-sleep-lock -- ${pkgs.i3lock}/bin/i3lock --nofork"; + notification = false; + } + { + command = "${pkgs.networkmanagerapplet}/bin/nm-applet"; + notification = false; + } + { + command = "${pkgs.feh}/bin/feh --bg-fill ${config.home.homeDirectory}/Pictures/wallpapers/jupiter.png"; + notification = false; + always = true; + } + { + command = "${pkgs.i3-gaps}/bin/i3-msg 'workspace 1; exec ${pkgs.firefox}/bin/firefox'"; + } + { + command = "${pkgs.i3-gaps}/bin/i3-msg 'workspace 2; exec ${pkgs.tdesktop}/bin/telegram-desktop'"; + } + #{ + # command = "${pkgs.i3-gaps}/bin/i3-msg 'workspace 2; exec ${pkgs.element-desktop}/bin/element-desktop'"; + #} + { + command = "${pkgs.systemd}/bin/systemctl --user restart polybar.service"; + notification = false; + always = true; + } + { + command = "${pkgs.autorandr}/bin/autorandr -c"; + notification = false; + always = true; + } + ]; + + workspaceOutputAssign = + [ + { + output = config.local.display."0"; + workspace = "1"; + } + ] + ++ optional (config.local.display."1" != null) { + output = config.local.display."1"; + workspace = "10"; + }; + + bars = []; + }; + }; + }; +} diff --git a/home/platforms/fabian@posixlycorrect/gui/polybar.nix b/home/platforms/fabian@posixlycorrect/gui/polybar.nix new file mode 100644 index 0000000..042c668 --- /dev/null +++ b/home/platforms/fabian@posixlycorrect/gui/polybar.nix @@ -0,0 +1,464 @@ +{ + config, + pkgs, + lib, + ... +}: +with lib; let + cfg = config.local.gui.polybar; +in { + options.local.gui.polybar.enable = mkEnableOption "Polybar"; + config = mkIf cfg.enable { + services.polybar = mkIf (!config.home.isolation.active) { + enable = true; + package = pkgs.polybarFull; + script = '' + # Terminate already running bar instances + killall -q polybar + + # Wait until the processes have been shut down + while pgrep -u $UID -x polybar >/dev/null; do sleep 1; done + + # Launch Polybar, using default config location ~/.config/polybar/config + polybar -r main & polybar -r secondary & + ''; + + settings = { + "colors" = { + # background = "\${xrdb:color0:#222}"; + background = "#AA000000"; + background-alt = "#00000000"; + # foreground = "\${xrdb:color7:#222}"; + foreground = "#ffffff"; + foreground-alt = "#ffffff"; + primary = "#ffffff"; + secondary = "#e60053"; + alert = "#bd2c40"; + }; + + "bar/main" = { + monitor = "${config.local.display."0"}"; + width = "100%"; + height = 30; + offset-x = "0%"; + offset-y = "0%"; + radius = 0.0; + fixed-center = false; + + background = "\${colors.background}"; + foreground = "\${colors.foreground}"; + + line-size = 1; + line-color = "#f0000000"; + + border-size = 0; + border-color = "#00000000"; + + padding-left = 0; + padding-right = 0; + + module-margin-left = 1; + module-margin-right = 1; + + # font-0 = "fixed:pixelsize=10;1"; + font-0 = "JetBrains Mono Light:size=10;0"; + font-1 = "unifont:fontformat=truetype:size=8:antialias=false;0"; + font-2 = "siji:pixelsize=10;1"; + # font-2 = "FontAwesome5Free:style=Regular:size=10;4"; + + modules-left = "i3"; + modules-center = "xwindow"; + modules-right = "xkeyboard pulseaudio filesystem memory cpu temperature gputemperature nvmetemperature wlan eth date semanatec"; + separator = "|"; + + tray-position = "right"; + tray-padding = 2; + + # To allow other windows to be placed above the bar, or to avoid having the bar visible when in fullscreen mode, + # you need to use the following two parameters. Note that it will tell the window manager to back off so no + # area will be reserved, etc. + # + # wm-restack = "i3"; + # override-redirect = true; + + cursor-click = "pointer"; + cursor-scroll = "ns-resize"; + }; + + "bar/secondary" = optionalAttrs (config.local.display."1" != null) { + monitor = "${config.local.display."1"}"; + "inherit" = "bar/main"; + + modules-left = "i3"; + modules-center = "xwindow"; + modules-right = "xkeyboard pulseaudio date"; + tray-position = "none"; + }; + + "module/xwindow" = { + type = "internal/xwindow"; + label = "%title:0:30:...%"; + }; + + "module/xkeyboard" = { + type = "internal/xkeyboard"; + blacklist-0 = "num lock"; + + format-prefix = ""; + format-prefix-foreground = "\${colors.foreground-alt}"; + + label-layout = "%layout%"; + + label-indicator-padding = 2; + label-indicator-margin = 1; + label-indicator-background = "\${colors.secondary}"; + }; + + "module/filesystem" = { + type = "internal/fs"; + interval = 10; + + mount-0 = "/"; + + label-mounted = "%{F#0a81f5}%mountpoint%%{F-}: %used%/%total%"; + label-unmounted = ""; + }; + + "module/i3" = { + type = "internal/i3"; + format = " "; + index-sort = true; + wrapping-scroll = false; + + # Only show workspaces on the same output as the bar + # pin-workspaces = true + + label-mode-padding = 1; + label-mode-foreground = "#000"; + label-mode-background = "\${colors.primary}"; + + # focused = Active workspace on focused monitor + label-focused = "%index%"; + label-focused-background = "\${colors.background}"; + label-focused-underline = "\${colors.primary}"; + label-focused-padding = 1; + + # unfocused = Inactive workspace on any monitor + label-unfocused = "%index%"; + label-unfocused-padding = 1; + + # visible = Active workspace on unfocused monitor + label-visible = "%index%"; + label-visible-background = "\${self.label-focused-background}"; + label-visible-underline = "\${self.label-focused-underline}"; + label-visible-padding = "\${self.label-focused-padding}"; + + # urgent = Workspace with urgency hint set + label-urgent = "%index%"; + label-urgent-background = "\${colors.alert}"; + label-urgent-padding = 1; + }; + + "module/xbacklight" = { + type = "internal/xbacklight"; + + format = "