Two clusters of documented-but-non-functional options surfaced during
the Pillar 8 audit, both setting toggles that have zero runtime effect.
1. `nomarchy.toggles.skipVsCodeTheme` was declared in
core/home/options.nix, defaulted from lib/state-schema.nix, and
surfaced as `NOMARCHY_TOGGLE_SKIP_VSCODE_THEME` env var in
features/scripts/default.nix — but `features/apps/vscode.nix` always
sets `workbench.colorTheme` unconditionally, and no script reads the
env var. Setting the toggle to true did nothing. Removed from
options, schema, state, env-var export, and OPTIONS.md.
2. `nomarchy.themeLoader.apps.{waybar,mako,kitty,alacritty}` were
declared in themes/engine/loader.nix but only `btop` is actually
wired (line 87 gates the per-theme btop.theme deploy). The other
four had no consumer. The actual theming pipeline for those apps is
elsewhere: waybar themes inline from `colorScheme` in waybar.nix;
kitty and alacritty are themed by stylix targets in
themes/engine/stylix.nix; mako has no theme integration at all.
Removed the four dead options + updated OPTIONS.md to list only
btop with a note about where the other apps' theming lives.
144 lines
4.6 KiB
Nix
144 lines
4.6 KiB
Nix
{ lib, pkgs, ... }:
|
|
|
|
let
|
|
# Defaults live in lib/state-schema.nix so they can't drift between this
|
|
# file, core/system/options.nix, and core/home/state.nix's `or` fallbacks.
|
|
schema = import ../../lib/state-schema.nix { inherit lib; };
|
|
in
|
|
{
|
|
options.nomarchy = {
|
|
toggles = {
|
|
suspend = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = schema.home.suspend;
|
|
description = "Whether to show suspend in system menu.";
|
|
};
|
|
screensaver = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = schema.home.screensaver;
|
|
description = "Whether the screensaver is enabled.";
|
|
};
|
|
idle = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = schema.home.idle;
|
|
description = "Whether the idle lock is enabled.";
|
|
};
|
|
nightlight = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = schema.home.nightlight;
|
|
description = "Whether the nightlight is enabled.";
|
|
};
|
|
waybar = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = schema.home.waybar;
|
|
description = "Whether the top bar is enabled.";
|
|
};
|
|
};
|
|
nightlightTemperature = lib.mkOption {
|
|
type = lib.types.int;
|
|
default = schema.home.nightlightTemperature;
|
|
description = "Temperature for the nightlight.";
|
|
};
|
|
theme = lib.mkOption {
|
|
type = lib.types.str;
|
|
default = schema.home.theme;
|
|
description = "System theme name.";
|
|
};
|
|
formFactor = lib.mkOption {
|
|
type = lib.types.enum [ "laptop" "desktop" ];
|
|
default = "laptop";
|
|
description = ''
|
|
Physical form factor. Drives UI affordances (battery widget,
|
|
future lid handling). Default "laptop" — battery widget is
|
|
harmless on a desktop (renders empty when no BAT* is present),
|
|
so the safe default is "show, don't hide". The installer
|
|
auto-detects via /sys/class/power_supply/BAT* and writes the
|
|
explicit value into the generated home.nix.
|
|
'';
|
|
};
|
|
wallpaper = lib.mkOption {
|
|
type = lib.types.str;
|
|
default = schema.home.wallpaper;
|
|
description = "System wallpaper path.";
|
|
};
|
|
panelPosition = lib.mkOption {
|
|
type = lib.types.enum [ "top" "bottom" ];
|
|
default = schema.home.panelPosition;
|
|
description = "Waybar panel position.";
|
|
};
|
|
hyprland = {
|
|
gaps_in = lib.mkOption {
|
|
type = lib.types.int;
|
|
default = schema.home.hyprland.gaps_in;
|
|
description = "Inner gaps for Hyprland.";
|
|
};
|
|
gaps_out = lib.mkOption {
|
|
type = lib.types.int;
|
|
default = schema.home.hyprland.gaps_out;
|
|
description = "Outer gaps for Hyprland.";
|
|
};
|
|
border_size = lib.mkOption {
|
|
type = lib.types.int;
|
|
default = schema.home.hyprland.border_size;
|
|
description = "Border size for Hyprland.";
|
|
};
|
|
};
|
|
fonts = {
|
|
monospace = lib.mkOption {
|
|
type = lib.types.str;
|
|
default = schema.home.font;
|
|
description = "System monospace font.";
|
|
};
|
|
};
|
|
iconsTheme = lib.mkOption {
|
|
type = lib.types.str;
|
|
default = "Yaru-blue";
|
|
description = "System icon theme name.";
|
|
};
|
|
isLightMode = lib.mkOption {
|
|
type = lib.types.bool;
|
|
default = false;
|
|
description = "Whether the current theme is light mode.";
|
|
};
|
|
cursor = {
|
|
name = lib.mkOption {
|
|
type = lib.types.str;
|
|
default = "Bibata-Modern-Ice";
|
|
description = "Mouse cursor theme name.";
|
|
};
|
|
package = lib.mkOption {
|
|
type = lib.types.package;
|
|
default = pkgs.bibata-cursors;
|
|
description = "Package providing the cursor theme.";
|
|
};
|
|
};
|
|
configOverrides = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.path;
|
|
default = null;
|
|
description = "Path to a directory containing configuration overrides.";
|
|
};
|
|
|
|
apps = {
|
|
opencode = {
|
|
enable = lib.mkEnableOption ''
|
|
opencode AI coding CLI integration. When on, deploys
|
|
~/.config/opencode/opencode.json. The `opencode` package itself
|
|
is not installed by Nomarchy — add it to your home.nix if you
|
|
want it on PATH.
|
|
'';
|
|
};
|
|
};
|
|
|
|
gaming = {
|
|
enable = lib.mkEnableOption ''
|
|
Gaming preset (home-side companion to nomarchy.system.gaming.enable).
|
|
Adds a Hyprland window rule that fullscreens windows whose class
|
|
matches steam_app_* — i.e. games launched through Steam — so they
|
|
grab the whole screen instead of opening windowed. Set this to the
|
|
same value as nomarchy.system.gaming.enable; the installer flips
|
|
both when the Gaming profile is selected.
|
|
'';
|
|
};
|
|
};
|
|
}
|