Files
Nomarchy/modules/lib/default.nix
Bernardo Magri b27fc5aee8 refactor: major architectural restructure for theme-centric organization
Theme System:
- Move all theme app configs to apps/ subdirectory (20 themes)
- Add theme-loader.nix for dynamic theme config deployment
- Simplify stylix.nix to focus on base theming only

Override System:
- Add overrides.nix for file-based config overrides
- Add behavior-configs.nix for non-visual configuration
- Split hypr/nomarchy.conf into behavior vs visual sections

Module Improvements:
- Add lib.mkDefault to all customizable settings
- Add modules/lib/ with shared utilities and state schema
- Update all home and system modules for downstream overridability

Installer:
- New minimal TTY installer (installer/install.sh)
- Golden path: BTRFS + LUKS2 (disko-golden.nix)
- New installer-iso.nix for TTY-only installation
- Keep graphical installer as installerIsoGraphical option

Cleanup:
- Remove obsolete install.sh, disko-ext4.nix, install-nomarchy.sh
- Update live-iso.nix references
- Add .claude/ to .gitignore for local IDE settings

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-04-11 19:38:27 +01:00

97 lines
2.7 KiB
Nix

# Nomarchy Shared Library
# Centralized utilities to reduce code duplication across modules
{ lib }:
let
# Import theme palettes once - used by multiple modules
palettes = import ../../assets/themes/nomarchy-palettes.nix;
# Unified state reading function
# Handles both JSON and plain text files with graceful fallbacks
readState = { file, default }:
if builtins.pathExists file then
let
content = builtins.readFile file;
cleanContent = lib.removeSuffix "\n" content;
in
if lib.hasSuffix ".json" (toString file) then
builtins.fromJSON cleanContent
else
cleanContent
else
default;
# Read home state from unified location
readHomeState = homeDirectory:
readState {
file = "${homeDirectory}/.config/nomarchy/state.json";
default = {};
};
# Read system state
readSystemState =
readState {
file = /etc/nixos/state.json;
default = {};
};
# Resolve wallpaper path with fallback
# Returns either the user-specified wallpaper or a default from the theme
resolveWallpaper = { wallpaperPath, themeName, assetsPath }:
if wallpaperPath != "" then
wallpaperPath
else
let
themeBackgrounds = assetsPath + "/${themeName}/backgrounds";
defaultBackground = assetsPath + "/catppuccin/backgrounds/1-totoro.png";
in
if builtins.pathExists themeBackgrounds then
let
backgrounds = builtins.attrNames (builtins.readDir themeBackgrounds);
in
if backgrounds != [] then
"${themeBackgrounds}/${builtins.head (builtins.sort (a: b: a < b) backgrounds)}"
else
defaultBackground
else
defaultBackground;
# Get current palette from theme name
getPalette = themeName:
(palettes.${themeName} or palettes.nord).palette;
# Get full color scheme from theme name
getColorScheme = themeName:
palettes.${themeName} or palettes.nord;
# Check if a theme is light mode
isThemeLightMode = { themeName, assetsPath }:
builtins.pathExists (assetsPath + "/${themeName}/light.mode");
# Get icons theme for a given theme
getIconsTheme = { themeName, assetsPath, default ? "Yaru-blue" }:
let
iconsFile = assetsPath + "/${themeName}/icons.theme";
in
if builtins.pathExists iconsFile then
lib.removeSuffix "\n" (builtins.readFile iconsFile)
else
default;
# Get list of available theme names
themeNames = builtins.attrNames palettes;
in {
inherit
palettes
readState
readHomeState
readSystemState
resolveWallpaper
getPalette
getColorScheme
isThemeLightMode
getIconsTheme
themeNames;
}