diff --git a/_sources/generated.json b/_sources/generated.json index cfb2acf1..ec09c483 100644 --- a/_sources/generated.json +++ b/_sources/generated.json @@ -179,6 +179,26 @@ }, "version": "8313c7250fcbbb22c6680db332669073ec6b28c2" }, + "hyprland": { + "cargoLocks": null, + "date": "2023-05-03", + "extract": null, + "name": "hyprland", + "passthru": null, + "pinned": false, + "src": { + "deepClone": false, + "fetchSubmodules": false, + "leaveDotGit": false, + "name": null, + "owner": "catppuccin", + "repo": "hyprland", + "rev": "99a88fd21fac270bd999d4a26cf0f4a4222c58be", + "sha256": "sha256-07B5QmQmsUKYf38oWU3+2C6KO4JvinuTwmW1Pfk8CT8=", + "type": "github" + }, + "version": "99a88fd21fac270bd999d4a26cf0f4a4222c58be" + }, "kitty": { "cargoLocks": null, "date": "2023-06-09", diff --git a/_sources/generated.nix b/_sources/generated.nix index 7005e518..93fa1bf8 100644 --- a/_sources/generated.nix +++ b/_sources/generated.nix @@ -109,6 +109,18 @@ }; date = "2023-10-20"; }; + hyprland = { + pname = "hyprland"; + version = "99a88fd21fac270bd999d4a26cf0f4a4222c58be"; + src = fetchFromGitHub { + owner = "catppuccin"; + repo = "hyprland"; + rev = "99a88fd21fac270bd999d4a26cf0f4a4222c58be"; + fetchSubmodules = false; + sha256 = "sha256-07B5QmQmsUKYf38oWU3+2C6KO4JvinuTwmW1Pfk8CT8="; + }; + date = "2023-05-03"; + }; kitty = { pname = "kitty"; version = "4820b3ef3f4968cf3084b2239ce7d1e99ea04dda"; diff --git a/modules/home-manager/default.nix b/modules/home-manager/default.nix index 29c697a0..6b06e09c 100644 --- a/modules/home-manager/default.nix +++ b/modules/home-manager/default.nix @@ -16,6 +16,7 @@ in ./lazygit.nix ./starship.nix ./helix.nix + ./hyprland.nix ./glamour.nix ./gtk.nix ./mako.nix diff --git a/modules/home-manager/hyprland.nix b/modules/home-manager/hyprland.nix new file mode 100644 index 00000000..e51c08c3 --- /dev/null +++ b/modules/home-manager/hyprland.nix @@ -0,0 +1,19 @@ +{ config +, lib +, sources +, ... +}: +let + cfg = config.wayland.windowManager.hyprland.catppuccin; + enable = cfg.enable && config.wayland.windowManager.hyprland.enable; +in +{ + options.wayland.windowManager.hyprland.catppuccin = + lib.ctp.mkCatppuccinOpt "hyprland"; + + # Because of how nix merges options and hyprland interprets options, sourcing + # the file does not work. instead, parse the theme and put it in settings so + # the variables appear early enough in the file to be applied properly. + config.wayland.windowManager.hyprland.settings = lib.mkIf enable + (lib.ctp.fromINI (sources.hyprland + /themes/${cfg.flavour}.conf)); +} diff --git a/nvfetcher.toml b/nvfetcher.toml index ce4ede59..1bb69044 100644 --- a/nvfetcher.toml +++ b/nvfetcher.toml @@ -34,6 +34,10 @@ fetch.github = "catppuccin/gtk" src.git = "https://github.com/catppuccin/helix.git" fetch.github = "catppuccin/helix" +[hyprland] +src.git = "https://github.com/catppuccin/hyprland.git" +fetch.github = "catppuccin/hyprland" + [kitty] src.git = "https://github.com/catppuccin/kitty.git" fetch.github = "catppuccin/kitty" diff --git a/test.nix b/test.nix index c23eb85f..342c5bed 100644 --- a/test.nix +++ b/test.nix @@ -80,6 +80,7 @@ in }; wayland.windowManager.sway = ctpEnable; + wayland.windowManager.hyprland = ctpEnable; }; };