{ stylix }: { config, pkgs, lib, ... }: let cfg = config.jconfig; in { imports = [ ./options.nix ./gui stylix.nixosModules.stylix # FIXME(https://github.com/danth/stylix/issues/216): Must configure stylix { stylix = import ./stylix-config.nix { inherit config pkgs; }; } ]; config = lib.mkIf cfg.enable { boot.plymouth.enable = cfg.styling.enable; # Enable unlocking the gpg-agent at boot (configured through home.nix) security.pam.services.login.gnupg.enable = true; environment.systemPackages = [ # Dev tools pkgs.gcc pkgs.clang # CLI tools pkgs.fd pkgs.bat pkgs.skim pkgs.ripgrep pkgs.du-dust pkgs.curl pkgs.wget pkgs.eza pkgs.zip pkgs.unzip ]; # Shell prompt programs.starship.enable = true; programs.starship.settings = lib.mkIf cfg.styling.enable { format = "$time$all"; add_newline = false; cmd_duration.min_time = 500; cmd_duration.show_milliseconds = true; time.format = "[$time](bold yellow) "; time.disabled = false; status.format = "[$signal_name$common_meaning$maybe_int](red)"; status.symbol = "[✗](bold red)"; status.disabled = false; sudo.disabled = false; }; programs.ssh.knownHostsFiles = lib.mapAttrsToList (username: sha256: builtins.fetchurl { inherit sha256; url = "https://github.com/${username}.keys"; }) cfg.importSSHKeysFromGithub; # Default shell programs.zsh.enable = true; users.defaultUserShell = pkgs.zsh; # Open ports for spotifyd networking.firewall.allowedUDPPorts = [ 5353 ]; networking.firewall.allowedTCPPorts = [ 2020 ]; # Nix Settings nix.gc.automatic = true; nix.gc.dates = "weekly"; nix.gc.options = "--delete-older-than 30d"; # run between 0 and 45min after boot if run was missed nix.gc.randomizedDelaySec = "45min"; nix.settings.auto-optimise-store = true; nix.settings.experimental-features = [ "nix-command" "flakes" ]; }; }