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>
97 lines
2.7 KiB
Nix
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;
|
|
}
|