Switch to Niri WM
This commit is contained in:
parent
b89a6b83f0
commit
c8f81f4190
15 changed files with 1196 additions and 443 deletions
427
flake.lock
generated
427
flake.lock
generated
|
@ -1,5 +1,72 @@
|
||||||
{
|
{
|
||||||
"nodes": {
|
"nodes": {
|
||||||
|
"base16": {
|
||||||
|
"inputs": {
|
||||||
|
"fromYaml": "fromYaml"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1746562888,
|
||||||
|
"narHash": "sha256-YgNJQyB5dQiwavdDFBMNKk1wyS77AtdgDk/VtU6wEaI=",
|
||||||
|
"owner": "SenchoPens",
|
||||||
|
"repo": "base16.nix",
|
||||||
|
"rev": "806a1777a5db2a1ef9d5d6f493ef2381047f2b89",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "SenchoPens",
|
||||||
|
"repo": "base16.nix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"base16-fish": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1622559957,
|
||||||
|
"narHash": "sha256-PebymhVYbL8trDVVXxCvZgc0S5VxI7I1Hv4RMSquTpA=",
|
||||||
|
"owner": "tomyun",
|
||||||
|
"repo": "base16-fish",
|
||||||
|
"rev": "2f6dd973a9075dabccd26f1cded09508180bf5fe",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tomyun",
|
||||||
|
"repo": "base16-fish",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"base16-helix": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1748408240,
|
||||||
|
"narHash": "sha256-9M2b1rMyMzJK0eusea0x3lyh3mu5nMeEDSc4RZkGm+g=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "base16-helix",
|
||||||
|
"rev": "6c711ab1a9db6f51e2f6887cc3345530b33e152e",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "base16-helix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"base16-vim": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1732806396,
|
||||||
|
"narHash": "sha256-e0bpPySdJf0F68Ndanwm+KWHgQiZ0s7liLhvJSWDNsA=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "base16-vim",
|
||||||
|
"rev": "577fe8125d74ff456cf942c733a85d769afe58b7",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "base16-vim",
|
||||||
|
"rev": "577fe8125d74ff456cf942c733a85d769afe58b7",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"crane": {
|
"crane": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752946753,
|
"lastModified": 1752946753,
|
||||||
|
@ -35,6 +102,22 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"firefox-gnome-theme": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1748383148,
|
||||||
|
"narHash": "sha256-pGvD/RGuuPf/4oogsfeRaeMm6ipUIznI2QSILKjKzeA=",
|
||||||
|
"owner": "rafaelmardojai",
|
||||||
|
"repo": "firefox-gnome-theme",
|
||||||
|
"rev": "4eb2714fbed2b80e234312611a947d6cb7d70caf",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "rafaelmardojai",
|
||||||
|
"repo": "firefox-gnome-theme",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"flake-compat": {
|
"flake-compat": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
|
@ -109,6 +192,27 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"flake-parts_3": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs-lib": [
|
||||||
|
"stylix",
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1749398372,
|
||||||
|
"narHash": "sha256-tYBdgS56eXYaWVW3fsnPQ/nFlgWi/Z2Ymhyu21zVM98=",
|
||||||
|
"owner": "hercules-ci",
|
||||||
|
"repo": "flake-parts",
|
||||||
|
"rev": "9305fe4e5c2a6fcf5ba6a3ff155720fbe4076569",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "hercules-ci",
|
||||||
|
"repo": "flake-parts",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"flake-utils": {
|
"flake-utils": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"systems": "systems_2"
|
"systems": "systems_2"
|
||||||
|
@ -127,6 +231,22 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"fromYaml": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1731966426,
|
||||||
|
"narHash": "sha256-lq95WydhbUTWig/JpqiB7oViTcHFP8Lv41IGtayokA8=",
|
||||||
|
"owner": "SenchoPens",
|
||||||
|
"repo": "fromYaml",
|
||||||
|
"rev": "106af9e2f715e2d828df706c386a685698f3223b",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "SenchoPens",
|
||||||
|
"repo": "fromYaml",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"gitignore": {
|
"gitignore": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
|
@ -149,6 +269,23 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"gnome-shell": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1744584021,
|
||||||
|
"narHash": "sha256-0RJ4mJzf+klKF4Fuoc8VN8dpQQtZnKksFmR2jhWE1Ew=",
|
||||||
|
"owner": "GNOME",
|
||||||
|
"repo": "gnome-shell",
|
||||||
|
"rev": "52c517c8f6c199a1d6f5118fae500ef69ea845ae",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "GNOME",
|
||||||
|
"ref": "48.1",
|
||||||
|
"repo": "gnome-shell",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"home-manager": {
|
"home-manager": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
|
@ -223,6 +360,64 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"niri": {
|
||||||
|
"inputs": {
|
||||||
|
"niri-stable": "niri-stable",
|
||||||
|
"niri-unstable": "niri-unstable",
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
],
|
||||||
|
"nixpkgs-stable": "nixpkgs-stable",
|
||||||
|
"xwayland-satellite-stable": "xwayland-satellite-stable",
|
||||||
|
"xwayland-satellite-unstable": "xwayland-satellite-unstable"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1754098183,
|
||||||
|
"narHash": "sha256-xiDTiBJlApXRiuTmOrdGaiJzs33lIdQepyCI8r9hy5w=",
|
||||||
|
"owner": "sodiboo",
|
||||||
|
"repo": "niri-flake",
|
||||||
|
"rev": "f2a7b326dc420360a66a542f2262081763f0f9ab",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "sodiboo",
|
||||||
|
"repo": "niri-flake",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"niri-stable": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1748151941,
|
||||||
|
"narHash": "sha256-z4viQZLgC2bIJ3VrzQnR+q2F3gAOEQpU1H5xHtX/2fs=",
|
||||||
|
"owner": "YaLTeR",
|
||||||
|
"repo": "niri",
|
||||||
|
"rev": "8ba57fcf25d2fc9565131684a839d58703f1dae7",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "YaLTeR",
|
||||||
|
"ref": "v25.05.1",
|
||||||
|
"repo": "niri",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"niri-unstable": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1753983552,
|
||||||
|
"narHash": "sha256-xnPPjASWt4/u+GmRdrHADBKKSCtIhTFY53CSKM+Xtfk=",
|
||||||
|
"owner": "YaLTeR",
|
||||||
|
"repo": "niri",
|
||||||
|
"rev": "91b6a111cf228fadaabba706d8f4d155efc63b3a",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "YaLTeR",
|
||||||
|
"repo": "niri",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nixos-hardware": {
|
"nixos-hardware": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1753122741,
|
"lastModified": 1753122741,
|
||||||
|
@ -270,6 +465,22 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"nixpkgs-stable": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1754028485,
|
||||||
|
"narHash": "sha256-IiiXB3BDTi6UqzAZcf2S797hWEPCRZOwyNThJIYhUfk=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "59e69648d345d6e8fef86158c555730fa12af9de",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixos-25.05",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nixpkgs-unstable": {
|
"nixpkgs-unstable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1753694789,
|
"lastModified": 1753694789,
|
||||||
|
@ -325,6 +536,32 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"nur": {
|
||||||
|
"inputs": {
|
||||||
|
"flake-parts": [
|
||||||
|
"stylix",
|
||||||
|
"flake-parts"
|
||||||
|
],
|
||||||
|
"nixpkgs": [
|
||||||
|
"stylix",
|
||||||
|
"nixpkgs"
|
||||||
|
],
|
||||||
|
"treefmt-nix": "treefmt-nix"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1751320053,
|
||||||
|
"narHash": "sha256-3m6RMw0FbbaUUa01PNaMLoO7D99aBClmY5ed9V3vz+0=",
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "NUR",
|
||||||
|
"rev": "cbde1735782f9c2bb2c63d5e05fba171a14a4670",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "NUR",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nuschtosSearch": {
|
"nuschtosSearch": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": "flake-utils",
|
"flake-utils": "flake-utils",
|
||||||
|
@ -379,13 +616,15 @@
|
||||||
"deploy-rs": "deploy-rs",
|
"deploy-rs": "deploy-rs",
|
||||||
"home-manager": "home-manager",
|
"home-manager": "home-manager",
|
||||||
"lanzaboote": "lanzaboote",
|
"lanzaboote": "lanzaboote",
|
||||||
|
"niri": "niri",
|
||||||
"nixos-hardware": "nixos-hardware",
|
"nixos-hardware": "nixos-hardware",
|
||||||
"nixpkgs": "nixpkgs_2",
|
"nixpkgs": "nixpkgs_2",
|
||||||
"nixpkgs-pr-feishin": "nixpkgs-pr-feishin",
|
"nixpkgs-pr-feishin": "nixpkgs-pr-feishin",
|
||||||
"nixpkgs-unstable": "nixpkgs-unstable",
|
"nixpkgs-unstable": "nixpkgs-unstable",
|
||||||
"nixvim": "nixvim",
|
"nixvim": "nixvim",
|
||||||
"secrets": "secrets",
|
"secrets": "secrets",
|
||||||
"sops-nix": "sops-nix"
|
"sops-nix": "sops-nix",
|
||||||
|
"stylix": "stylix"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"rust-overlay": {
|
"rust-overlay": {
|
||||||
|
@ -446,6 +685,41 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"stylix": {
|
||||||
|
"inputs": {
|
||||||
|
"base16": "base16",
|
||||||
|
"base16-fish": "base16-fish",
|
||||||
|
"base16-helix": "base16-helix",
|
||||||
|
"base16-vim": "base16-vim",
|
||||||
|
"firefox-gnome-theme": "firefox-gnome-theme",
|
||||||
|
"flake-parts": "flake-parts_3",
|
||||||
|
"gnome-shell": "gnome-shell",
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
],
|
||||||
|
"nur": "nur",
|
||||||
|
"systems": "systems_4",
|
||||||
|
"tinted-foot": "tinted-foot",
|
||||||
|
"tinted-kitty": "tinted-kitty",
|
||||||
|
"tinted-schemes": "tinted-schemes",
|
||||||
|
"tinted-tmux": "tinted-tmux",
|
||||||
|
"tinted-zed": "tinted-zed"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1753979771,
|
||||||
|
"narHash": "sha256-MdMdQymbivEWWkC5HqeLYtP8FYu0SqiSpiRlyw9Fm3Y=",
|
||||||
|
"owner": "danth",
|
||||||
|
"repo": "stylix",
|
||||||
|
"rev": "5b81b0c4fbab3517b39d63f493760d33287150ad",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "danth",
|
||||||
|
"ref": "release-25.05",
|
||||||
|
"repo": "stylix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"systems": {
|
"systems": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1681028828,
|
"lastModified": 1681028828,
|
||||||
|
@ -491,6 +765,124 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"systems_4": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1681028828,
|
||||||
|
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tinted-foot": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1726913040,
|
||||||
|
"narHash": "sha256-+eDZPkw7efMNUf3/Pv0EmsidqdwNJ1TaOum6k7lngDQ=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "tinted-foot",
|
||||||
|
"rev": "fd1b924b6c45c3e4465e8a849e67ea82933fcbe4",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "tinted-foot",
|
||||||
|
"rev": "fd1b924b6c45c3e4465e8a849e67ea82933fcbe4",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tinted-kitty": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1735730497,
|
||||||
|
"narHash": "sha256-4KtB+FiUzIeK/4aHCKce3V9HwRvYaxX+F1edUrfgzb8=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "tinted-kitty",
|
||||||
|
"rev": "de6f888497f2c6b2279361bfc790f164bfd0f3fa",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "tinted-kitty",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tinted-schemes": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1750770351,
|
||||||
|
"narHash": "sha256-LI+BnRoFNRa2ffbe3dcuIRYAUcGklBx0+EcFxlHj0SY=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "schemes",
|
||||||
|
"rev": "5a775c6ffd6e6125947b393872cde95867d85a2a",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "schemes",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tinted-tmux": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1751159871,
|
||||||
|
"narHash": "sha256-UOHBN1fgHIEzvPmdNMHaDvdRMgLmEJh2hNmDrp3d3LE=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "tinted-tmux",
|
||||||
|
"rev": "bded5e24407cec9d01bd47a317d15b9223a1546c",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "tinted-tmux",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tinted-zed": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1751158968,
|
||||||
|
"narHash": "sha256-ksOyv7D3SRRtebpXxgpG4TK8gZSKFc4TIZpR+C98jX8=",
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "base16-zed",
|
||||||
|
"rev": "86a470d94204f7652b906ab0d378e4231a5b3384",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "tinted-theming",
|
||||||
|
"repo": "base16-zed",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"treefmt-nix": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": [
|
||||||
|
"stylix",
|
||||||
|
"nur",
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1733222881,
|
||||||
|
"narHash": "sha256-JIPcz1PrpXUCbaccEnrcUS8jjEb/1vJbZz5KkobyFdM=",
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "treefmt-nix",
|
||||||
|
"rev": "49717b5af6f80172275d47a418c9719a31a78b53",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "treefmt-nix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"utils": {
|
"utils": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"systems": "systems"
|
"systems": "systems"
|
||||||
|
@ -508,6 +900,39 @@
|
||||||
"repo": "flake-utils",
|
"repo": "flake-utils",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"xwayland-satellite-stable": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1748488455,
|
||||||
|
"narHash": "sha256-IiLr1alzKFIy5tGGpDlabQbe6LV1c9ABvkH6T5WmyRI=",
|
||||||
|
"owner": "Supreeeme",
|
||||||
|
"repo": "xwayland-satellite",
|
||||||
|
"rev": "3ba30b149f9eb2bbf42cf4758d2158ca8cceef73",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "Supreeeme",
|
||||||
|
"ref": "v0.6",
|
||||||
|
"repo": "xwayland-satellite",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"xwayland-satellite-unstable": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1752338000,
|
||||||
|
"narHash": "sha256-Fxlp/yKtynug0jyuauAmvZU2SzHCfwlwWf85j+IvQ0U=",
|
||||||
|
"owner": "Supreeeme",
|
||||||
|
"repo": "xwayland-satellite",
|
||||||
|
"rev": "ba78881a68182ce338041846164cbfed0d70935c",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "Supreeeme",
|
||||||
|
"repo": "xwayland-satellite",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"root": "root",
|
"root": "root",
|
||||||
|
|
12
flake.nix
12
flake.nix
|
@ -33,6 +33,18 @@
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# System-wide styling.
|
||||||
|
stylix = {
|
||||||
|
url = "github:danth/stylix/release-25.05";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
|
# Niri WM.
|
||||||
|
niri = {
|
||||||
|
url = "github:sodiboo/niri-flake";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
# Neovim.
|
# Neovim.
|
||||||
nixvim = {
|
nixvim = {
|
||||||
url = "github:nix-community/nixvim";
|
url = "github:nix-community/nixvim";
|
||||||
|
|
29
helpers.nix
29
helpers.nix
|
@ -23,8 +23,12 @@ with inputs.nixpkgs.lib; {
|
||||||
extraModules =
|
extraModules =
|
||||||
hostModules # Host-specific modules.
|
hostModules # Host-specific modules.
|
||||||
++ optionals (docker == true) [./suites/server/docker] # Enable docker if required.
|
++ optionals (docker == true) [./suites/server/docker] # Enable docker if required.
|
||||||
|
++ optionals (suite == "desktop") [niri.nixosModules.niri]
|
||||||
++ (filesystem.listFilesRecursive ./modules); # Custom modules.
|
++ (filesystem.listFilesRecursive ./modules); # Custom modules.
|
||||||
|
|
||||||
|
# specialArgs & extraSpecialArgs.
|
||||||
|
args = {inherit inputs hostname secrets;};
|
||||||
|
|
||||||
# nixpkgs config.
|
# nixpkgs config.
|
||||||
pkgs = import nixpkgs {
|
pkgs = import nixpkgs {
|
||||||
inherit system;
|
inherit system;
|
||||||
|
@ -42,6 +46,7 @@ with inputs.nixpkgs.lib; {
|
||||||
# Import my overlay.
|
# Import my overlay.
|
||||||
overlays = [
|
overlays = [
|
||||||
(import ./overlay.nix {inherit inputs system;})
|
(import ./overlay.nix {inherit inputs system;})
|
||||||
|
niri.overlays.niri
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -62,19 +67,11 @@ with inputs.nixpkgs.lib; {
|
||||||
{
|
{
|
||||||
nixosConfigurations.${hostname} = nixosSystem {
|
nixosConfigurations.${hostname} = nixosSystem {
|
||||||
inherit system pkgs;
|
inherit system pkgs;
|
||||||
|
specialArgs = args;
|
||||||
specialArgs = {
|
|
||||||
# Make some variables accesible to modules.
|
|
||||||
inherit
|
|
||||||
inputs
|
|
||||||
hostname
|
|
||||||
secrets
|
|
||||||
;
|
|
||||||
};
|
|
||||||
|
|
||||||
modules =
|
modules =
|
||||||
[
|
[
|
||||||
nixvim.nixosModules.nixvim # Neovim.
|
stylix.nixosModules.stylix # Universal styling.
|
||||||
lanzaboote.nixosModules.lanzaboote # Secure boot.
|
lanzaboote.nixosModules.lanzaboote # Secure boot.
|
||||||
sops-nix.nixosModules.sops # Secrets management.
|
sops-nix.nixosModules.sops # Secrets management.
|
||||||
|
|
||||||
|
@ -88,7 +85,17 @@ with inputs.nixpkgs.lib; {
|
||||||
useGlobalPkgs = true;
|
useGlobalPkgs = true;
|
||||||
useUserPackages = true;
|
useUserPackages = true;
|
||||||
backupFileExtension = "backup";
|
backupFileExtension = "backup";
|
||||||
users.fern = ./home.nix;
|
extraSpecialArgs = args;
|
||||||
|
users.fern = {
|
||||||
|
home.username = "fern"; # My username.
|
||||||
|
home.homeDirectory = "/home/fern"; # My home directory.
|
||||||
|
home.stateVersion = "25.05"; # NixOS/home manager version (must match).
|
||||||
|
programs.home-manager.enable = true; # Enable home manager:
|
||||||
|
imports = [
|
||||||
|
nixvim.homeModules.nixvim # Neovim.
|
||||||
|
./suites/${suite}/home.nix # Suite-specific config.
|
||||||
|
];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
15
home.nix
15
home.nix
|
@ -1,15 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
# Me!
|
|
||||||
home.username = "fern";
|
|
||||||
home.homeDirectory = "/home/fern";
|
|
||||||
|
|
||||||
# Home manager version.
|
|
||||||
home.stateVersion = "25.05";
|
|
||||||
|
|
||||||
# Let Home Manager install and manage itself.
|
|
||||||
programs.home-manager.enable = true;
|
|
||||||
}
|
|
|
@ -35,8 +35,6 @@
|
||||||
# Install some packages.
|
# Install some packages.
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
mergerfs
|
mergerfs
|
||||||
ansible
|
|
||||||
(python3.withPackages (ps: [ps.ansible ps.pip ps.requests]))
|
|
||||||
];
|
];
|
||||||
|
|
||||||
# MergerFS.
|
# MergerFS.
|
||||||
|
@ -50,7 +48,6 @@
|
||||||
# Media group.
|
# Media group.
|
||||||
users.groups.media = {
|
users.groups.media = {
|
||||||
gid = 1800;
|
gid = 1800;
|
||||||
|
members = ["fern"];
|
||||||
};
|
};
|
||||||
|
|
||||||
users.users.fern.extraGroups = ["media"];
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,29 +38,4 @@ with lib; {
|
||||||
"dmask=0077"
|
"dmask=0077"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
# Share Music dir.
|
|
||||||
services.samba = {
|
|
||||||
enable = true;
|
|
||||||
openFirewall = true;
|
|
||||||
settings = {
|
|
||||||
global = {
|
|
||||||
"workgroup" = "FLOCK";
|
|
||||||
"server string" = "muskduck";
|
|
||||||
"netbios name" = "muskduck";
|
|
||||||
"security" = "user";
|
|
||||||
};
|
|
||||||
"Music" = {
|
|
||||||
"path" = "/home/fern/Music";
|
|
||||||
"browseable" = "yes";
|
|
||||||
"read only" = "yes";
|
|
||||||
"guest ok" = "no";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
services.samba-wsdd = {
|
|
||||||
enable = true;
|
|
||||||
openFirewall = true;
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
117
overlay.nix
117
overlay.nix
|
@ -5,67 +5,12 @@
|
||||||
}:
|
}:
|
||||||
with inputs;
|
with inputs;
|
||||||
final: prev: {
|
final: prev: {
|
||||||
# WebOne HTTP proxy.
|
## My Packages ##
|
||||||
webone = prev.pkgs.callPackage ./packages/webone {};
|
webone = prev.pkgs.callPackage ./packages/webone {}; # WebOne HTTP proxy.
|
||||||
|
cups-dymo = prev.pkgs.callPackage ./packages/cups-dymo {}; # Dymo label printer drivers.
|
||||||
# Yazi Gruvbox theme.
|
|
||||||
yazi-flavour-gruvbox-dark = prev.pkgs.callPackage ./packages/yazi-flavour-gruvbox {};
|
|
||||||
|
|
||||||
# Dymo label printer drivers.
|
|
||||||
cups-dymo = prev.pkgs.callPackage ./packages/cups-dymo {};
|
|
||||||
|
|
||||||
# Latest protonmail-desktop
|
|
||||||
protonmail-desktop = (import nixpkgs-unstable {inherit system;}).protonmail-desktop;
|
|
||||||
|
|
||||||
# Latest FluffyChat.
|
|
||||||
fluffychat =
|
|
||||||
(import nixpkgs-unstable
|
|
||||||
{
|
|
||||||
inherit system;
|
|
||||||
overlays = [
|
|
||||||
(final: prev: {
|
|
||||||
fluffychat = prev.fluffychat.overrideAttrs (prevAttrs: {
|
|
||||||
desktopItems = [
|
|
||||||
((builtins.elemAt prevAttrs.desktopItems 0).override {startupWMClass = "fluffychat";})
|
|
||||||
];
|
|
||||||
});
|
|
||||||
})
|
|
||||||
];
|
|
||||||
}).fluffychat;
|
|
||||||
|
|
||||||
# Latest Feishin.
|
|
||||||
feishin =
|
|
||||||
(import nixpkgs-pr-feishin {
|
|
||||||
inherit system;
|
|
||||||
overlays = [
|
|
||||||
(final: prev: {
|
|
||||||
feishin = prev.feishin.overrideAttrs (prevAttrs: rec {
|
|
||||||
pname = "feishin";
|
|
||||||
version = "0.18.0";
|
|
||||||
|
|
||||||
src = prev.fetchFromGitHub {
|
|
||||||
owner = "jeffvli";
|
|
||||||
repo = "feishin";
|
|
||||||
rev = "v${version}";
|
|
||||||
hash = "sha256-4gcS7Vd7LSpEByO2Hlk6nb8V2adBPh5XwWGCu2lwOA4=";
|
|
||||||
};
|
|
||||||
|
|
||||||
pnpmDeps = prev.pnpm_10.fetchDeps {
|
|
||||||
inherit pname version src;
|
|
||||||
hash = "sha256-1MGxrUcfvazxAubaYAsQuulUKm05opWOIC7oaLzjr7o=";
|
|
||||||
};
|
|
||||||
});
|
|
||||||
})
|
|
||||||
];
|
|
||||||
}).feishin;
|
|
||||||
|
|
||||||
# PrismLauncher with Temurin JRE;
|
|
||||||
prismlauncher = prev.prismlauncher.override {
|
|
||||||
jdks = [
|
|
||||||
prev.pkgs.temurin-jre-bin
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
|
## Package Mods ##
|
||||||
|
# Custom build of iosevka
|
||||||
iosevka = prev.iosevka.override {
|
iosevka = prev.iosevka.override {
|
||||||
set = "Custom";
|
set = "Custom";
|
||||||
|
|
||||||
|
@ -91,4 +36,56 @@ with inputs;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Latest Feishin.
|
||||||
|
feishin =
|
||||||
|
(import nixpkgs-pr-feishin {
|
||||||
|
inherit system;
|
||||||
|
overlays = [
|
||||||
|
(final: prev: {
|
||||||
|
feishin = prev.feishin.overrideAttrs (prevAttrs: rec {
|
||||||
|
pname = "feishin";
|
||||||
|
version = "0.19.0";
|
||||||
|
|
||||||
|
src = prev.fetchFromGitHub {
|
||||||
|
owner = "jeffvli";
|
||||||
|
repo = "feishin";
|
||||||
|
rev = "v${version}";
|
||||||
|
hash = "sha256-2Jry/wulzkS1P4tughDlH5klqNngPNmFuC5Nqe9sakM=";
|
||||||
|
};
|
||||||
|
|
||||||
|
pnpmDeps = prev.pnpm_10.fetchDeps {
|
||||||
|
inherit pname version src;
|
||||||
|
hash = "sha256-4cbrK+3nFD2NgoaGoAQdQ0+/07WiUiFUAyJFOsge8X8=";
|
||||||
|
};
|
||||||
|
});
|
||||||
|
})
|
||||||
|
];
|
||||||
|
}).feishin;
|
||||||
|
|
||||||
|
## Unstable Channel ##
|
||||||
|
protonmail-desktop = (import nixpkgs-unstable {inherit system;}).protonmail-desktop; # Latest protonmail-desktop
|
||||||
|
|
||||||
|
# Latest FluffyChat.
|
||||||
|
fluffychat =
|
||||||
|
(import nixpkgs-unstable
|
||||||
|
{
|
||||||
|
inherit system;
|
||||||
|
overlays = [
|
||||||
|
(final: prev: {
|
||||||
|
fluffychat = prev.fluffychat.overrideAttrs (prevAttrs: {
|
||||||
|
desktopItems = [
|
||||||
|
((builtins.elemAt prevAttrs.desktopItems 0).override {startupWMClass = "fluffychat";})
|
||||||
|
];
|
||||||
|
});
|
||||||
|
})
|
||||||
|
];
|
||||||
|
}).fluffychat;
|
||||||
|
|
||||||
|
# PrismLauncher with Temurin JRE;
|
||||||
|
prismlauncher = prev.prismlauncher.override {
|
||||||
|
jdks = [
|
||||||
|
prev.pkgs.temurin-jre-bin
|
||||||
|
];
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
{
|
|
||||||
pkgs,
|
|
||||||
fetchFromGitHub,
|
|
||||||
}: let
|
|
||||||
flavor = "gruvbox-dark";
|
|
||||||
in
|
|
||||||
pkgs.stdenv.mkDerivation {
|
|
||||||
pname = "yazi-flavor-${flavor}";
|
|
||||||
version = "2025.04.24";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "bennyyip";
|
|
||||||
repo = "${flavor}.yazi";
|
|
||||||
rev = "91fdfa70f6d593934e62aba1e449f4ec3d3ccc90";
|
|
||||||
hash = "sha256-RWqyAdETD/EkDVGcnBPiMcw1mSd78Aayky9yoxSsry4=";
|
|
||||||
};
|
|
||||||
|
|
||||||
installPhase = ''
|
|
||||||
mkdir -p $out
|
|
||||||
cp $src/* $out/
|
|
||||||
'';
|
|
||||||
}
|
|
|
@ -1,11 +1,10 @@
|
||||||
{
|
{
|
||||||
|
config,
|
||||||
inputs,
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
lib,
|
|
||||||
hostname,
|
hostname,
|
||||||
...
|
...
|
||||||
}:
|
}: {
|
||||||
with lib; {
|
|
||||||
# NixOS version.
|
# NixOS version.
|
||||||
system.stateVersion = "25.05";
|
system.stateVersion = "25.05";
|
||||||
|
|
||||||
|
@ -42,6 +41,13 @@ with lib; {
|
||||||
LC_TIME = "en_AU.UTF-8";
|
LC_TIME = "en_AU.UTF-8";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Set console font.
|
||||||
|
console = {
|
||||||
|
earlySetup = true;
|
||||||
|
font = "${pkgs.terminus_font}/share/consolefonts/ter-122n.psf.gz";
|
||||||
|
packages = with pkgs; [terminus_font];
|
||||||
|
};
|
||||||
|
|
||||||
# Configure keymap in X11.
|
# Configure keymap in X11.
|
||||||
services.xserver.xkb = {
|
services.xserver.xkb = {
|
||||||
layout = "us";
|
layout = "us";
|
||||||
|
@ -50,6 +56,7 @@ with lib; {
|
||||||
|
|
||||||
# Enable networking.
|
# Enable networking.
|
||||||
networking.networkmanager.enable = true;
|
networking.networkmanager.enable = true;
|
||||||
|
users.groups.networkmanager.members = ["fern"];
|
||||||
|
|
||||||
# Set hostname
|
# Set hostname
|
||||||
networking.hostName = hostname;
|
networking.hostName = hostname;
|
||||||
|
@ -59,37 +66,11 @@ with lib; {
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
uid = 1000;
|
uid = 1000;
|
||||||
description = "Fern Garden";
|
description = "Fern Garden";
|
||||||
extraGroups = [
|
extraGroups = ["wheel"];
|
||||||
"wheel"
|
|
||||||
"networkmanager"
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
# Use fish shell
|
# Use fish shell
|
||||||
programs.fish = {
|
programs.fish.enable = true;
|
||||||
enable = true;
|
|
||||||
shellAbbrs = let
|
|
||||||
flake = "/home/fern/Repositories/flock";
|
|
||||||
in {
|
|
||||||
ns = "nh os switch ${flake}";
|
|
||||||
nt = "nh os test ${flake}";
|
|
||||||
nb = "nh os boot ${flake}";
|
|
||||||
};
|
|
||||||
interactiveShellInit = ''
|
|
||||||
# set gruvbox theme
|
|
||||||
theme_gruvbox dark hard
|
|
||||||
|
|
||||||
# yazi cd on quit.
|
|
||||||
function y
|
|
||||||
set tmp (mktemp -t "yazi-cwd.XXXXXX")
|
|
||||||
yazi $argv --cwd-file="$tmp"
|
|
||||||
if read -z cwd < "$tmp"; and [ -n "$cwd" ]; and [ "$cwd" != "$PWD" ]
|
|
||||||
builtin cd -- "$cwd"
|
|
||||||
end
|
|
||||||
rm -f -- "$tmp"
|
|
||||||
end
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
# https://nixos.wiki/wiki/Fish#Setting_fish_as_your_shell
|
# https://nixos.wiki/wiki/Fish#Setting_fish_as_your_shell
|
||||||
programs.bash = {
|
programs.bash = {
|
||||||
|
@ -102,179 +83,21 @@ with lib; {
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Enable nh.
|
||||||
|
programs.nh = {
|
||||||
|
enable = true;
|
||||||
|
clean = {
|
||||||
|
enable = true;
|
||||||
|
extraArgs = "--keep-since 3d";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
# https://discourse.nixos.org/t/slow-build-at-building-man-cache/52365/2
|
# https://discourse.nixos.org/t/slow-build-at-building-man-cache/52365/2
|
||||||
documentation.man.generateCaches = false;
|
documentation.man.generateCaches = false;
|
||||||
|
|
||||||
# Enable all terminfo (for ghostty).
|
# Enable all terminfo.
|
||||||
environment.enableAllTerminfo = true;
|
environment.enableAllTerminfo = true;
|
||||||
|
|
||||||
# Install some packages.
|
|
||||||
programs = {
|
|
||||||
git.enable = true;
|
|
||||||
lazygit.enable = true;
|
|
||||||
|
|
||||||
nixvim = {
|
|
||||||
enable = true;
|
|
||||||
|
|
||||||
# Set $EDITOR
|
|
||||||
defaultEditor = true;
|
|
||||||
|
|
||||||
# For telescope grep.
|
|
||||||
dependencies.ripgrep.enable = true;
|
|
||||||
|
|
||||||
# Space as leader.
|
|
||||||
globals.mapleader = " ";
|
|
||||||
|
|
||||||
keymaps = [
|
|
||||||
{
|
|
||||||
key = "<Leader>t";
|
|
||||||
action = "<cmd> ToggleTerm direction=float <CR>";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
key = "<Leader>x";
|
|
||||||
action = "<cmd> Trouble diagnostics toggle focus=false <CR>";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
key = "<Leader>y";
|
|
||||||
action = "<cmd> Yazi <CR>";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
key = "<Leader>fs";
|
|
||||||
action = "<cmd> SessionSearch <CR>";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
colorschemes.gruvbox = {
|
|
||||||
enable = true;
|
|
||||||
settings = {
|
|
||||||
contrast = "hard";
|
|
||||||
overrides.SignColumn.bg = "none";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
opts = rec {
|
|
||||||
shiftwidth = 2;
|
|
||||||
tabstop = shiftwidth;
|
|
||||||
softtabstop = shiftwidth;
|
|
||||||
expandtab = true;
|
|
||||||
number = true;
|
|
||||||
cursorline = true;
|
|
||||||
undofile = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
plugins = {
|
|
||||||
auto-session.enable = true;
|
|
||||||
bufferline.enable = true;
|
|
||||||
colorizer.enable = true;
|
|
||||||
comment.enable = true;
|
|
||||||
gitsigns.enable = true;
|
|
||||||
lsp-format.enable = true;
|
|
||||||
notify.enable = true;
|
|
||||||
nvim-autopairs.enable = true;
|
|
||||||
nvim-surround.enable = true;
|
|
||||||
toggleterm.enable = true;
|
|
||||||
trouble.enable = true;
|
|
||||||
web-devicons.enable = true;
|
|
||||||
yazi.enable = true;
|
|
||||||
|
|
||||||
lualine = {
|
|
||||||
enable = true;
|
|
||||||
settings.extensions = ["trouble" "toggleterm"];
|
|
||||||
};
|
|
||||||
|
|
||||||
telescope = {
|
|
||||||
enable = true;
|
|
||||||
keymaps = {
|
|
||||||
"<Leader>ff" = "find_files";
|
|
||||||
"<Leader>fg" = "live_grep";
|
|
||||||
"<Leader>fb" = "buffers";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
blink-cmp = {
|
|
||||||
enable = true;
|
|
||||||
settings = {
|
|
||||||
keymap = {
|
|
||||||
preset = "enter";
|
|
||||||
"<Tab>" = [
|
|
||||||
"select_next"
|
|
||||||
"fallback"
|
|
||||||
];
|
|
||||||
"<S-Tab>" = [
|
|
||||||
"select_prev"
|
|
||||||
"fallback"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
completion = {
|
|
||||||
menu.auto_show = true;
|
|
||||||
documentation.auto_show = true;
|
|
||||||
list.selection.preselect = false;
|
|
||||||
};
|
|
||||||
cmdline = {
|
|
||||||
keymap.preset = "inherit";
|
|
||||||
completion = {
|
|
||||||
menu.auto_show = true;
|
|
||||||
list.selection.preselect = false;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
lsp = {
|
|
||||||
enable = true;
|
|
||||||
inlayHints = true;
|
|
||||||
servers = {
|
|
||||||
nixd = {
|
|
||||||
enable = true;
|
|
||||||
settings = {
|
|
||||||
nixpkgs.expr = "import (builtins.getFlake (builtins.toString ${inputs.self})).inputs.nixpkgs { }";
|
|
||||||
formatting.command = ["${pkgs.alejandra}/bin/alejandra"];
|
|
||||||
options = {
|
|
||||||
nixos.expr = "(builtins.getFlake (builtins.toString ${inputs.self})).nixosConfigurations.${hostname}.options";
|
|
||||||
home-manager.expr = "(builtins.getFlake (builtins.toString ${inputs.self})).nixosConfigurations.${hostname}.options.home-manager.users.type.getSubOptions []";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
docker_compose_language_service.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
treesitter = {
|
|
||||||
enable = true;
|
|
||||||
settings = {
|
|
||||||
highlight.enable = true;
|
|
||||||
incremental_selection.enable = true;
|
|
||||||
indent.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
programs.yazi = {
|
|
||||||
enable = true;
|
|
||||||
flavors."gruvbox-dark.yazi" = pkgs.yazi-flavour-gruvbox-dark;
|
|
||||||
settings.theme = {
|
|
||||||
flavor.dark = "gruvbox-dark";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
programs.tmux = {
|
|
||||||
enable = true;
|
|
||||||
plugins = [pkgs.tmuxPlugins.gruvbox];
|
|
||||||
};
|
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
|
||||||
aria2
|
|
||||||
btop
|
|
||||||
fishPlugins.gruvbox
|
|
||||||
lynx
|
|
||||||
ncdu
|
|
||||||
nh
|
|
||||||
rsync
|
|
||||||
trash-cli
|
|
||||||
];
|
|
||||||
|
|
||||||
# Enable avahi hostname resolution.
|
# Enable avahi hostname resolution.
|
||||||
services.avahi = {
|
services.avahi = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -287,12 +110,42 @@ with lib; {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Home manager settings.
|
# Universal styling.
|
||||||
home-manager.users.fern = {
|
stylix = {
|
||||||
programs.git = {
|
enable = true;
|
||||||
enable = true;
|
base16Scheme = "${pkgs.base16-schemes}/share/themes/kanagawa-dragon.yaml";
|
||||||
userEmail = "mail@fern.garden";
|
polarity = "dark";
|
||||||
userName = "Fern Garden";
|
|
||||||
|
cursor = {
|
||||||
|
name = "Adwaita";
|
||||||
|
package = pkgs.adwaita-icon-theme;
|
||||||
|
size = 24;
|
||||||
|
};
|
||||||
|
|
||||||
|
fonts = {
|
||||||
|
sizes = {
|
||||||
|
applications = 11;
|
||||||
|
desktop = config.stylix.fonts.sizes.applications;
|
||||||
|
popups = config.stylix.fonts.sizes.applications;
|
||||||
|
terminal = 12;
|
||||||
|
};
|
||||||
|
|
||||||
|
sansSerif = {
|
||||||
|
package = pkgs.adwaita-fonts;
|
||||||
|
name = "Adwaita Sans";
|
||||||
|
};
|
||||||
|
|
||||||
|
serif = config.stylix.fonts.sansSerif;
|
||||||
|
|
||||||
|
monospace = {
|
||||||
|
package = pkgs.iosevka;
|
||||||
|
name = "IosevkaCustom";
|
||||||
|
};
|
||||||
|
|
||||||
|
emoji = {
|
||||||
|
package = pkgs.noto-fonts-emoji;
|
||||||
|
name = "Noto Color Emoji";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,50 +40,38 @@ with lib; {
|
||||||
# Encrypt user's home with fscrypt
|
# Encrypt user's home with fscrypt
|
||||||
security.pam.enableFscrypt = true;
|
security.pam.enableFscrypt = true;
|
||||||
|
|
||||||
# Enable the GNOME Desktop Environment.
|
# Enable login manager.
|
||||||
services.xserver = {
|
programs.regreet = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
cageArgs = ["-m" "last"];
|
||||||
excludePackages = [
|
font = {
|
||||||
pkgs.xterm # Don't install xterm.
|
size = 11;
|
||||||
];
|
name = "Adwaita Sans";
|
||||||
|
|
||||||
displayManager.gdm.enable = true;
|
|
||||||
|
|
||||||
desktopManager.gnome = {
|
|
||||||
enable = true;
|
|
||||||
# Enable fractional scaling.
|
|
||||||
extraGSettingsOverridePackages = [pkgs.mutter];
|
|
||||||
extraGSettingsOverrides = ''
|
|
||||||
[org.gnome.mutter]
|
|
||||||
experimental-features=['scale-monitor-framebuffer']
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Theme QT applications
|
# Enable window manager.
|
||||||
qt = {
|
programs.niri = {
|
||||||
enable = true;
|
enable = true;
|
||||||
platformTheme = "gnome";
|
package = pkgs.niri-unstable;
|
||||||
style = "adwaita-dark";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
# Exclude some default gnome applications.
|
# Set wallpaper.
|
||||||
environment.gnome.excludePackages = (
|
stylix.image = ./wallpaper.jpg;
|
||||||
with pkgs; [
|
|
||||||
epiphany # Browser (replaced by Firefox).
|
|
||||||
gnome-connections # Remote desktop viewer.
|
|
||||||
gnome-console # Terminal (replaced by ghostTTY).
|
|
||||||
gnome-maps # Maps viewer.
|
|
||||||
gnome-music # Music player.
|
|
||||||
gnome-tour # First-boot tour.
|
|
||||||
totem # Movie player (replaced by Celluloid).
|
|
||||||
yelp # Help viewer.
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
# Run electron apps under wayland.
|
programs.dconf.enable = true;
|
||||||
environment.sessionVariables.NIXOS_OZONE_WL = "1";
|
security.polkit.enable = true;
|
||||||
|
services.hardware.bolt.enable = true;
|
||||||
|
services.upower.enable = true;
|
||||||
|
services.libinput.enable = true;
|
||||||
|
|
||||||
|
xdg.portal = {
|
||||||
|
enable = true;
|
||||||
|
extraPortals = [
|
||||||
|
pkgs.xdg-desktop-portal-gnome
|
||||||
|
pkgs.xdg-desktop-portal-gtk
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
# Virtualisation.
|
# Virtualisation.
|
||||||
programs.virt-manager.enable = true;
|
programs.virt-manager.enable = true;
|
||||||
|
@ -103,56 +91,8 @@ with lib; {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Install some packages.
|
# Install Steam client.
|
||||||
programs = {
|
programs.steam.enable = true;
|
||||||
steam.enable = true;
|
|
||||||
firefox.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
|
||||||
adw-gtk3
|
|
||||||
adwsteamgtk
|
|
||||||
caligula
|
|
||||||
celluloid
|
|
||||||
deploy-rs
|
|
||||||
discord
|
|
||||||
feishin
|
|
||||||
fluffychat
|
|
||||||
fusee-nano
|
|
||||||
ghostty
|
|
||||||
gimp3
|
|
||||||
glabels-qt
|
|
||||||
gnome-tweaks
|
|
||||||
gnomeExtensions.adw-gtk3-colorizer
|
|
||||||
gnomeExtensions.auto-move-windows
|
|
||||||
gnomeExtensions.caffeine
|
|
||||||
gnomeExtensions.color-picker
|
|
||||||
gnomeExtensions.rounded-window-corners-reborn
|
|
||||||
gnomeExtensions.smile-complementary-extension
|
|
||||||
jellyfin-media-player
|
|
||||||
libreoffice
|
|
||||||
nextcloud-client
|
|
||||||
ns-usbloader
|
|
||||||
obsidian
|
|
||||||
prismlauncher
|
|
||||||
protonmail-desktop
|
|
||||||
rockbox-utility
|
|
||||||
signal-desktop
|
|
||||||
smile
|
|
||||||
via
|
|
||||||
yubioath-flutter
|
|
||||||
];
|
|
||||||
|
|
||||||
fonts.packages = with pkgs; [
|
|
||||||
merriweather
|
|
||||||
iosevka
|
|
||||||
];
|
|
||||||
|
|
||||||
# Allow opening terminal applications from gnome app launcher.
|
|
||||||
xdg.terminal-exec = {
|
|
||||||
enable = true;
|
|
||||||
settings.default = ["ghostty.desktop"];
|
|
||||||
};
|
|
||||||
|
|
||||||
# Enable configuration of keyboard.
|
# Enable configuration of keyboard.
|
||||||
hardware.keyboard.qmk.enable = true;
|
hardware.keyboard.qmk.enable = true;
|
||||||
|
@ -173,9 +113,15 @@ with lib; {
|
||||||
drivers = [pkgs.brlaser pkgs.cups-dymo]; # Brother laser printer & Dymo label printer.
|
drivers = [pkgs.brlaser pkgs.cups-dymo]; # Brother laser printer & Dymo label printer.
|
||||||
};
|
};
|
||||||
|
|
||||||
|
services.system-config-printer.enable = true;
|
||||||
|
|
||||||
# https://github.com/tailscale/tailscale/issues/4432#issuecomment-1112819111
|
# https://github.com/tailscale/tailscale/issues/4432#issuecomment-1112819111
|
||||||
networking.firewall.checkReversePath = false;
|
networking.firewall.checkReversePath = false;
|
||||||
|
|
||||||
|
# Enable brightness control.
|
||||||
|
hardware.brillo.enable = true;
|
||||||
|
users.groups.video.members = ["fern"];
|
||||||
|
|
||||||
# Enable sound with pipewire.
|
# Enable sound with pipewire.
|
||||||
services.pulseaudio.enable = false;
|
services.pulseaudio.enable = false;
|
||||||
security.rtkit.enable = true;
|
security.rtkit.enable = true;
|
||||||
|
@ -191,23 +137,28 @@ with lib; {
|
||||||
services.tlp.enable = mkForce false; # enabled by nixos-hardware
|
services.tlp.enable = mkForce false; # enabled by nixos-hardware
|
||||||
services.auto-cpufreq.enable = true;
|
services.auto-cpufreq.enable = true;
|
||||||
|
|
||||||
# Home manager settings.
|
# Samba file sharing.
|
||||||
home-manager.users.fern = {
|
services.samba = {
|
||||||
# Ghostty settings.
|
enable = true;
|
||||||
programs.ghostty = {
|
openFirewall = true;
|
||||||
enable = true;
|
settings = {
|
||||||
settings = {
|
global = {
|
||||||
font-family = "IosevkaCustom";
|
"workgroup" = "FLOCK";
|
||||||
theme = "GruvboxDarkHard";
|
"server string" = "muskduck";
|
||||||
|
"netbios name" = "muskduck";
|
||||||
|
"security" = "user";
|
||||||
};
|
};
|
||||||
};
|
"Music" = {
|
||||||
|
"path" = "/home/fern/Music";
|
||||||
# virt-manager - autoconnect to qemu.
|
"browseable" = "yes";
|
||||||
dconf.settings = {
|
"read only" = "yes";
|
||||||
"org/virt-manager/virt-manager/connections" = {
|
"guest ok" = "no";
|
||||||
autoconnect = ["qemu:///system"];
|
|
||||||
uris = ["qemu:///system"];
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
services.samba-wsdd = {
|
||||||
|
enable = true;
|
||||||
|
openFirewall = true;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
368
suites/desktop/home.nix
Normal file
368
suites/desktop/home.nix
Normal file
|
@ -0,0 +1,368 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
with lib; {
|
||||||
|
imports = [../home.nix];
|
||||||
|
|
||||||
|
# Consistent theming.
|
||||||
|
qt.enable = true;
|
||||||
|
gtk.enable = true;
|
||||||
|
|
||||||
|
programs.niri = {
|
||||||
|
settings = {
|
||||||
|
# Wayland environment variables.
|
||||||
|
environment = {
|
||||||
|
CLUTTER_BACKEND = "wayland";
|
||||||
|
DISPLAY = null;
|
||||||
|
GDK_BACKEND = "wayland,x11";
|
||||||
|
MOZ_ENABLE_WAYLAND = "1";
|
||||||
|
NIXOS_OZONE_WL = "1";
|
||||||
|
QT_QPA_PLATFORM = "wayland;xcb";
|
||||||
|
QT_WAYLAND_DISABLE_WINDOWDECORATION = "1";
|
||||||
|
SDL_VIDEODRIVER = "wayland";
|
||||||
|
};
|
||||||
|
|
||||||
|
# X11 support.
|
||||||
|
xwayland-satellite = {
|
||||||
|
enable = true;
|
||||||
|
path = getExe pkgs.xwayland-satellite-unstable;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Don't show client-side window decorations.
|
||||||
|
prefer-no-csd = true;
|
||||||
|
|
||||||
|
# Don't show hotkeys at startup.
|
||||||
|
hotkey-overlay.skip-at-startup = true;
|
||||||
|
|
||||||
|
# Disable hot corner.
|
||||||
|
gestures.hot-corners.enable = false;
|
||||||
|
|
||||||
|
# Keyboard, mouse, trackpad, trackpoint.
|
||||||
|
input = {
|
||||||
|
touchpad.natural-scroll = false;
|
||||||
|
keyboard.repeat-rate = 60;
|
||||||
|
};
|
||||||
|
|
||||||
|
binds = {
|
||||||
|
# Spawn programs.
|
||||||
|
"Mod+Return".action.spawn = "kitty";
|
||||||
|
"Mod+Space".action.spawn = "fuzzel";
|
||||||
|
"Mod+Alt+L".action.spawn = "hyprlock";
|
||||||
|
|
||||||
|
# Media & brightness control.
|
||||||
|
"XF86AudioRaiseVolume" = {
|
||||||
|
allow-when-locked = true;
|
||||||
|
action.spawn = ["wpctl" "set-volume" "@DEFAULT_AUDIO_SINK@" "5%+"];
|
||||||
|
};
|
||||||
|
|
||||||
|
"XF86AudioLowerVolume" = {
|
||||||
|
allow-when-locked = true;
|
||||||
|
action.spawn = ["wpctl" "set-volume" "@DEFAULT_AUDIO_SINK@" "5%-"];
|
||||||
|
};
|
||||||
|
|
||||||
|
"XF86AudioMute" = {
|
||||||
|
allow-when-locked = true;
|
||||||
|
action.spawn = ["wpctl" "set-mute" "@DEFAULT_AUDIO_SINK@" "toggle"];
|
||||||
|
};
|
||||||
|
|
||||||
|
"XF86AudioMicMute" = {
|
||||||
|
allow-when-locked = true;
|
||||||
|
action.spawn = ["wpctl" "set-mute" "@DEFAULT_AUDIO_SOURCE@" "toggle"];
|
||||||
|
};
|
||||||
|
|
||||||
|
"XF86MonBrightnessUp" = {
|
||||||
|
allow-when-locked = true;
|
||||||
|
action.spawn = ["brillo" "-A" "5"];
|
||||||
|
};
|
||||||
|
|
||||||
|
"XF86MonBrightnessDown" = {
|
||||||
|
allow-when-locked = true;
|
||||||
|
action.spawn = ["brillo" "-U" "5"];
|
||||||
|
};
|
||||||
|
|
||||||
|
# Close windows.
|
||||||
|
"Mod+Q".action.close-window = {};
|
||||||
|
|
||||||
|
# Quit Niri.
|
||||||
|
"Mod+Shift+E".action.quit = {};
|
||||||
|
|
||||||
|
# Turn off monitors.
|
||||||
|
"Mod+Shift+Escape".action.power-off-monitors = {};
|
||||||
|
|
||||||
|
# Take a screenshot.
|
||||||
|
"Mod+P".action.screenshot = {};
|
||||||
|
"Mod+Shift+P".action.screenshot-screen = {};
|
||||||
|
"Mod+Shift+Ctrl+P".action.screenshot-window = {};
|
||||||
|
|
||||||
|
# Focus and move columns.
|
||||||
|
"Mod+H".action.focus-column-left = {};
|
||||||
|
"Mod+J".action.focus-window-down = {};
|
||||||
|
"Mod+K".action.focus-window-up = {};
|
||||||
|
"Mod+L".action.focus-column-right = {};
|
||||||
|
|
||||||
|
"Mod+Shift+H".action.move-column-left = {};
|
||||||
|
"Mod+Shift+J".action.move-window-down = {};
|
||||||
|
"Mod+Shift+K".action.move-window-up = {};
|
||||||
|
"Mod+Shift+L".action.move-column-right = {};
|
||||||
|
|
||||||
|
"Mod+Home".action.focus-column-first = {};
|
||||||
|
"Mod+End".action.focus-column-last = {};
|
||||||
|
|
||||||
|
"Mod+Shift+Home".action.move-column-to-first = {};
|
||||||
|
"Mod+Shift+End".action.move-column-to-last = {};
|
||||||
|
|
||||||
|
# Focus monitors.
|
||||||
|
"Mod+bracketleft".action.focus-monitor-left = {};
|
||||||
|
"Mod+bracketright".action.focus-monitor-right = {};
|
||||||
|
|
||||||
|
# Move columns between monitors.
|
||||||
|
"Mod+Shift+bracketleft".action.move-column-to-monitor-left = {};
|
||||||
|
"Mod+Shift+bracketright".action.move-column-to-monitor-right = {};
|
||||||
|
|
||||||
|
# Focus workspaces.
|
||||||
|
"Mod+U".action.focus-workspace-down = {};
|
||||||
|
"Mod+I".action.focus-workspace-up = {};
|
||||||
|
|
||||||
|
"Mod+1".action.focus-workspace = 1;
|
||||||
|
"Mod+2".action.focus-workspace = 2;
|
||||||
|
"Mod+3".action.focus-workspace = 3;
|
||||||
|
"Mod+4".action.focus-workspace = 4;
|
||||||
|
"Mod+5".action.focus-workspace = 5;
|
||||||
|
"Mod+6".action.focus-workspace = 6;
|
||||||
|
"Mod+7".action.focus-workspace = 7;
|
||||||
|
"Mod+8".action.focus-workspace = 8;
|
||||||
|
"Mod+9".action.focus-workspace = 9;
|
||||||
|
|
||||||
|
# Move columns to workspaces.
|
||||||
|
"Mod+Shift+U".action.move-column-to-workspace-down = {};
|
||||||
|
"Mod+Shift+I".action.move-column-to-workspace-up = {};
|
||||||
|
|
||||||
|
"Mod+Shift+1".action.move-column-to-workspace = 1;
|
||||||
|
"Mod+Shift+2".action.move-column-to-workspace = 2;
|
||||||
|
"Mod+Shift+3".action.move-column-to-workspace = 3;
|
||||||
|
"Mod+Shift+4".action.move-column-to-workspace = 4;
|
||||||
|
"Mod+Shift+5".action.move-column-to-workspace = 5;
|
||||||
|
"Mod+Shift+6".action.move-column-to-workspace = 6;
|
||||||
|
"Mod+Shift+7".action.move-column-to-workspace = 7;
|
||||||
|
"Mod+Shift+8".action.move-column-to-workspace = 8;
|
||||||
|
"Mod+Shift+9".action.move-column-to-workspace = 9;
|
||||||
|
|
||||||
|
# Expel & consume windows into columns.
|
||||||
|
"Mod+Comma".action.consume-window-into-column = {};
|
||||||
|
"Mod+Period".action.expel-window-from-column = {};
|
||||||
|
|
||||||
|
# Resize columns.
|
||||||
|
"Mod+R".action.switch-preset-column-width = {};
|
||||||
|
"Mod+Shift+R".action.reset-window-height = {};
|
||||||
|
|
||||||
|
"Mod+F".action.maximize-column = {};
|
||||||
|
"Mod+Shift+F".action.fullscreen-window = {};
|
||||||
|
|
||||||
|
"Mod+C".action.center-column = {};
|
||||||
|
|
||||||
|
"Mod+Minus".action.set-column-width = "-10%";
|
||||||
|
"Mod+Equal".action.set-column-width = "+10%";
|
||||||
|
|
||||||
|
"Mod+Shift+Minus".action.set-window-height = "-10%";
|
||||||
|
"Mod+Shift+Equal".action.set-window-height = "+10%";
|
||||||
|
};
|
||||||
|
|
||||||
|
layout = {
|
||||||
|
gaps = 4;
|
||||||
|
border.width = 1;
|
||||||
|
preset-column-widths = [
|
||||||
|
{proportion = 1.0 / 3.0;}
|
||||||
|
{proportion = 1.0 / 2.0;}
|
||||||
|
{proportion = 2.0 / 6.0;}
|
||||||
|
];
|
||||||
|
default-column-width = {
|
||||||
|
proportion = 1.0 / 2.0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Lock screen.
|
||||||
|
programs.hyprlock = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
input-field = {
|
||||||
|
fade_on_empty = false;
|
||||||
|
rounding = 0;
|
||||||
|
outline_thickness = 1;
|
||||||
|
valign = "center";
|
||||||
|
halign = "center";
|
||||||
|
position = "0%, -10%";
|
||||||
|
size = "20%, 5%";
|
||||||
|
};
|
||||||
|
label = {
|
||||||
|
valign = "center";
|
||||||
|
halign = "center";
|
||||||
|
position = "0%, 10%";
|
||||||
|
text = "$TIME";
|
||||||
|
font_size = 128;
|
||||||
|
font_family = "Adwaita Sans Bold";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
stylix.targets.hyprlock.useWallpaper = false;
|
||||||
|
|
||||||
|
# Auto-lock.
|
||||||
|
services.hypridle = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
general.lock_cmd = "hyprlock";
|
||||||
|
|
||||||
|
listener = [
|
||||||
|
{
|
||||||
|
timeout = 300;
|
||||||
|
on-timeout = "brillo -O; brillo -u 500000 -S 10";
|
||||||
|
on-resume = "brillo -I -u 250000";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
timeout = 600;
|
||||||
|
on-timeout = "loginctl lock-session";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Launcher.
|
||||||
|
programs.fuzzel = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
main = {
|
||||||
|
horizontal-pad = 8;
|
||||||
|
vertical-pad = 8;
|
||||||
|
inner-pad = 8;
|
||||||
|
};
|
||||||
|
border.radius = 0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Panel.
|
||||||
|
programs.waybar = {
|
||||||
|
enable = true;
|
||||||
|
systemd.enable = true;
|
||||||
|
|
||||||
|
style = ''
|
||||||
|
* {
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
|
settings.main = {
|
||||||
|
modules-left = ["niri/workspaces"];
|
||||||
|
modules-center = ["clock"];
|
||||||
|
modules-right = ["network" "wireplumber" "battery#0" "battery#1"];
|
||||||
|
|
||||||
|
"battery#0" = {
|
||||||
|
bat = "BAT0";
|
||||||
|
format-icons = ["" "" "" "" "" "" "" "" ""];
|
||||||
|
format = "{icon} {capacity}%";
|
||||||
|
tooltip = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
"battery#1" = {
|
||||||
|
bat = "BAT1";
|
||||||
|
format-icons = ["" "" "" "" "" "" "" "" ""];
|
||||||
|
format = "{icon} {capacity}%";
|
||||||
|
tooltip = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
"network" = {
|
||||||
|
format-icons = ["" "" "" "" ""];
|
||||||
|
format = "{icon}";
|
||||||
|
format-disconnected = "";
|
||||||
|
tooltip = true;
|
||||||
|
tooltip-format = "{essid}";
|
||||||
|
};
|
||||||
|
|
||||||
|
"wireplumber" = {
|
||||||
|
format-icons = ["" "" ""];
|
||||||
|
format = "{icon} {volume}%";
|
||||||
|
format-muted = " ";
|
||||||
|
tooltip = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
"clock" = {
|
||||||
|
format = "{:%a %b %d · %H:%M}";
|
||||||
|
tooltip = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
stylix.targets.waybar.font = "sansSerif"; # use sans-serif font, not monospaced.
|
||||||
|
|
||||||
|
# polkit-gnome.
|
||||||
|
systemd.user.services.polkit-gnome-authentication-agent-1 = {
|
||||||
|
Unit.Description = "polkit-gnome-authentication-agent-1";
|
||||||
|
|
||||||
|
Install = {
|
||||||
|
WantedBy = ["graphical-session.target"];
|
||||||
|
Wants = ["graphical-session.target"];
|
||||||
|
After = ["graphical-session.target"];
|
||||||
|
};
|
||||||
|
|
||||||
|
Service = {
|
||||||
|
Type = "simple";
|
||||||
|
ExecStart = "${pkgs.polkit_gnome}/libexec/polkit-gnome-authentication-agent-1";
|
||||||
|
Restart = "on-failure";
|
||||||
|
RestartSec = 1;
|
||||||
|
TimeoutStopSec = 10;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Wallpaper manager.
|
||||||
|
services.hyprpaper.enable = true;
|
||||||
|
|
||||||
|
# Notifications
|
||||||
|
services.mako.enable = true;
|
||||||
|
|
||||||
|
# Install some software.
|
||||||
|
programs.firefox = {
|
||||||
|
enable = true;
|
||||||
|
profiles.default = {};
|
||||||
|
};
|
||||||
|
|
||||||
|
stylix.targets.firefox.profileNames = ["default"];
|
||||||
|
|
||||||
|
programs.kitty = {
|
||||||
|
enable = true;
|
||||||
|
settings.window_padding_width = 4;
|
||||||
|
};
|
||||||
|
|
||||||
|
fonts.fontconfig.enable = true; # discover fonts installed by home.packages.
|
||||||
|
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
caligula
|
||||||
|
celluloid
|
||||||
|
deploy-rs
|
||||||
|
discord
|
||||||
|
feishin
|
||||||
|
fluffychat
|
||||||
|
fusee-nano
|
||||||
|
gimp3
|
||||||
|
glabels-qt
|
||||||
|
jellyfin-media-player
|
||||||
|
libreoffice
|
||||||
|
nautilus
|
||||||
|
nerd-fonts.symbols-only
|
||||||
|
nextcloud-client
|
||||||
|
noto-fonts
|
||||||
|
noto-fonts-cjk-sans
|
||||||
|
noto-fonts-cjk-serif
|
||||||
|
ns-usbloader
|
||||||
|
obsidian
|
||||||
|
prismlauncher
|
||||||
|
protonmail-desktop
|
||||||
|
rockbox-utility
|
||||||
|
signal-desktop
|
||||||
|
smile
|
||||||
|
via
|
||||||
|
yubioath-flutter
|
||||||
|
];
|
||||||
|
}
|
195
suites/home.nix
Normal file
195
suites/home.nix
Normal file
|
@ -0,0 +1,195 @@
|
||||||
|
{
|
||||||
|
inputs,
|
||||||
|
pkgs,
|
||||||
|
hostname,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
stylix.targets.nixvim.enable = false; # style is defined below.
|
||||||
|
|
||||||
|
# Install some packages.
|
||||||
|
programs = {
|
||||||
|
lazygit.enable = true;
|
||||||
|
yazi.enable = true;
|
||||||
|
tmux.enable = true;
|
||||||
|
btop.enable = true;
|
||||||
|
|
||||||
|
aria2 = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
max-concurrent-downloads = 2;
|
||||||
|
max-connection-per-server = 16;
|
||||||
|
min-split-size = "8M";
|
||||||
|
split = 32;
|
||||||
|
continue = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
git = {
|
||||||
|
enable = true;
|
||||||
|
userEmail = "mail@fern.garden";
|
||||||
|
userName = "Fern Garden";
|
||||||
|
};
|
||||||
|
|
||||||
|
fish = {
|
||||||
|
enable = true;
|
||||||
|
shellAbbrs = let
|
||||||
|
flake = "/home/fern/Repositories/flock";
|
||||||
|
in {
|
||||||
|
ns = "nh os switch ${flake}";
|
||||||
|
nt = "nh os test ${flake}";
|
||||||
|
nb = "nh os boot ${flake}";
|
||||||
|
};
|
||||||
|
functions = {
|
||||||
|
y = ''
|
||||||
|
set tmp (mktemp -t "yazi-cwd.XXXXXX")
|
||||||
|
yazi $argv --cwd-file="$tmp"
|
||||||
|
if read -z cwd < "$tmp"; and [ -n "$cwd" ]; and [ "$cwd" != "$PWD" ]
|
||||||
|
builtin cd -- "$cwd"
|
||||||
|
end
|
||||||
|
rm -f -- "$tmp"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nixvim = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
# Set $EDITOR
|
||||||
|
defaultEditor = true;
|
||||||
|
|
||||||
|
# For telescope grep.
|
||||||
|
dependencies.ripgrep.enable = true;
|
||||||
|
|
||||||
|
# Space as leader.
|
||||||
|
globals.mapleader = " ";
|
||||||
|
|
||||||
|
keymaps = [
|
||||||
|
{
|
||||||
|
key = "<Leader>t";
|
||||||
|
action = "<cmd> ToggleTerm direction=float <CR>";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
key = "<Leader>x";
|
||||||
|
action = "<cmd> Trouble diagnostics toggle focus=false <CR>";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
key = "<Leader>y";
|
||||||
|
action = "<cmd> Yazi <CR>";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
key = "<Leader>fs";
|
||||||
|
action = "<cmd> SessionSearch <CR>";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
colorschemes.kanagawa = {
|
||||||
|
enable = true;
|
||||||
|
settings.colors.theme.all.ui.bg_gutter = "none"; # Remove gutter background.
|
||||||
|
settings.background.dark = "dragon";
|
||||||
|
};
|
||||||
|
|
||||||
|
opts = rec {
|
||||||
|
shiftwidth = 2;
|
||||||
|
tabstop = shiftwidth;
|
||||||
|
softtabstop = shiftwidth;
|
||||||
|
expandtab = true;
|
||||||
|
number = true;
|
||||||
|
cursorline = true;
|
||||||
|
undofile = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
plugins = {
|
||||||
|
auto-session.enable = true;
|
||||||
|
bufferline.enable = true;
|
||||||
|
colorizer.enable = true;
|
||||||
|
comment.enable = true;
|
||||||
|
gitsigns.enable = true;
|
||||||
|
lsp-format.enable = true;
|
||||||
|
notify.enable = true;
|
||||||
|
nvim-autopairs.enable = true;
|
||||||
|
nvim-surround.enable = true;
|
||||||
|
toggleterm.enable = true;
|
||||||
|
trouble.enable = true;
|
||||||
|
web-devicons.enable = true;
|
||||||
|
yazi.enable = true;
|
||||||
|
|
||||||
|
lualine = {
|
||||||
|
enable = true;
|
||||||
|
settings.extensions = ["trouble" "toggleterm"];
|
||||||
|
};
|
||||||
|
|
||||||
|
telescope = {
|
||||||
|
enable = true;
|
||||||
|
keymaps = {
|
||||||
|
"<Leader>ff" = "find_files";
|
||||||
|
"<Leader>fg" = "live_grep";
|
||||||
|
"<Leader>fb" = "buffers";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
blink-cmp = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
keymap = {
|
||||||
|
preset = "enter";
|
||||||
|
"<Tab>" = [
|
||||||
|
"select_next"
|
||||||
|
"fallback"
|
||||||
|
];
|
||||||
|
"<S-Tab>" = [
|
||||||
|
"select_prev"
|
||||||
|
"fallback"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
completion = {
|
||||||
|
menu.auto_show = true;
|
||||||
|
documentation.auto_show = true;
|
||||||
|
list.selection.preselect = false;
|
||||||
|
};
|
||||||
|
cmdline = {
|
||||||
|
keymap.preset = "inherit";
|
||||||
|
completion = {
|
||||||
|
menu.auto_show = true;
|
||||||
|
list.selection.preselect = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
lsp = {
|
||||||
|
enable = true;
|
||||||
|
inlayHints = true;
|
||||||
|
servers = {
|
||||||
|
nixd = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
nixpkgs.expr = "import (builtins.getFlake (builtins.toString ${inputs.self})).inputs.nixpkgs { }";
|
||||||
|
formatting.command = ["${pkgs.alejandra}/bin/alejandra"];
|
||||||
|
options = {
|
||||||
|
nixos.expr = "(builtins.getFlake (builtins.toString ${inputs.self})).nixosConfigurations.${hostname}.options";
|
||||||
|
home-manager.expr = "(builtins.getFlake (builtins.toString ${inputs.self})).nixosConfigurations.${hostname}.options.home-manager.users.type.getSubOptions []";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
docker_compose_language_service.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
treesitter = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
highlight.enable = true;
|
||||||
|
incremental_selection.enable = true;
|
||||||
|
indent.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
ncdu
|
||||||
|
rsync
|
||||||
|
trash-cli
|
||||||
|
];
|
||||||
|
}
|
3
suites/server/home.nix
Normal file
3
suites/server/home.nix
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
imports = [../home.nix];
|
||||||
|
}
|
3
suites/server/lxc/home.nix
Normal file
3
suites/server/lxc/home.nix
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
imports = [../home.nix];
|
||||||
|
}
|
3
suites/server/vm/home.nix
Normal file
3
suites/server/vm/home.nix
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
imports = [../home.nix];
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue