Compare commits

...

2 Commits

Author SHA1 Message Date
henrov b0e6759817 Working on reshuffling 2026-03-19 12:52:11 +00:00
henrov 61e1a92a56 deleted generated files 2026-03-19 12:52:10 +00:00
2 changed files with 46 additions and 58 deletions
+23 -29
View File
@@ -1000,68 +1000,62 @@ This file installs and configures eww
let let
programName = "eww"; programName = "eww";
# --- Path to the program's assets in the flake ---
programAssets = "${flakeRoot}/assets/system/conf/${programName}"; programAssets = "${flakeRoot}/assets/system/conf/${programName}";
# --- Read all files in the asset directory ---
programFiles = builtins.readDir programAssets; programFiles = builtins.readDir programAssets;
# --- Generate attrset of file contents ---
files = lib.genAttrs (builtins.attrNames programFiles) (name: { files = lib.genAttrs (builtins.attrNames programFiles) (name: {
text = builtins.readFile "${programAssets}/${name}"; src = "${programAssets}/${name}";
}); });
in in
{ {
# --- Top-level toggle for this module --- # Top-level toggle for this program
options.enableEww = options.myApps.${programName}.enable =
lib.mkEnableOption "Enable eww widgets"; lib.mkEnableOption "Enable Eww widgets";
# --- Configuration only applied if enabled --- # Wrap everything in config if enabled
config = let config = { config, ... }: let
# Assign enableProgram inside config to match the toggle option enableProgram = config.myApps.${programName}.enable or false;
enableProgram = config.enableEww or false;
# Determine user safely after config exists # Determine username safely inside config.mkIf
username = config.defaultUser or "henrov"; username = enableProgram then (config.defaultUser or "henrov") else null;
# User's XDG config path for eww # Full config directory path in user's home
configDir = "/home/${username}/.config/${programName}"; ewwConfigDir = enableProgram then "/home/${username}/.config/${programName}" else null;
in lib.mkIf enableProgram { in lib.mkIf enableProgram {
# --- Top-level container for all apps ---
myApps = { myApps = {
eww = { ${programName} = {
enable = true; enable = true;
assetsDir = programAssets; assetsDir = programAssets;
files = files; files = files;
# Assign user after config exists
user = username; user = username;
# Symbolic package reference; actual package should be assigned elsewhere # Add more program-specific options below
package = "eww"; # e.g., theme = "catppuccin-mocha";
}; };
}; };
# --- Home Manager deployment --- # Home Manager user configuration
home-manager.users.${username} = { home-manager.users.${username} = {
home.stateVersion = "26.05"; home.stateVersion = "26.05";
home.username = username; home.username = username;
home.homeDirectory = "/home/${username}"; home.homeDirectory = "/home/${username}";
# Deploy all config files recursively # Deploy Eww configs
home.file."${configDir}" = { home.file."${ewwConfigDir}" = {
source = programAssets; source = programAssets;
recursive = true; recursive = true;
}; };
# Session variables for the program # Session variables
home.sessionVariables = { home.sessionVariables = {
EWW_BIN = "${programName}"; EWW_BIN = "${config.pkgs.eww}/bin/eww";
}; };
# Wayland/Hyprland startup hooks # Wayland/Hyprland startup hooks
wayland.windowManager.hyprland.settings = lib.mkForce { wayland.windowManager.hyprland.settings = lib.mkForce {
exec-once = [ "${programName} daemon" ]; exec-once = [ "eww daemon" ];
exec = [ "${programName} open-many ${configDir}/widgets" ]; exec = [ "eww open-many ${ewwConfigDir}/widgets" ];
}; };
}; };
}; };
+23 -29
View File
@@ -2,68 +2,62 @@
let let
programName = "eww"; programName = "eww";
# --- Path to the program's assets in the flake ---
programAssets = "${flakeRoot}/assets/system/conf/${programName}"; programAssets = "${flakeRoot}/assets/system/conf/${programName}";
# --- Read all files in the asset directory ---
programFiles = builtins.readDir programAssets; programFiles = builtins.readDir programAssets;
# --- Generate attrset of file contents ---
files = lib.genAttrs (builtins.attrNames programFiles) (name: { files = lib.genAttrs (builtins.attrNames programFiles) (name: {
text = builtins.readFile "${programAssets}/${name}"; src = "${programAssets}/${name}";
}); });
in in
{ {
# --- Top-level toggle for this module --- # Top-level toggle for this program
options.enableEww = options.myApps.${programName}.enable =
lib.mkEnableOption "Enable eww widgets"; lib.mkEnableOption "Enable Eww widgets";
# --- Configuration only applied if enabled --- # Wrap everything in config if enabled
config = let config = { config, ... }: let
# Assign enableProgram inside config to match the toggle option enableProgram = config.myApps.${programName}.enable or false;
enableProgram = config.enableEww or false;
# Determine user safely after config exists # Determine username safely inside config.mkIf
username = config.defaultUser or "henrov"; username = enableProgram then (config.defaultUser or "henrov") else null;
# User's XDG config path for eww # Full config directory path in user's home
configDir = "/home/${username}/.config/${programName}"; ewwConfigDir = enableProgram then "/home/${username}/.config/${programName}" else null;
in lib.mkIf enableProgram { in lib.mkIf enableProgram {
# --- Top-level container for all apps ---
myApps = { myApps = {
eww = { ${programName} = {
enable = true; enable = true;
assetsDir = programAssets; assetsDir = programAssets;
files = files; files = files;
# Assign user after config exists
user = username; user = username;
# Symbolic package reference; actual package should be assigned elsewhere # Add more program-specific options below
package = "eww"; # e.g., theme = "catppuccin-mocha";
}; };
}; };
# --- Home Manager deployment --- # Home Manager user configuration
home-manager.users.${username} = { home-manager.users.${username} = {
home.stateVersion = "26.05"; home.stateVersion = "26.05";
home.username = username; home.username = username;
home.homeDirectory = "/home/${username}"; home.homeDirectory = "/home/${username}";
# Deploy all config files recursively # Deploy Eww configs
home.file."${configDir}" = { home.file."${ewwConfigDir}" = {
source = programAssets; source = programAssets;
recursive = true; recursive = true;
}; };
# Session variables for the program # Session variables
home.sessionVariables = { home.sessionVariables = {
EWW_BIN = "${programName}"; EWW_BIN = "${config.pkgs.eww}/bin/eww";
}; };
# Wayland/Hyprland startup hooks # Wayland/Hyprland startup hooks
wayland.windowManager.hyprland.settings = lib.mkForce { wayland.windowManager.hyprland.settings = lib.mkForce {
exec-once = [ "${programName} daemon" ]; exec-once = [ "eww daemon" ];
exec = [ "${programName} open-many ${configDir}/widgets" ]; exec = [ "eww open-many ${ewwConfigDir}/widgets" ];
}; };
}; };
}; };