From 8cdd9f07259d63635920775740b3a349e62e56ca Mon Sep 17 00:00:00 2001 From: Devin <90054389+justDeeevin@users.noreply.github.com> Date: Wed, 18 Dec 2024 09:15:36 -0500 Subject: [PATCH] treewide: extend stylix.imageScalingMode support Add stylix.imageScalingMode support to all modules except: - hyprlock - hyprpaper - kde - lightdm - sway Closes: https://github.com/danth/stylix/issues/677 Link: https://github.com/danth/stylix/pull/678 Reviewed-by: NAHO <90870942+trueNAHO@users.noreply.github.com> Reviewed-by: Daniel Thwaites (cherry picked from commit a2d66f25478103ac9b4adc6d6713794f7005221e) --- modules/feh/hm.nix | 16 ++++++++++++++-- modules/feh/nixos.nix | 15 ++++++++++++++- modules/gnome/hm.nix | 14 +++++++++++++- modules/grub/nixos.nix | 13 ++++++++++++- modules/regreet/nixos.nix | 15 ++++++++++++++- modules/swaylock/hm.nix | 2 +- modules/wpaperd/hm.nix | 10 +++++++++- 7 files changed, 77 insertions(+), 8 deletions(-) diff --git a/modules/feh/hm.nix b/modules/feh/hm.nix index 3642ec693..62fccb0a7 100644 --- a/modules/feh/hm.nix +++ b/modules/feh/hm.nix @@ -18,6 +18,18 @@ || spectrwm.enable || xmonad.enable ) - ) - "${pkgs.feh}/bin/feh --no-fehbg --bg-scale ${config.stylix.image}"; + ) (let + inherit (config.stylix) imageScalingMode; + bg-arg = + if imageScalingMode == "fill" + then "--bg-fill" + else if imageScalingMode == "center" + then "--bg-center" + else if imageScalingMode == "tile" + then "--bg-tile" + else if imageScalingMode == "stretch" + then "--bg-scale" + # Fit + else "--bg-max"; + in "${pkgs.feh}/bin/feh --no-fehbg ${bg-arg} ${config.stylix.image}"); } diff --git a/modules/feh/nixos.nix b/modules/feh/nixos.nix index 2826af181..74f668858 100644 --- a/modules/feh/nixos.nix +++ b/modules/feh/nixos.nix @@ -16,5 +16,18 @@ || i3.enable ) ) - "${pkgs.feh}/bin/feh --no-fehbg --bg-scale ${config.stylix.image}"; + (let + inherit (config.stylix) imageScalingMode; + bg-arg = + if imageScalingMode == "fill" + then "--bg-fill" + else if imageScalingMode == "center" + then "--bg-center" + else if imageScalingMode == "tile" + then "--bg-tile" + else if imageScalingMode == "stretch" + then "--bg-scale" + # Fit + else "--bg-max"; + in "${pkgs.feh}/bin/feh --no-fehbg ${bg-arg} ${config.stylix.image}"); } diff --git a/modules/gnome/hm.nix b/modules/gnome/hm.nix index ea98eccc6..c0cfd2293 100644 --- a/modules/gnome/hm.nix +++ b/modules/gnome/hm.nix @@ -13,7 +13,19 @@ in { dconf.settings = { "org/gnome/desktop/background" = { color-shading-type = "solid"; - picture-options = "zoom"; + picture-options = let + inherit (config.stylix) imageScalingMode; + in + if imageScalingMode == "fit" + then "scaled" + else if imageScalingMode == "fill" + then "zoom" + else if imageScalingMode == "stretch" + then "stretched" + else if imageScalingMode == "center" + then "centered" + # Seemingly no tile support... :( + else "zoom"; picture-uri = "file://${config.stylix.image}"; picture-uri-dark = "file://${config.stylix.image}"; }; diff --git a/modules/grub/nixos.nix b/modules/grub/nixos.nix index f90df7cff..c95b13652 100644 --- a/modules/grub/nixos.nix +++ b/modules/grub/nixos.nix @@ -23,6 +23,17 @@ let ${pkgs.grub2}/bin/grub-mkfont $font --output $out --size ${toString sizes.applications} ''; + inherit (config.stylix) imageScalingMode; + + image-scale = + if imageScalingMode == "fill" + then "crop" + else if imageScalingMode == "fit" + then "fitheight" + else if imageScalingMode == "center" + then "padding" + # Grub doesn't seem to support tile + else "crop"; in { options.stylix.targets.grub = { enable = config.lib.stylix.mkEnableTarget "GRUB" true; @@ -46,7 +57,7 @@ in { theme = pkgs.runCommand "stylix-grub" { themeTxt = '' desktop-image: "background.png" - desktop-image-scale-method: "crop" + desktop-image-scale-method: "${image-scale}" desktop-color: "${base00}" title-text: "" diff --git a/modules/regreet/nixos.nix b/modules/regreet/nixos.nix index a9c76da35..3b610c6b6 100644 --- a/modules/regreet/nixos.nix +++ b/modules/regreet/nixos.nix @@ -13,7 +13,20 @@ (config.stylix.enable && config.stylix.targets.regreet.enable && pkgs.stdenv.hostPlatform.isLinux) { programs.regreet = { - settings.background.path = config.stylix.image; + settings.background = { + path = config.stylix.image; + fit = let + inherit (config.stylix) imageScalingMode; + in + if imageScalingMode == "fill" + then "Cover" + else if imageScalingMode == "fit" + then "Contain" + else if imageScalingMode == "stretch" + then "Fill" + # No other available options + else null; + }; font = { inherit (config.stylix.fonts.sansSerif) name package; }; diff --git a/modules/swaylock/hm.nix b/modules/swaylock/hm.nix index 7bde8960f..ad10cc676 100644 --- a/modules/swaylock/hm.nix +++ b/modules/swaylock/hm.nix @@ -26,7 +26,7 @@ in { config = lib.mkIf (config.stylix.enable && config.stylix.targets.swaylock.enable && pkgs.stdenv.hostPlatform.isLinux) { programs.swaylock.settings = { color = outside; - scaling = "fill"; + scaling = config.stylix.imageScalingMode; inside-color = inside; inside-clear-color = inside; inside-caps-lock-color = inside; diff --git a/modules/wpaperd/hm.nix b/modules/wpaperd/hm.nix index 7008593ad..c117d6f61 100644 --- a/modules/wpaperd/hm.nix +++ b/modules/wpaperd/hm.nix @@ -4,6 +4,14 @@ options.stylix.targets.wpaperd.enable = config.lib.stylix.mkEnableTarget "wpaperd" true; config = lib.mkIf (config.stylix.enable && config.stylix.targets.wpaperd.enable) { - programs.wpaperd.settings.any.path = "${config.stylix.image}"; + programs.wpaperd.settings.any = { + path = "${config.stylix.image}"; + mode = let + inherit (config.stylix) imageScalingMode; + in + if imageScalingMode == "fill" + then "fit" + else imageScalingMode; + }; }; }