Compare commits

...

2 Commits

Author SHA1 Message Date
henrov 6cddbae686 Working on reshuffling 2026-03-19 12:54:14 +00:00
henrov 9b116a44c4 deleted generated files 2026-03-19 12:54:13 +00:00
2 changed files with 22 additions and 46 deletions
+11 -23
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";
@@ -1005,57 +1005,45 @@ let
files = lib.genAttrs (builtins.attrNames programFiles) (name: { files = lib.genAttrs (builtins.attrNames programFiles) (name: {
src = "${programAssets}/${name}"; src = "${programAssets}/${name}";
}); });
in in {
{
# Top-level toggle for this program
options.myApps.${programName}.enable = options.myApps.${programName}.enable =
lib.mkEnableOption "Enable Eww widgets"; lib.mkEnableOption "Enable Eww widgets";
# Wrap everything in config if enabled config = lib.mkIf (config.myApps.${programName}.enable or false) (let
config = { config, ... }: let # Determine username safely after config exists
enableProgram = config.myApps.${programName}.enable or false; username = config.defaultUser or "henrov";
ewwConfigDir = "/home/${username}/.config/${programName}";
# Determine username safely inside config.mkIf enableProgram = true; # already gated by mkIf
username = if enableProgram then (config.defaultUser or "henrov") else null; in {
# Full config directory path in user's home
ewwConfigDir = if enableProgram then "/home/${username}/.config/${programName}" else null;
in lib.mkIf enableProgram {
myApps = { myApps = {
${programName} = { ${programName} = {
enable = true; enable = enableProgram;
assetsDir = programAssets; assetsDir = programAssets;
files = files; files = files;
# Assign user after config exists
user = username; user = username;
}; };
}; };
# 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 Eww configs
home.file."${ewwConfigDir}" = { home.file."${ewwConfigDir}" = {
source = programAssets; source = programAssets;
recursive = true; recursive = true;
}; };
# Session variables
home.sessionVariables = { home.sessionVariables = {
EWW_BIN = "${config.pkgs.eww}/bin/eww"; EWW_BIN = "${pkgs.eww}/bin/eww";
}; };
# Wayland/Hyprland startup hooks
wayland.windowManager.hyprland.settings = lib.mkForce { wayland.windowManager.hyprland.settings = lib.mkForce {
exec-once = [ "eww daemon" ]; exec-once = [ "eww daemon" ];
exec = [ "eww open-many ${ewwConfigDir}/widgets" ]; exec = [ "eww open-many ${ewwConfigDir}/widgets" ];
}; };
}; };
}; });
} }
#+END_SRC #+END_SRC
+11 -23
View File
@@ -1,4 +1,4 @@
{ lib, flakeRoot, ... }: { lib, flakeRoot, pkgs, ... }:
let let
programName = "eww"; programName = "eww";
@@ -7,55 +7,43 @@ let
files = lib.genAttrs (builtins.attrNames programFiles) (name: { files = lib.genAttrs (builtins.attrNames programFiles) (name: {
src = "${programAssets}/${name}"; src = "${programAssets}/${name}";
}); });
in in {
{
# Top-level toggle for this program
options.myApps.${programName}.enable = options.myApps.${programName}.enable =
lib.mkEnableOption "Enable Eww widgets"; lib.mkEnableOption "Enable Eww widgets";
# Wrap everything in config if enabled config = lib.mkIf (config.myApps.${programName}.enable or false) (let
config = { config, ... }: let # Determine username safely after config exists
enableProgram = config.myApps.${programName}.enable or false; username = config.defaultUser or "henrov";
ewwConfigDir = "/home/${username}/.config/${programName}";
# Determine username safely inside config.mkIf enableProgram = true; # already gated by mkIf
username = if enableProgram then (config.defaultUser or "henrov") else null; in {
# Full config directory path in user's home
ewwConfigDir = if enableProgram then "/home/${username}/.config/${programName}" else null;
in lib.mkIf enableProgram {
myApps = { myApps = {
${programName} = { ${programName} = {
enable = true; enable = enableProgram;
assetsDir = programAssets; assetsDir = programAssets;
files = files; files = files;
# Assign user after config exists
user = username; user = username;
}; };
}; };
# 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 Eww configs
home.file."${ewwConfigDir}" = { home.file."${ewwConfigDir}" = {
source = programAssets; source = programAssets;
recursive = true; recursive = true;
}; };
# Session variables
home.sessionVariables = { home.sessionVariables = {
EWW_BIN = "${config.pkgs.eww}/bin/eww"; EWW_BIN = "${pkgs.eww}/bin/eww";
}; };
# Wayland/Hyprland startup hooks
wayland.windowManager.hyprland.settings = lib.mkForce { wayland.windowManager.hyprland.settings = lib.mkForce {
exec-once = [ "eww daemon" ]; exec-once = [ "eww daemon" ];
exec = [ "eww open-many ${ewwConfigDir}/widgets" ]; exec = [ "eww open-many ${ewwConfigDir}/widgets" ];
}; };
}; };
}; });
} }