Compare commits
4 Commits
6ce116ef71
...
15268487f3
| Author | SHA1 | Date | |
|---|---|---|---|
| 15268487f3 | |||
| 25718939f8 | |||
| 002d90b664 | |||
| 7c3c15a9a2 |
@ -10,7 +10,7 @@ general {
|
|||||||
|
|
||||||
background {
|
background {
|
||||||
monitor =
|
monitor =
|
||||||
path = /home/foglar/dotfiles/nixos/aurora_borealis.png
|
path = /home/foglar/dotfiles/config/backgrounds/aurora_borealis.png
|
||||||
color = rgba(25, 20, 20, 1.0)
|
color = rgba(25, 20, 20, 1.0)
|
||||||
|
|
||||||
# all these options are taken from hyprland, see https://wiki.hyprland.org/Configuring/Variables/#blur for explanations
|
# all these options are taken from hyprland, see https://wiki.hyprland.org/Configuring/Variables/#blur for explanations
|
||||||
|
|||||||
18
flake.lock
18
flake.lock
@ -108,11 +108,11 @@
|
|||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "pkgs/firefox-addons",
|
"dir": "pkgs/firefox-addons",
|
||||||
"lastModified": 1732248209,
|
"lastModified": 1732437995,
|
||||||
"narHash": "sha256-Mv8k0VuGdb6YhhKt+8SIvhMdmI4xZhw/3ycSvlAq19Q=",
|
"narHash": "sha256-e+a2fakuHryskUKuupz3ZhwEM9MFD6eUxM7dRJAlOLs=",
|
||||||
"owner": "rycee",
|
"owner": "rycee",
|
||||||
"repo": "nur-expressions",
|
"repo": "nur-expressions",
|
||||||
"rev": "4a8ba00d1be3f3745428ed56efbb32155c548192",
|
"rev": "9fdaef6ec5c8317cee125ea69b5b79fa73a26c69",
|
||||||
"type": "gitlab"
|
"type": "gitlab"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -252,11 +252,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1732025103,
|
"lastModified": 1732420764,
|
||||||
"narHash": "sha256-qjEI64RKvDxRyEarY0jTzrZMa8ebezh2DEZmJJrpVdo=",
|
"narHash": "sha256-u6JOOVlnGe8fMekW0BgaHuuZwbJp4ixQaMA5BEvRoDA=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "a46e702093a5c46e192243edbd977d5749e7f294",
|
"rev": "67cd4814a247fd0fe97171acb90659f7e304bcb8",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -329,11 +329,11 @@
|
|||||||
"xdph": "xdph"
|
"xdph": "xdph"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1732242702,
|
"lastModified": 1732416388,
|
||||||
"narHash": "sha256-fJ+fGtTRLSMBdaz0q2yi2xlC0gMTo+4cGjcLlwtOGQk=",
|
"narHash": "sha256-9kCpC9NtQwm5hrPseqLF8nN2eWZv/3I1KmuvNlxv03w=",
|
||||||
"owner": "hyprwm",
|
"owner": "hyprwm",
|
||||||
"repo": "Hyprland",
|
"repo": "Hyprland",
|
||||||
"rev": "b1003445953474b967464d4d0878955d37498647",
|
"rev": "55ec8bd512605a014cc322d3419a9cfa72178340",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|||||||
11
flake.nix
11
flake.nix
@ -11,6 +11,7 @@
|
|||||||
hyprland = {
|
hyprland = {
|
||||||
url = "github:hyprwm/Hyprland";
|
url = "github:hyprwm/Hyprland";
|
||||||
};
|
};
|
||||||
|
|
||||||
#hyprland-plugins = {
|
#hyprland-plugins = {
|
||||||
# url = "github:hyprwm/hyprland-plugins";
|
# url = "github:hyprwm/hyprland-plugins";
|
||||||
# inputs.hyprland.follows = "hyprland";
|
# inputs.hyprland.follows = "hyprland";
|
||||||
@ -42,6 +43,10 @@
|
|||||||
nix-ld,
|
nix-ld,
|
||||||
...
|
...
|
||||||
} @ inputs: let
|
} @ inputs: let
|
||||||
|
|
||||||
|
username = "foglar";
|
||||||
|
hostname = "laptop";
|
||||||
|
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
|
|
||||||
pkgs = import nixpkgs {
|
pkgs = import nixpkgs {
|
||||||
@ -62,13 +67,15 @@
|
|||||||
in {
|
in {
|
||||||
nixosConfigurations = {
|
nixosConfigurations = {
|
||||||
laptop = nixpkgs.lib.nixosSystem {
|
laptop = nixpkgs.lib.nixosSystem {
|
||||||
specialArgs = {inherit inputs system pkgs pkgs-stable;};
|
specialArgs = {
|
||||||
|
inherit inputs system pkgs pkgs-stable username hostname;
|
||||||
|
};
|
||||||
|
|
||||||
modules = [
|
modules = [
|
||||||
./nixos/configuration.nix
|
./nixos/configuration.nix
|
||||||
inputs.stylix.nixosModules.stylix
|
inputs.stylix.nixosModules.stylix
|
||||||
nix-ld.nixosModules.nix-ld
|
nix-ld.nixosModules.nix-ld
|
||||||
{ programs.nix-ld.dev.enable = true; }
|
{programs.nix-ld.dev.enable = true;}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@ -2,6 +2,7 @@
|
|||||||
inputs,
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
pkgs-stable,
|
pkgs-stable,
|
||||||
|
username,
|
||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
imports = [
|
imports = [
|
||||||
@ -28,14 +29,14 @@
|
|||||||
WLR_NO_HARDWARE_CURSORS = "1";
|
WLR_NO_HARDWARE_CURSORS = "1";
|
||||||
NIXOS_OZONE_WL = "1";
|
NIXOS_OZONE_WL = "1";
|
||||||
EDITOR = "nvim";
|
EDITOR = "nvim";
|
||||||
FLAKE = "/home/foglar/dotfiles";
|
FLAKE = "/home/${username}/dotfiles";
|
||||||
|
|
||||||
DEFAULT_BROWSER = "${pkgs.librewolf}/bin/librewolf";
|
DEFAULT_BROWSER = "${pkgs.librewolf}/bin/librewolf";
|
||||||
};
|
};
|
||||||
|
|
||||||
users.users.foglar = {
|
users.users.${username} = {
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
description = "foglar";
|
description = "${username}";
|
||||||
extraGroups = ["wheel"];
|
extraGroups = ["wheel"];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -148,7 +148,7 @@
|
|||||||
"$mod" = "SUPER";
|
"$mod" = "SUPER";
|
||||||
"$term" = "${pkgs.kitty}/bin/kitty";
|
"$term" = "${pkgs.kitty}/bin/kitty";
|
||||||
"$editor" = "${pkgs.vscode}/bin/code";
|
"$editor" = "${pkgs.vscode}/bin/code";
|
||||||
"$file" = "dolphin";
|
"$file" = "nautilus";
|
||||||
"$browser" = "${pkgs.librewolf}/bin/librewolf";
|
"$browser" = "${pkgs.librewolf}/bin/librewolf";
|
||||||
|
|
||||||
animations = {
|
animations = {
|
||||||
|
|||||||
@ -5,8 +5,6 @@
|
|||||||
hypridle
|
hypridle
|
||||||
hyprpolkitagent
|
hyprpolkitagent
|
||||||
|
|
||||||
kdePackages.dolphin
|
|
||||||
|
|
||||||
dunst
|
dunst
|
||||||
libnotify
|
libnotify
|
||||||
swayosd
|
swayosd
|
||||||
@ -81,5 +79,6 @@
|
|||||||
#(writeShellScriptBin "rofilaunch" '''')
|
#(writeShellScriptBin "rofilaunch" '''')
|
||||||
]) ++ (with pkgs-stable; [
|
]) ++ (with pkgs-stable; [
|
||||||
pavucontrol
|
pavucontrol
|
||||||
|
gnome.nautilus
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -69,7 +69,7 @@
|
|||||||
orientation = mkLiteral "vertical";
|
orientation = mkLiteral "vertical";
|
||||||
children = ["inputbar" "listbox"];
|
children = ["inputbar" "listbox"];
|
||||||
background-color = mkLiteral "transparent";
|
background-color = mkLiteral "transparent";
|
||||||
background-image = mkLiteral "url(\"~/dotfiles/nixos/aurora_borealis.png\", height)";
|
background-image = mkLiteral "url(\"~/dotfiles/config/backgrounds/aurora_borealis.png\", height)";
|
||||||
};
|
};
|
||||||
|
|
||||||
# Input bar settings
|
# Input bar settings
|
||||||
@ -79,7 +79,7 @@
|
|||||||
padding = mkLiteral "5em";
|
padding = mkLiteral "5em";
|
||||||
children = ["entry"];
|
children = ["entry"];
|
||||||
background-color = mkLiteral "transparent";
|
background-color = mkLiteral "transparent";
|
||||||
background-image = mkLiteral "url(\"~/dotfiles/nixos/aurora_borealis.png\", width)";
|
background-image = mkLiteral "url(\"~/dotfiles/config/backgrounds/aurora_borealis.png\", width)";
|
||||||
};
|
};
|
||||||
|
|
||||||
# Entry field settings
|
# Entry field settings
|
||||||
|
|||||||
@ -14,37 +14,6 @@
|
|||||||
|
|
||||||
gtk.enable = true;
|
gtk.enable = true;
|
||||||
|
|
||||||
programs.bash = {
|
|
||||||
enable = true;
|
|
||||||
enableCompletion = true;
|
|
||||||
|
|
||||||
shellAliases = {
|
|
||||||
vim = "nvim";
|
|
||||||
ls = "exa --icons";
|
|
||||||
ll = "exa -alh --icons";
|
|
||||||
tree = "exa --tree --icons";
|
|
||||||
open = "rifle";
|
|
||||||
ip = "ip -c";
|
|
||||||
s = "kitten ssh";
|
|
||||||
diff = "diff --color";
|
|
||||||
cd = "z";
|
|
||||||
|
|
||||||
respawn = "clear; pfetch";
|
|
||||||
l = "eza -lh --icons=auto";
|
|
||||||
mkdir = "mkdir -p";
|
|
||||||
cat = "bat --style plain";
|
|
||||||
rasp = "s foglar@192.168.8.140";
|
|
||||||
hist = "history | awk '{for (i=2; i<=NF; i++) printf \$i\" \"; print \"\"}' | fzf | wl-copy";
|
|
||||||
packages = "paru -Qe | fzf | wl-copy";
|
|
||||||
cdx = "zoxide query --interactive";
|
|
||||||
|
|
||||||
distrobox-enter = "distrobox-enter --root";
|
|
||||||
distrobox-create = "distrobox-create --root";
|
|
||||||
};
|
|
||||||
|
|
||||||
bashrcExtra = ''
|
|
||||||
pfetch'';
|
|
||||||
};
|
|
||||||
|
|
||||||
home.file = {
|
home.file = {
|
||||||
".config/hypr/hyprlock.conf".source = ../config/hyprlock.conf;
|
".config/hypr/hyprlock.conf".source = ../config/hyprlock.conf;
|
||||||
@ -58,14 +27,6 @@
|
|||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
home.sessionVariables = {
|
|
||||||
EDITOR = "nvim";
|
|
||||||
FLAKE = "/home/foglar/dotfiles";
|
|
||||||
XDG_DATA_HOME = "$HOME/.local/share";
|
|
||||||
XDG_PICTURES_DIR = "$HOME/Pictures/Screenshots/";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Let Home Manager install and manage itself.
|
# Let Home Manager install and manage itself.
|
||||||
programs.home-manager.enable = true;
|
programs.home-manager.enable = true;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -23,13 +23,13 @@
|
|||||||
libreoffice
|
libreoffice
|
||||||
localsend
|
localsend
|
||||||
plasma5Packages.kdeconnect-kde
|
plasma5Packages.kdeconnect-kde
|
||||||
qbittorrent
|
|
||||||
vlc
|
vlc
|
||||||
openrocket
|
openrocket
|
||||||
spotify
|
spotify
|
||||||
spotube
|
spotube
|
||||||
inkscape
|
inkscape
|
||||||
gnome-disk-utility
|
gnome-disk-utility
|
||||||
|
qbittorrent
|
||||||
])
|
])
|
||||||
++ (with pkgs-stable; [
|
++ (with pkgs-stable; [
|
||||||
loupe
|
loupe
|
||||||
|
|||||||
@ -12,8 +12,8 @@
|
|||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
vitetris
|
vitetris
|
||||||
steam
|
steam
|
||||||
|
superTuxKart
|
||||||
heroic
|
heroic
|
||||||
gamescope
|
|
||||||
wine
|
wine
|
||||||
|
|
||||||
(writeShellScriptBin "nvidia-offload" ''
|
(writeShellScriptBin "nvidia-offload" ''
|
||||||
@ -23,6 +23,36 @@
|
|||||||
export __VK_LAYER_NV_optimus=NVIDIA_only
|
export __VK_LAYER_NV_optimus=NVIDIA_only
|
||||||
exec "$@"
|
exec "$@"
|
||||||
'')
|
'')
|
||||||
|
|
||||||
|
(writeShellScriptBin "gs" ''
|
||||||
|
set -xeuo pipefail
|
||||||
|
|
||||||
|
gamescopeArgs=(
|
||||||
|
--adaptive-sync # VRR support
|
||||||
|
--hdr-enabled
|
||||||
|
--mangoapp # performance overlay
|
||||||
|
--rt
|
||||||
|
--steam
|
||||||
|
)
|
||||||
|
steamArgs=(
|
||||||
|
-pipewire-dmabuf
|
||||||
|
-tenfoot
|
||||||
|
)
|
||||||
|
mangoConfig=(
|
||||||
|
cpu_temp
|
||||||
|
gpu_temp
|
||||||
|
ram
|
||||||
|
vram
|
||||||
|
)
|
||||||
|
mangoVars=(
|
||||||
|
MANGOHUD=1
|
||||||
|
MANGOHUD_CONFIG="$(IFS=,; echo "''${mangoConfig[*]}")"
|
||||||
|
)
|
||||||
|
|
||||||
|
export "''${mangoVars[@]}"
|
||||||
|
exec gamescope "''${gamescopeArgs[@]}" -- steam "''${steamArgs[@]}"
|
||||||
|
|
||||||
|
'')
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -30,7 +30,6 @@
|
|||||||
"discord"
|
"discord"
|
||||||
"spotify"
|
"spotify"
|
||||||
|
|
||||||
"webstorm"
|
|
||||||
"pycharm"
|
"pycharm"
|
||||||
"pycharm-professional"
|
"pycharm-professional"
|
||||||
|
|
||||||
|
|||||||
@ -5,10 +5,10 @@
|
|||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
options = {
|
options = {
|
||||||
vscode.enable = lib.mkEnableOption "enable vscode";
|
programming.vscode.enable = lib.mkEnableOption "enable vscode";
|
||||||
};
|
};
|
||||||
|
|
||||||
config = lib.mkIf config.vscode.enable {
|
config = lib.mkIf config.programming.vscode.enable {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
vscode
|
vscode
|
||||||
gopls
|
gopls
|
||||||
@ -37,6 +37,7 @@
|
|||||||
"security.workspace.trust.enabled" = false;
|
"security.workspace.trust.enabled" = false;
|
||||||
"terminal.external.linuxExec" = "kitty";
|
"terminal.external.linuxExec" = "kitty";
|
||||||
"terminal.integrated.stickyScroll.enabled" = true;
|
"terminal.integrated.stickyScroll.enabled" = true;
|
||||||
|
"terminal.integrated.inheritEnv"= false;
|
||||||
"telemetry.telemetryLevel" = "off";
|
"telemetry.telemetryLevel" = "off";
|
||||||
"workbench.activityBar.location" = "hidden"; # bottom
|
"workbench.activityBar.location" = "hidden"; # bottom
|
||||||
"workbench.iconTheme" = "material-icon-theme";
|
"workbench.iconTheme" = "material-icon-theme";
|
||||||
|
|||||||
@ -6,10 +6,10 @@
|
|||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
options = {
|
options = {
|
||||||
git.enable = lib.mkEnableOption "enable git";
|
programming.git.enable = lib.mkEnableOption "enable git";
|
||||||
};
|
};
|
||||||
|
|
||||||
config = lib.mkIf config.git.enable {
|
config = lib.mkIf config.programming.git.enable {
|
||||||
programs.git = {
|
programs.git = {
|
||||||
enable = true;
|
enable = true;
|
||||||
userName = "foglar";
|
userName = "foglar";
|
||||||
|
|||||||
@ -17,8 +17,8 @@
|
|||||||
|
|
||||||
config = lib.mkIf config.programming.enable {
|
config = lib.mkIf config.programming.enable {
|
||||||
|
|
||||||
vscode.enable = lib.mkDefault true;
|
programming.vscode.enable = lib.mkDefault true;
|
||||||
git.enable = lib.mkDefault true;
|
programming.git.enable = lib.mkDefault true;
|
||||||
|
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
neovim
|
neovim
|
||||||
@ -27,7 +27,6 @@
|
|||||||
go
|
go
|
||||||
jq
|
jq
|
||||||
conda
|
conda
|
||||||
jetbrains.webstorm
|
|
||||||
jetbrains.pycharm-professional
|
jetbrains.pycharm-professional
|
||||||
dotnet-sdk_8
|
dotnet-sdk_8
|
||||||
nodejs
|
nodejs
|
||||||
|
|||||||
@ -15,7 +15,8 @@
|
|||||||
|
|
||||||
config = lib.mkIf config.terminal_tools.enable {
|
config = lib.mkIf config.terminal_tools.enable {
|
||||||
|
|
||||||
oh-my-posh.enable = lib.mkDefault true;
|
shell.bash.enable = lib.mkDefault true;
|
||||||
|
shell.bash.oh-my-posh.enable = lib.mkDefault true;
|
||||||
|
|
||||||
programs = {
|
programs = {
|
||||||
bat.enable = true;
|
bat.enable = true;
|
||||||
|
|||||||
@ -5,10 +5,10 @@
|
|||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
options = {
|
options = {
|
||||||
oh-my-posh.enable = lib.mkEnableOption "enable oh-my-posh";
|
shell.oh-my-posh.enable = lib.mkEnableOption "enable oh-my-posh";
|
||||||
};
|
};
|
||||||
|
|
||||||
config = lib.mkIf config.oh-my-posh.enable {
|
config = lib.mkIf config.shell.oh-my-posh.enable {
|
||||||
programs.oh-my-posh = {
|
programs.oh-my-posh = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enableBashIntegration = true;
|
enableBashIntegration = true;
|
||||||
|
|||||||
47
nixos/packages/tools/shell.nix
Normal file
47
nixos/packages/tools/shell.nix
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{lib, ...}: {
|
||||||
|
options = {
|
||||||
|
shell.enable =
|
||||||
|
lib.mkEnableOption "enables shell tools";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf lib.config.shell.enable {
|
||||||
|
programs.bash = {
|
||||||
|
enable = true;
|
||||||
|
enableCompletion = true;
|
||||||
|
|
||||||
|
shellAliases = {
|
||||||
|
vim = "nvim";
|
||||||
|
ls = "exa --icons";
|
||||||
|
ll = "exa -alh --icons";
|
||||||
|
tree = "exa --tree --icons";
|
||||||
|
open = "rifle";
|
||||||
|
ip = "ip -c";
|
||||||
|
s = "kitten ssh";
|
||||||
|
diff = "diff --color";
|
||||||
|
cd = "z";
|
||||||
|
|
||||||
|
respawn = "clear; pfetch";
|
||||||
|
l = "eza -lh --icons=auto";
|
||||||
|
mkdir = "mkdir -p";
|
||||||
|
cat = "bat --style plain";
|
||||||
|
rasp = "s foglar@192.168.8.140";
|
||||||
|
hist = "history | awk '{for (i=2; i<=NF; i++) printf \$i\" \"; print \"\"}' | fzf | wl-copy";
|
||||||
|
cdx = "zoxide query --interactive";
|
||||||
|
|
||||||
|
distrobox-enter = "distrobox-enter --root";
|
||||||
|
distrobox-create = "distrobox-create --root";
|
||||||
|
distrobox-list = "distrobox-list --root";
|
||||||
|
};
|
||||||
|
|
||||||
|
bashrcExtra = ''
|
||||||
|
pfetch'';
|
||||||
|
};
|
||||||
|
|
||||||
|
home.sessionVariables = {
|
||||||
|
EDITOR = "nvim";
|
||||||
|
FLAKE = "/home/foglar/dotfiles";
|
||||||
|
XDG_DATA_HOME = "$HOME/.local/share";
|
||||||
|
XDG_PICTURES_DIR = "$HOME/Pictures/Screenshots/";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -13,6 +13,7 @@
|
|||||||
tor.enable = lib.mkDefault true;
|
tor.enable = lib.mkDefault true;
|
||||||
virt-manager.enable = lib.mkDefault true;
|
virt-manager.enable = lib.mkDefault true;
|
||||||
};
|
};
|
||||||
|
desktop.steamdeck.enable = lib.mkDefault false;
|
||||||
programs.kdeconnect.enable = true;
|
programs.kdeconnect.enable = true;
|
||||||
programs.wireshark.enable = true;
|
programs.wireshark.enable = true;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
lib,
|
lib,
|
||||||
config,
|
config,
|
||||||
|
username,
|
||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
options = {
|
options = {
|
||||||
@ -16,6 +17,6 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
users.users.foglar.extraGroups = [ "docker" ];
|
users.users.${username}.extraGroups = [ "docker" ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,18 +1,33 @@
|
|||||||
{
|
{
|
||||||
lib,
|
lib,
|
||||||
config,
|
config,
|
||||||
|
pkgs,
|
||||||
|
username,
|
||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
options = {
|
options = {
|
||||||
package.steam.enable = lib.mkEnableOption "Enable Steam module";
|
package.steam.enable = lib.mkEnableOption "Enable Steam module";
|
||||||
|
desktop.steamdeck.enable = lib.mkEnableOption "Enable Steam desktop integration";
|
||||||
};
|
};
|
||||||
|
|
||||||
config = lib.mkIf config.package.steam.enable {
|
config = lib.mkMerge [
|
||||||
|
(lib.mkIf config.package.steam.enable {
|
||||||
programs.steam = {
|
programs.steam = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
gamescopeSession.enable = true;
|
||||||
remotePlay.openFirewall = true; # Open ports in the firewall for Steam Remote Play
|
remotePlay.openFirewall = true; # Open ports in the firewall for Steam Remote Play
|
||||||
dedicatedServer.openFirewall = true; # Open ports in the firewall for Source Dedicated Server
|
dedicatedServer.openFirewall = true; # Open ports in the firewall for Source Dedicated Server
|
||||||
localNetworkGameTransfers.openFirewall = true; # Open ports in the firewall for Steam Local Network Game Transfers
|
localNetworkGameTransfers.openFirewall = true; # Open ports in the firewall for Steam Local Network Game Transfers
|
||||||
};
|
};
|
||||||
|
})
|
||||||
|
(lib.mkIf config.desktop.steamdeck.enable {
|
||||||
|
services.getty.autologinUser = "${username}";
|
||||||
|
environment = {
|
||||||
|
systemPackages = [pkgs.mangohud];
|
||||||
|
loginShellInit = ''
|
||||||
|
[[ "$(tty)" = "/dev/tty1" ]] && gs
|
||||||
|
'';
|
||||||
};
|
};
|
||||||
|
})
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,11 @@
|
|||||||
{...}:
|
|
||||||
{
|
{
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
options.sys.audio.enable = lib.mkEnableOption "Enable audio support";
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.audio.enable {
|
||||||
# Enable sound with pipewire.
|
# Enable sound with pipewire.
|
||||||
hardware.pulseaudio.enable = false;
|
hardware.pulseaudio.enable = false;
|
||||||
security.rtkit.enable = true;
|
security.rtkit.enable = true;
|
||||||
@ -15,4 +21,5 @@
|
|||||||
# no need to redefine it in your config for now)
|
# no need to redefine it in your config for now)
|
||||||
#media-session.enable = true;
|
#media-session.enable = true;
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
@ -1,30 +1,19 @@
|
|||||||
{
|
{
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
inputs,
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
...
|
...
|
||||||
}:
|
}: {
|
||||||
{
|
options = {
|
||||||
services.desktopManager.plasma6.enable = true;
|
sys.desktop.plasma.enable = lib.mkEnableOption "Plasma Desktop";
|
||||||
#services.xserver.desktopManager.gnome.enable = true;
|
sys.desktop.gnome.enable = lib.mkEnableOption "GNOME Desktop";
|
||||||
|
sys.desktop.hyprland.enable = lib.mkEnableOption "Hyprland Desktop";
|
||||||
|
};
|
||||||
|
|
||||||
#environment.gnome.excludePackages = with pkgs; [
|
config = lib.mkMerge [
|
||||||
# gnome-tour
|
(lib.mkIf config.sys.desktop.plasma.enable {
|
||||||
# gnome-connections
|
services.desktopManager.plasma6.enable = true;
|
||||||
# epiphany # web browser
|
|
||||||
# geary # email reader. Up to 24.05. Starting from 24.11 the package name is just geary.
|
|
||||||
# #evince # document viewer
|
|
||||||
# gnome-weather
|
|
||||||
# gnome-contacts
|
|
||||||
# gnome-maps
|
|
||||||
# gnome-logs
|
|
||||||
# gnome-music
|
|
||||||
# gnome-system-monitor
|
|
||||||
# gnome-text-editor
|
|
||||||
# yelp
|
|
||||||
# totem
|
|
||||||
# snapshot
|
|
||||||
# seahorse
|
|
||||||
#];
|
|
||||||
|
|
||||||
environment.plasma6.excludePackages = with pkgs.kdePackages; [
|
environment.plasma6.excludePackages = with pkgs.kdePackages; [
|
||||||
ark
|
ark
|
||||||
@ -38,11 +27,38 @@
|
|||||||
krdp
|
krdp
|
||||||
khelpcenter
|
khelpcenter
|
||||||
];
|
];
|
||||||
|
})
|
||||||
|
|
||||||
|
(lib.mkIf config.sys.desktop.gnome.enable {
|
||||||
|
services.xserver.desktopManager.gnome.enable = true;
|
||||||
|
|
||||||
|
environment.gnome.excludePackages = with pkgs; [
|
||||||
|
gnome-tour
|
||||||
|
gnome-connections
|
||||||
|
epiphany # web browser
|
||||||
|
geary # email reader. Up to 24.05. Starting from 24.11 the package name is just geary.
|
||||||
|
#evince # document viewer
|
||||||
|
gnome-weather
|
||||||
|
gnome-contacts
|
||||||
|
gnome-maps
|
||||||
|
gnome-logs
|
||||||
|
gnome-music
|
||||||
|
gnome-system-monitor
|
||||||
|
gnome-text-editor
|
||||||
|
yelp
|
||||||
|
totem
|
||||||
|
snapshot
|
||||||
|
seahorse
|
||||||
|
];
|
||||||
|
})
|
||||||
|
|
||||||
|
(lib.mkIf config.sys.desktop.hyprland.enable {
|
||||||
programs.hyprland = {
|
programs.hyprland = {
|
||||||
enable = true;
|
enable = true;
|
||||||
xwayland.enable = true;
|
xwayland.enable = true;
|
||||||
package = inputs.hyprland.packages."${pkgs.system}".hyprland;
|
package = inputs.hyprland.packages."${pkgs.system}".hyprland;
|
||||||
portalPackage = pkgs.xdg-desktop-portal-hyprland;
|
portalPackage = pkgs.xdg-desktop-portal-hyprland;
|
||||||
};
|
};
|
||||||
|
})
|
||||||
|
];
|
||||||
}
|
}
|
||||||
@ -1,8 +1,19 @@
|
|||||||
{pkgs, ...}: {
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
options = {
|
||||||
|
sys.fonts.packages = pkgs.lib.mkEnableOption "Install fonts";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.fonts.packages {
|
||||||
fonts.packages = with pkgs; [
|
fonts.packages = with pkgs; [
|
||||||
noto-fonts
|
noto-fonts
|
||||||
noto-fonts-emoji
|
noto-fonts-emoji
|
||||||
(nerdfonts.override {fonts = ["JetBrainsMono"];})
|
(nerdfonts.override {fonts = ["JetBrainsMono"];})
|
||||||
monaspace
|
monaspace
|
||||||
];
|
];
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,4 +1,15 @@
|
|||||||
{...}: {
|
{
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
options = {
|
||||||
|
sys.locales = {
|
||||||
|
enable = lib.mkEnableOption "Enable locales configuration";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.locales.enable {
|
||||||
# Set your time zone.
|
# Set your time zone.
|
||||||
time.timeZone = "Europe/Prague";
|
time.timeZone = "Europe/Prague";
|
||||||
# Select internationalisation properties.
|
# Select internationalisation properties.
|
||||||
@ -20,4 +31,5 @@
|
|||||||
xkb.layout = "us,cz";
|
xkb.layout = "us,cz";
|
||||||
xkb.options = "grp:win_space_toggle";
|
xkb.options = "grp:win_space_toggle";
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,18 @@
|
|||||||
{...}: {
|
{
|
||||||
networking.hostName = "laptop"; # Define your hostname.
|
lib,
|
||||||
|
config,
|
||||||
|
hostname,
|
||||||
|
username,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
options = {
|
||||||
|
sys.network.enable = lib.mkEnableOption "Enable networking";
|
||||||
|
sys.bluetooth.enable = lib.mkEnableOption "Enable Bluetooth support";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkMerge [
|
||||||
|
(lib.mkIf config.sys.network.enable {
|
||||||
|
networking.hostName = "${hostname}"; # Define your hostname.
|
||||||
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
|
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
|
||||||
|
|
||||||
# Configure network proxy if necessary
|
# Configure network proxy if necessary
|
||||||
@ -8,9 +21,14 @@
|
|||||||
|
|
||||||
# Enable networking
|
# Enable networking
|
||||||
networking.networkmanager.enable = true;
|
networking.networkmanager.enable = true;
|
||||||
|
users.users.${username}.extraGroups = ["networkmanager"];
|
||||||
|
})
|
||||||
|
(
|
||||||
|
lib.mkIf config.sys.bluetooth.enable {
|
||||||
hardware.bluetooth.enable = true; # enables support for Bluetooth
|
hardware.bluetooth.enable = true; # enables support for Bluetooth
|
||||||
hardware.bluetooth.powerOnBoot = true; # powers up the default Bluetooth controller on boot
|
hardware.bluetooth.powerOnBoot = true; # powers up the default Bluetooth controller on boot
|
||||||
services.blueman.enable = true;
|
services.blueman.enable = true;
|
||||||
|
}
|
||||||
users.users.foglar.extraGroups = [ "networkmanager" ];
|
)
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,4 +1,13 @@
|
|||||||
{config, ...}: {
|
{
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
options = {
|
||||||
|
sys.nvidia.enable = lib.mkEnableOption "Enable Nvidia graphics support";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.nvidia.enable {
|
||||||
hardware = {
|
hardware = {
|
||||||
graphics.enable = true;
|
graphics.enable = true;
|
||||||
};
|
};
|
||||||
@ -42,4 +51,5 @@
|
|||||||
# Optionally, you may need to select the appropriate driver version for your specific GPU.
|
# Optionally, you may need to select the appropriate driver version for your specific GPU.
|
||||||
package = config.boot.kernelPackages.nvidiaPackages.stable;
|
package = config.boot.kernelPackages.nvidiaPackages.stable;
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,15 @@
|
|||||||
{pkgs, ...}: {
|
{
|
||||||
# Printing
|
lib,
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
username,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
options = {
|
||||||
|
sys.printing.enable = lib.mkEnableOption "Enable printing support";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.printing.enable {
|
||||||
services.printing.enable = true;
|
services.printing.enable = true;
|
||||||
services.printing.drivers = with pkgs; [gutenprint hplip splix];
|
services.printing.drivers = with pkgs; [gutenprint hplip splix];
|
||||||
hardware.printers = {
|
hardware.printers = {
|
||||||
@ -22,5 +32,6 @@
|
|||||||
services.ipp-usb.enable = true;
|
services.ipp-usb.enable = true;
|
||||||
hardware.sane.extraBackends = [pkgs.hplipWithPlugin];
|
hardware.sane.extraBackends = [pkgs.hplipWithPlugin];
|
||||||
|
|
||||||
users.users.foglar.extraGroups = ["lp" "scanner"];
|
users.users.${username}.extraGroups = ["lp" "scanner"];
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,10 +1,14 @@
|
|||||||
{
|
{
|
||||||
pkgs,
|
|
||||||
lib,
|
lib,
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
...
|
...
|
||||||
}:
|
}: {
|
||||||
{
|
options = {
|
||||||
|
sys.sddm.enable = lib.mkEnableOption "Enable SDDM login";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.sddm.enable {
|
||||||
services.displayManager = {
|
services.displayManager = {
|
||||||
defaultSession = "hyprland";
|
defaultSession = "hyprland";
|
||||||
sddm = {
|
sddm = {
|
||||||
@ -25,4 +29,5 @@
|
|||||||
};
|
};
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
|
};
|
||||||
}
|
}
|
||||||
@ -1,8 +1,14 @@
|
|||||||
{
|
{
|
||||||
|
lib,
|
||||||
|
config,
|
||||||
pkgs,
|
pkgs,
|
||||||
...
|
...
|
||||||
}:
|
}: {
|
||||||
{
|
options = {
|
||||||
|
sys.style.enable = lib.mkEnableOption "Enable the Stylix theme manager.";
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf config.sys.style.enable {
|
||||||
stylix = {
|
stylix = {
|
||||||
enable = true;
|
enable = true;
|
||||||
image = ../../../config/backgrounds/aurora_borealis.png;
|
image = ../../../config/backgrounds/aurora_borealis.png;
|
||||||
@ -33,4 +39,5 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
@ -1,5 +1,4 @@
|
|||||||
{...}:
|
{lib, ...}: {
|
||||||
{
|
|
||||||
imports = [
|
imports = [
|
||||||
./sys/audio.nix
|
./sys/audio.nix
|
||||||
./sys/desktops.nix
|
./sys/desktops.nix
|
||||||
@ -11,4 +10,21 @@
|
|||||||
./sys/sddm.nix
|
./sys/sddm.nix
|
||||||
./sys/style.nix
|
./sys/style.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
sys = {
|
||||||
|
audio.enable = lib.mkDefault true;
|
||||||
|
desktop = {
|
||||||
|
plasma.enable = lib.mkDefault true;
|
||||||
|
gnome.enable = lib.mkDefault false;
|
||||||
|
hyprland.enable = lib.mkDefault true;
|
||||||
|
};
|
||||||
|
fonts.packages = lib.mkDefault true;
|
||||||
|
locales.enable = lib.mkDefault true;
|
||||||
|
network.enable = lib.mkDefault true;
|
||||||
|
bluetooth.enable = lib.mkDefault true;
|
||||||
|
nvidia.enable = lib.mkDefault true;
|
||||||
|
printing.enable = lib.mkDefault true;
|
||||||
|
sddm.enable = lib.mkDefault true;
|
||||||
|
style.enable = lib.mkDefault true;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
Loading…
Reference in New Issue
Block a user