Compare commits

...

2 Commits

Author SHA1 Message Date
henrov 6ef7345919 Working on reshuffling 2026-03-19 12:57:25 +00:00
henrov b05cad4351 deleted generated files 2026-03-19 12:57:24 +00:00
2 changed files with 16 additions and 22 deletions
+8 -11
View File
@@ -996,7 +996,7 @@ This file installs and configures fonts
** =generated/modules/desktop/eww.nix= ** =generated/modules/desktop/eww.nix=
This file installs and configures eww This file installs and configures eww
#+BEGIN_SRC nix :tangle generated/modules/desktop/eww.nix :noweb tangle :mkdirp yes :eval never-html #+BEGIN_SRC nix :tangle generated/modules/desktop/eww.nix :noweb tangle :mkdirp yes :eval never-html
{ lib, flakeRoot, ... }: { lib, flakeRoot, pkgs, ... }:
let let
programName = "eww"; programName = "eww";
@@ -1007,28 +1007,25 @@ let
}); });
in in
{ {
# 1. Top-level enable toggle (never reference config here) # 1. Top-level toggle (no config usage!)
options.myApps.${programName}.enable = options.myApps.${programName}.enable =
lib.mkEnableOption "Enable Eww widgets"; lib.mkEnableOption "Enable Eww widgets";
# 2. Config is a function — config argument exists here! # 2. Configuration block (only use config inside lib.mkIf)
config = { config, pkgs, ... }: let config = lib.mkIf (lib.getOption config "myApps.${programName}.enable" or false) (let
# Determine username safely inside the function
username = config.defaultUser or "henrov"; username = config.defaultUser or "henrov";
ewwConfigDir = "/home/${username}/.config/${programName}"; ewwConfigDir = "/home/${username}/.config/${programName}";
enableProgram = config.myApps.${programName}.enable or false; enableProgram = true; # already gated by mkIf
in lib.mkIf enableProgram { in {
# Top-level container for programs
myApps = { myApps = {
${programName} = { ${programName} = {
enable = true; enable = enableProgram;
assetsDir = programAssets; assetsDir = programAssets;
files = files; files = files;
user = username; user = username;
}; };
}; };
# Home Manager user config
home-manager.users.${username} = { home-manager.users.${username} = {
home.stateVersion = "26.05"; home.stateVersion = "26.05";
home.username = username; home.username = username;
@@ -1048,7 +1045,7 @@ in
exec = [ "eww open-many ${ewwConfigDir}/widgets" ]; exec = [ "eww open-many ${ewwConfigDir}/widgets" ];
}; };
}; };
}; });
} }
#+END_SRC #+END_SRC
+8 -11
View File
@@ -1,4 +1,4 @@
{ lib, flakeRoot, ... }: { lib, flakeRoot, pkgs, ... }:
let let
programName = "eww"; programName = "eww";
@@ -9,28 +9,25 @@ let
}); });
in in
{ {
# 1. Top-level enable toggle (never reference config here) # 1. Top-level toggle (no config usage!)
options.myApps.${programName}.enable = options.myApps.${programName}.enable =
lib.mkEnableOption "Enable Eww widgets"; lib.mkEnableOption "Enable Eww widgets";
# 2. Config is a function — config argument exists here! # 2. Configuration block (only use config inside lib.mkIf)
config = { config, pkgs, ... }: let config = lib.mkIf (lib.getOption config "myApps.${programName}.enable" or false) (let
# Determine username safely inside the function
username = config.defaultUser or "henrov"; username = config.defaultUser or "henrov";
ewwConfigDir = "/home/${username}/.config/${programName}"; ewwConfigDir = "/home/${username}/.config/${programName}";
enableProgram = config.myApps.${programName}.enable or false; enableProgram = true; # already gated by mkIf
in lib.mkIf enableProgram { in {
# Top-level container for programs
myApps = { myApps = {
${programName} = { ${programName} = {
enable = true; enable = enableProgram;
assetsDir = programAssets; assetsDir = programAssets;
files = files; files = files;
user = username; user = username;
}; };
}; };
# Home Manager user config
home-manager.users.${username} = { home-manager.users.${username} = {
home.stateVersion = "26.05"; home.stateVersion = "26.05";
home.username = username; home.username = username;
@@ -50,5 +47,5 @@ in
exec = [ "eww open-many ${ewwConfigDir}/widgets" ]; exec = [ "eww open-many ${ewwConfigDir}/widgets" ];
}; };
}; };
}; });
} }