Compare commits
2 Commits
d675df4728
...
6cddbae686
| Author | SHA1 | Date | |
|---|---|---|---|
| 6cddbae686 | |||
| 9b116a44c4 |
+11
-23
@@ -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
|
||||||
|
|
||||||
|
|||||||
@@ -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" ];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user