Compare commits
11 Commits
b9c48f9dd1
...
25.11
| Author | SHA1 | Date | |
|---|---|---|---|
| 0ae4d84ca2 | |||
| 7c877fde84 | |||
| d53286e04c | |||
| 445b0cd558 | |||
| 6d9686f14b | |||
| 4164832eea | |||
| ade60ba5ec | |||
| 48fb7cdada | |||
| 2d8cfe75a0 | |||
| 385fd798de | |||
| fe6558e0c1 |
66
flake.lock
generated
66
flake.lock
generated
@@ -43,16 +43,16 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1758463745,
|
"lastModified": 1764866045,
|
||||||
"narHash": "sha256-uhzsV0Q0I9j2y/rfweWeGif5AWe0MGrgZ/3TjpDYdGA=",
|
"narHash": "sha256-0GsEtXV9OquDQ1VclQfP16cU5VZh7NEVIOjSH4UaJuM=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "3b955f5f0a942f9f60cdc9cacb7844335d0f21c3",
|
"rev": "f63d0fe9d81d36e5fc95497217a72e02b8b7bcab",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"ref": "release-25.05",
|
"ref": "release-25.11",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -64,11 +64,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1763416652,
|
"lastModified": 1764872372,
|
||||||
"narHash": "sha256-8EBEEvtzQ11LCxpQHMNEBQAGtQiCu/pqP9zSovDSbNM=",
|
"narHash": "sha256-uZuXRz9CzeCHsRbc2MQvKomwoX6GcFC5BUMEk3ouSFU=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "ea164b7c9ccdc2321379c2ff78fd4317b4c41312",
|
"rev": "05a56dbf24f195c62286e3273a2671d3b4904b00",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -86,11 +86,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1763223001,
|
"lastModified": 1764746434,
|
||||||
"narHash": "sha256-Hi6XxTJJjKsDrO+D0fYXS88ehCYzQkZlp9qxX1zoM1s=",
|
"narHash": "sha256-6ymFuw+Z1C90ezf8H0BP3c2JFZhJYwMq31px2StwWHU=",
|
||||||
"owner": "Jovian-Experiments",
|
"owner": "Jovian-Experiments",
|
||||||
"repo": "Jovian-NixOS",
|
"repo": "Jovian-NixOS",
|
||||||
"rev": "68a1bcc019378272e601558719f82005a80ddab0",
|
"rev": "b4c0b604148adacf119b89824ed26df8926ce42c",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -106,16 +106,16 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1762912391,
|
"lastModified": 1764161084,
|
||||||
"narHash": "sha256-4hpBE7bGd24SfD28rzMdUGXsLsNEYxCCrTipFdoqoNM=",
|
"narHash": "sha256-HN84sByg9FhJnojkGGDSrcjcbeioFWoNXfuyYfJ1kBE=",
|
||||||
"owner": "nix-darwin",
|
"owner": "nix-darwin",
|
||||||
"repo": "nix-darwin",
|
"repo": "nix-darwin",
|
||||||
"rev": "d76299b2cd01837c4c271a7b5186e3d5d8ebd126",
|
"rev": "e95de00a471d07435e0527ff4db092c84998698e",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "nix-darwin",
|
"owner": "nix-darwin",
|
||||||
"ref": "nix-darwin-25.05",
|
"ref": "nix-darwin-25.11",
|
||||||
"repo": "nix-darwin",
|
"repo": "nix-darwin",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -148,11 +148,11 @@
|
|||||||
"nixpkgs": "nixpkgs"
|
"nixpkgs": "nixpkgs"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1763385941,
|
"lastModified": 1764730608,
|
||||||
"narHash": "sha256-99CBNgyMvg3Zu/hxqixtShevrF4Kfr/qjtizQ6oseVI=",
|
"narHash": "sha256-FxKIa3OCSRVC23qrk7VT68vExUcmSruJ8OobVlSWOxc=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "NixOS-WSL",
|
"repo": "NixOS-WSL",
|
||||||
"rev": "cc6483354b236c2fc95cc1d4ba1f0f40b7345e69",
|
"rev": "10124c58674360765adcb38c9a8b081fb72904e4",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -164,11 +164,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1762977756,
|
"lastModified": 1764517877,
|
||||||
"narHash": "sha256-4PqRErxfe+2toFJFgcRKZ0UI9NSIOJa+7RXVtBhy4KE=",
|
"narHash": "sha256-pp3uT4hHijIC8JUK5MEqeAWmParJrgBVzHLNfJDZxg4=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "c5ae371f1a6a7fd27823bc500d9390b38c05fa55",
|
"rev": "2d293cbfa5a793b4c50d17c05ef9e385b90edf6c",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -180,11 +180,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs-unstable": {
|
"nixpkgs-unstable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1763283776,
|
"lastModified": 1764667669,
|
||||||
"narHash": "sha256-Y7TDFPK4GlqrKrivOcsHG8xSGqQx3A6c+i7novT85Uk=",
|
"narHash": "sha256-7WUCZfmqLAssbDqwg9cUDAXrSoXN79eEEq17qhTNM/Y=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "50a96edd8d0db6cc8db57dab6bb6d6ee1f3dc49a",
|
"rev": "418468ac9527e799809c900eda37cbff999199b6",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -196,16 +196,16 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs_2": {
|
"nixpkgs_2": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1763049705,
|
"lastModified": 1764677808,
|
||||||
"narHash": "sha256-A5LS0AJZ1yDPTa2fHxufZN++n8MCmtgrJDtxFxrH4S8=",
|
"narHash": "sha256-H3lC7knbXOBrHI9hITQ7modLuX20mYJVhZORL5ioms0=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "3acb677ea67d4c6218f33de0db0955f116b7588c",
|
"rev": "1aab89277eb2d87823d5b69bae631a2496cff57a",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"ref": "nixos-25.05",
|
"ref": "nixos-25.11",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -220,11 +220,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1762784320,
|
"lastModified": 1763909441,
|
||||||
"narHash": "sha256-odsk96Erywk5hs0dhArF38zb7Oe0q6LZ70gXbxAPKno=",
|
"narHash": "sha256-56LwV51TX/FhgX+5LCG6akQ5KrOWuKgcJa+eUsRMxsc=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "plasma-manager",
|
"repo": "plasma-manager",
|
||||||
"rev": "7911a0f8a44c7e8b29d031be3149ee8943144321",
|
"rev": "b24ed4b272256dfc1cc2291f89a9821d5f9e14b4",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -243,11 +243,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1762784320,
|
"lastModified": 1763909441,
|
||||||
"narHash": "sha256-odsk96Erywk5hs0dhArF38zb7Oe0q6LZ70gXbxAPKno=",
|
"narHash": "sha256-56LwV51TX/FhgX+5LCG6akQ5KrOWuKgcJa+eUsRMxsc=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "plasma-manager",
|
"repo": "plasma-manager",
|
||||||
"rev": "7911a0f8a44c7e8b29d031be3149ee8943144321",
|
"rev": "b24ed4b272256dfc1cc2291f89a9821d5f9e14b4",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|||||||
14
flake.nix
14
flake.nix
@@ -2,17 +2,17 @@
|
|||||||
description = "A very basic flake";
|
description = "A very basic flake";
|
||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "github:nixos/nixpkgs/nixos-25.05";
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-25.11";
|
||||||
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||||
nixos-wsl.url = "github:nix-community/NixOS-WSL/main";
|
nixos-wsl.url = "github:nix-community/NixOS-WSL/main";
|
||||||
|
|
||||||
nix-darwin = {
|
nix-darwin = {
|
||||||
url = "github:nix-darwin/nix-darwin/nix-darwin-25.05";
|
url = "github:nix-darwin/nix-darwin/nix-darwin-25.11";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
home-manager = {
|
home-manager = {
|
||||||
url = "github:nix-community/home-manager/release-25.05";
|
url = "github:nix-community/home-manager/release-25.11";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -48,7 +48,6 @@
|
|||||||
nixosModules = [
|
nixosModules = [
|
||||||
./roles
|
./roles
|
||||||
] ++ [
|
] ++ [
|
||||||
./roles/jovian-compat.nix
|
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
{
|
{
|
||||||
nixpkgs.overlays = [
|
nixpkgs.overlays = [
|
||||||
@@ -110,6 +109,13 @@
|
|||||||
unstable = import nixpkgs-unstable {
|
unstable = import nixpkgs-unstable {
|
||||||
system = prev.system;
|
system = prev.system;
|
||||||
config.allowUnfree = true;
|
config.allowUnfree = true;
|
||||||
|
overlays = [
|
||||||
|
# Override claude-code in unstable to use our custom GCS-based build
|
||||||
|
# (needed for corporate networks that block npm registry)
|
||||||
|
(ufinal: uprev: {
|
||||||
|
claude-code = prev.custom.claude-code or (prev.callPackage ./packages {}).claude-code;
|
||||||
|
})
|
||||||
|
];
|
||||||
};
|
};
|
||||||
custom = prev.callPackage ./packages {};
|
custom = prev.callPackage ./packages {};
|
||||||
# Compatibility: bitwarden renamed to bitwarden-desktop in unstable
|
# Compatibility: bitwarden renamed to bitwarden-desktop in unstable
|
||||||
|
|||||||
@@ -1,30 +1,6 @@
|
|||||||
{ config, lib, pkgs, globalInputs, system, ... }:
|
{ config, lib, pkgs, globalInputs, system, ... }:
|
||||||
|
|
||||||
{
|
{
|
||||||
# Claude Code Package Override for Corporate Work Environment
|
|
||||||
#
|
|
||||||
# This overlay overrides the default claude-code package specifically for work environments
|
|
||||||
# where corporate network restrictions may prevent access to npm registry distributions.
|
|
||||||
#
|
|
||||||
# Context:
|
|
||||||
# - The default claude-code package (used in home environments) fetches from npm registry
|
|
||||||
# - Corporate firewalls and security policies often block npm registry access
|
|
||||||
# - Our custom claude-code package uses Google Cloud Storage distribution as a workaround
|
|
||||||
# - This maintains the same package name across environments while adapting to network constraints
|
|
||||||
#
|
|
||||||
# Environment-specific behavior:
|
|
||||||
# - Home environments: Use standard npm-distributed claude-code package
|
|
||||||
# - Work environments: Use custom binary-distributed claude-code package from GCS
|
|
||||||
#
|
|
||||||
# This approach ensures consistent tooling availability regardless of network environment
|
|
||||||
# while respecting corporate security policies.
|
|
||||||
nixpkgs.overlays = [
|
|
||||||
(final: prev: {
|
|
||||||
unstable = prev.unstable // {
|
|
||||||
claude-code = prev.custom.claude-code;
|
|
||||||
};
|
|
||||||
})
|
|
||||||
];
|
|
||||||
# Home Manager configuration for Darwin work laptop
|
# Home Manager configuration for Darwin work laptop
|
||||||
# Corporate-friendly setup with essential development tools
|
# Corporate-friendly setup with essential development tools
|
||||||
|
|
||||||
@@ -131,6 +107,8 @@
|
|||||||
aerospace = {
|
aerospace = {
|
||||||
enable = true;
|
enable = true;
|
||||||
leader = "cmd";
|
leader = "cmd";
|
||||||
|
ctrlShortcuts.enable = true;
|
||||||
|
sketchybar.enable = true;
|
||||||
# Optional: Add per-machine userSettings overrides
|
# Optional: Add per-machine userSettings overrides
|
||||||
# userSettings = {
|
# userSettings = {
|
||||||
# mode.main.binding."${leader}-custom" = "custom-command";
|
# mode.main.binding."${leader}-custom" = "custom-command";
|
||||||
@@ -140,5 +118,6 @@
|
|||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./roles
|
./roles
|
||||||
|
./roles/base-darwin
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,5 +29,6 @@
|
|||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./roles
|
./roles
|
||||||
|
./roles/base-linux
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,5 +38,6 @@
|
|||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./roles
|
./roles
|
||||||
|
./roles/base-linux
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./roles
|
./roles
|
||||||
|
./roles/base-linux
|
||||||
];
|
];
|
||||||
|
|
||||||
# Live USB specific overrides can go here if needed
|
# Live USB specific overrides can go here if needed
|
||||||
|
|||||||
@@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./roles
|
./roles
|
||||||
|
./roles/base-linux
|
||||||
];
|
];
|
||||||
|
|
||||||
# Media center specific overrides can go here if needed
|
# Media center specific overrides can go here if needed
|
||||||
|
|||||||
@@ -61,6 +61,52 @@ in
|
|||||||
description = "Delay before focusing window";
|
description = "Delay before focusing window";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enableSpansDisplays = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
description = ''
|
||||||
|
Configure macOS Spaces to span displays (required for aerospace multi-monitor support).
|
||||||
|
Sets com.apple.spaces.spans-displays to true.
|
||||||
|
|
||||||
|
NOTE: This was previously set at the system level in modules/aerospace.nix,
|
||||||
|
but has been moved to home-manager for better modularity.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
ctrlShortcuts = {
|
||||||
|
enable = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description = ''
|
||||||
|
Remap common macOS Cmd shortcuts to Ctrl equivalents for all operations.
|
||||||
|
This makes macOS behave more like Linux.
|
||||||
|
|
||||||
|
Shortcuts remapped globally:
|
||||||
|
- Ctrl+N: New Window
|
||||||
|
- Ctrl+T: New Tab
|
||||||
|
- Ctrl+W: Close Tab
|
||||||
|
- Ctrl+S: Save / Save As
|
||||||
|
- Ctrl+O: Open
|
||||||
|
- Ctrl+F: Find
|
||||||
|
- Ctrl+H: Find and Replace
|
||||||
|
- Ctrl+P: Print
|
||||||
|
- Ctrl+C/V/X: Copy/Paste/Cut
|
||||||
|
- Ctrl+Z: Undo
|
||||||
|
|
||||||
|
NOTE: Terminal emulators like Ghostty require per-app overrides (configured separately)
|
||||||
|
to preserve Ctrl+C as SIGINT instead of Copy.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
sketchybar = {
|
||||||
|
enable = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
description = "Whether to enable SketchyBar status bar";
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
@@ -72,17 +118,78 @@ in
|
|||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
# Install aerospace package and autoraise if enabled
|
# Configure macOS preferences via targets.darwin.defaults
|
||||||
home.packages = [ pkgs.aerospace ]
|
targets.darwin.defaults = mkMerge [
|
||||||
++ optionals cfg.autoraise.enable [ pkgs.autoraise ];
|
# Spaces span displays (required for multi-monitor aerospace)
|
||||||
|
(mkIf cfg.enableSpansDisplays {
|
||||||
|
"com.apple.spaces" = {
|
||||||
|
spans-displays = true;
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
# Configure aerospace with user settings
|
# Ctrl shortcuts to make macOS behave more like Linux
|
||||||
|
(mkIf cfg.ctrlShortcuts.enable {
|
||||||
|
NSGlobalDomain.NSUserKeyEquivalents = {
|
||||||
|
# Window/Tab operations
|
||||||
|
"New Window" = "^n";
|
||||||
|
"New Tab" = "^t";
|
||||||
|
"Close Tab" = "^w";
|
||||||
|
# File operations
|
||||||
|
"Save" = "^s";
|
||||||
|
"Save As…" = "^$s"; # Ctrl+Shift+S
|
||||||
|
"Open" = "^o";
|
||||||
|
"Open…" = "^o";
|
||||||
|
# Find operations
|
||||||
|
"Find" = "^f";
|
||||||
|
"Find…" = "^f";
|
||||||
|
"Find and Replace" = "^h";
|
||||||
|
"Find and Replace…" = "^h";
|
||||||
|
# Print
|
||||||
|
"Print" = "^p";
|
||||||
|
"Print…" = "^p";
|
||||||
|
# Clipboard operations
|
||||||
|
"Copy" = "^c";
|
||||||
|
"Paste" = "^v";
|
||||||
|
"Cut" = "^x";
|
||||||
|
# Undo/Redo
|
||||||
|
"Undo" = "^z";
|
||||||
|
"Redo" = "^$z"; # Ctrl+Shift+Z
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
# Ghostty-specific overrides to preserve terminal behavior
|
||||||
|
# Remap clipboard operations back to Cmd (macOS default) so Ctrl+C remains SIGINT
|
||||||
|
(mkIf cfg.ctrlShortcuts.enable {
|
||||||
|
"com.mitchellh.ghostty".NSUserKeyEquivalents = {
|
||||||
|
# Remap back to Cmd for clipboard operations
|
||||||
|
"Copy" = "@c"; # Cmd+C
|
||||||
|
"Paste" = "@v"; # Cmd+V
|
||||||
|
"Cut" = "@x"; # Cmd+X
|
||||||
|
"Undo" = "@z"; # Cmd+Z
|
||||||
|
"Redo" = "@$z"; # Cmd+Shift+Z
|
||||||
|
};
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
# Install aerospace package and optional tools if enabled
|
||||||
|
home.packages = [ pkgs.aerospace ]
|
||||||
|
++ optionals cfg.autoraise.enable [ pkgs.autoraise ]
|
||||||
|
++ optionals cfg.sketchybar.enable [ pkgs.sketchybar pkgs.sketchybar-app-font ];
|
||||||
|
|
||||||
|
# Enable and configure aerospace
|
||||||
|
programs.aerospace.enable = true;
|
||||||
|
programs.aerospace.launchd.enable = cfg.launchd.enable;
|
||||||
programs.aerospace.userSettings = mkMerge [
|
programs.aerospace.userSettings = mkMerge [
|
||||||
# Default configuration with leader key substitution
|
# Default configuration with leader key substitution
|
||||||
{
|
{
|
||||||
|
# Disable normalizations for i3-like behavior
|
||||||
|
enable-normalization-flatten-containers = false;
|
||||||
|
enable-normalization-opposite-orientation-for-nested-containers = false;
|
||||||
|
|
||||||
mode.main.binding = {
|
mode.main.binding = {
|
||||||
"${cfg.leader}-slash" = "layout tiles horizontal vertical";
|
"${cfg.leader}-w" = "layout accordion horizontal"; # tabbed
|
||||||
"${cfg.leader}-comma" = "layout accordion horizontal vertical";
|
"${cfg.leader}-s" = "layout accordion vertical"; # stacking
|
||||||
|
"${cfg.leader}-e" = "layout tiles horizontal vertical"; # tiles, toggles orientation
|
||||||
"${cfg.leader}-shift-q" = "close";
|
"${cfg.leader}-shift-q" = "close";
|
||||||
"${cfg.leader}-shift-f" = "fullscreen";
|
"${cfg.leader}-shift-f" = "fullscreen";
|
||||||
"${cfg.leader}-h" = "focus left";
|
"${cfg.leader}-h" = "focus left";
|
||||||
@@ -93,8 +200,7 @@ in
|
|||||||
"${cfg.leader}-shift-j" = "move down";
|
"${cfg.leader}-shift-j" = "move down";
|
||||||
"${cfg.leader}-shift-k" = "move up";
|
"${cfg.leader}-shift-k" = "move up";
|
||||||
"${cfg.leader}-shift-l" = "move right";
|
"${cfg.leader}-shift-l" = "move right";
|
||||||
"${cfg.leader}-minus" = "resize smart -50";
|
"${cfg.leader}-r" = "mode resize";
|
||||||
"${cfg.leader}-equal" = "resize smart +50";
|
|
||||||
"${cfg.leader}-1" = "workspace 1";
|
"${cfg.leader}-1" = "workspace 1";
|
||||||
"${cfg.leader}-2" = "workspace 2";
|
"${cfg.leader}-2" = "workspace 2";
|
||||||
"${cfg.leader}-3" = "workspace 3";
|
"${cfg.leader}-3" = "workspace 3";
|
||||||
@@ -148,6 +254,20 @@ in
|
|||||||
"${cfg.leader}-p" = "mode passthrough";
|
"${cfg.leader}-p" = "mode passthrough";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Resize mode: For window resizing operations
|
||||||
|
mode.resize.binding = {
|
||||||
|
h = "resize width -50";
|
||||||
|
j = "resize height +50";
|
||||||
|
k = "resize height -50";
|
||||||
|
l = "resize width +50";
|
||||||
|
|
||||||
|
minus = "resize smart -50";
|
||||||
|
equal = "resize smart +50";
|
||||||
|
|
||||||
|
esc = "mode main";
|
||||||
|
enter = "mode main";
|
||||||
|
};
|
||||||
|
|
||||||
# Service mode: For deliberate aerospace window management operations
|
# Service mode: For deliberate aerospace window management operations
|
||||||
mode.service.binding = {
|
mode.service.binding = {
|
||||||
esc = ["reload-config" "mode main"];
|
esc = ["reload-config" "mode main"];
|
||||||
@@ -166,22 +286,27 @@ in
|
|||||||
esc = "mode main";
|
esc = "mode main";
|
||||||
"${cfg.leader}-p" = "mode main";
|
"${cfg.leader}-p" = "mode main";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# SketchyBar integration - notify bar of workspace changes
|
||||||
|
exec-on-workspace-change = mkIf cfg.sketchybar.enable [
|
||||||
|
"/bin/bash" "-c"
|
||||||
|
"${pkgs.sketchybar}/bin/sketchybar --trigger aerospace_workspace_change FOCUSED=$AEROSPACE_FOCUSED_WORKSPACE PREV=$AEROSPACE_PREV_WORKSPACE"
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
# Gaps configuration - prevent windows from overlapping SketchyBar
|
||||||
|
(mkIf cfg.sketchybar.enable {
|
||||||
|
gaps = {
|
||||||
|
outer = {
|
||||||
|
top = 0;
|
||||||
|
bottom = 40;
|
||||||
|
left = 0;
|
||||||
|
right = 0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})
|
||||||
cfg.userSettings
|
cfg.userSettings
|
||||||
];
|
];
|
||||||
|
|
||||||
# Launchd agent for auto-starting aerospace
|
|
||||||
launchd.agents.aerospace = mkIf cfg.launchd.enable {
|
|
||||||
enable = true;
|
|
||||||
config = {
|
|
||||||
Program = "${pkgs.aerospace}/Applications/AeroSpace.app/Contents/MacOS/AeroSpace";
|
|
||||||
RunAtLoad = true;
|
|
||||||
KeepAlive = true;
|
|
||||||
StandardOutPath = "/tmp/aerospace.log";
|
|
||||||
StandardErrorPath = "/tmp/aerospace.err.log";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
# Launchd agent for autoraise
|
# Launchd agent for autoraise
|
||||||
launchd.agents.autoraise = mkIf cfg.autoraise.enable {
|
launchd.agents.autoraise = mkIf cfg.autoraise.enable {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -196,5 +321,396 @@ in
|
|||||||
KeepAlive = true;
|
KeepAlive = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# SketchyBar configuration
|
||||||
|
home.file.".config/sketchybar/sketchybarrc" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
onChange = "${pkgs.sketchybar}/bin/sketchybar --reload";
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Plugin directory
|
||||||
|
PLUGIN_DIR="$HOME/.config/sketchybar/plugins"
|
||||||
|
|
||||||
|
# Colors - i3/sway theme with exact color matching
|
||||||
|
# Focused window/workspace color from i3/sway
|
||||||
|
FOCUSED=0xff285577
|
||||||
|
|
||||||
|
# Background colors matching i3blocks bar
|
||||||
|
BAR_BG=0xcc000000 # Semi-transparent black
|
||||||
|
ITEM_BG=0xff333333 # Dark gray for inactive items
|
||||||
|
|
||||||
|
# Text colors
|
||||||
|
TEXT=0xffffffff # White text
|
||||||
|
GRAY=0xff888888 # Muted text for inactive items
|
||||||
|
|
||||||
|
# Accent colors for warnings
|
||||||
|
WARNING=0xffff9900
|
||||||
|
CRITICAL=0xff900000
|
||||||
|
|
||||||
|
# Configure the bar appearance
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --bar \
|
||||||
|
position=bottom \
|
||||||
|
height=32 \
|
||||||
|
color=$BAR_BG \
|
||||||
|
border_width=0 \
|
||||||
|
corner_radius=0 \
|
||||||
|
padding_left=10 \
|
||||||
|
padding_right=10
|
||||||
|
|
||||||
|
# Set default properties for all items
|
||||||
|
# Using monospace font to match waybar's Fira Code styling
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --default \
|
||||||
|
updates=when_shown \
|
||||||
|
icon.font="SF Mono:Regular:13.0" \
|
||||||
|
icon.color=$TEXT \
|
||||||
|
icon.padding_left=4 \
|
||||||
|
icon.padding_right=4 \
|
||||||
|
label.font="SF Mono:Regular:13.0" \
|
||||||
|
label.color=$TEXT \
|
||||||
|
label.padding_left=4 \
|
||||||
|
label.padding_right=4 \
|
||||||
|
padding_left=4 \
|
||||||
|
padding_right=4 \
|
||||||
|
background.corner_radius=5 \
|
||||||
|
background.height=24
|
||||||
|
|
||||||
|
# Register aerospace workspace change event
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add event aerospace_workspace_change
|
||||||
|
|
||||||
|
# Create workspace indicators for workspaces 1-10
|
||||||
|
for sid in 1 2 3 4 5 6 7 8 9 10; do
|
||||||
|
# Display "0" for workspace 10
|
||||||
|
if [ "$sid" = "10" ]; then
|
||||||
|
display="0"
|
||||||
|
else
|
||||||
|
display="$sid"
|
||||||
|
fi
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item space.$sid left \
|
||||||
|
--subscribe space.$sid aerospace_workspace_change \
|
||||||
|
--set space.$sid \
|
||||||
|
update_freq=2 \
|
||||||
|
width=32 \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.corner_radius=5 \
|
||||||
|
background.height=20 \
|
||||||
|
background.drawing=on \
|
||||||
|
icon="$display" \
|
||||||
|
icon.padding_left=13 \
|
||||||
|
icon.padding_right=11 \
|
||||||
|
icon.align=center \
|
||||||
|
label.drawing=off \
|
||||||
|
click_script="${pkgs.aerospace}/bin/aerospace workspace $sid" \
|
||||||
|
script="$PLUGIN_DIR/aerospace.sh $sid"
|
||||||
|
done
|
||||||
|
|
||||||
|
# Separator after workspaces
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item separator_left left \
|
||||||
|
--set separator_left \
|
||||||
|
icon="" \
|
||||||
|
label="" \
|
||||||
|
background.drawing=off \
|
||||||
|
padding_left=10 \
|
||||||
|
padding_right=10
|
||||||
|
|
||||||
|
# System monitoring modules (right side)
|
||||||
|
# Note: Items added to 'right' appear in reverse order (last added = leftmost)
|
||||||
|
# Adding in reverse to get: disk | cpu | memory | battery | volume | calendar
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item calendar right \
|
||||||
|
--set calendar \
|
||||||
|
icon="📅" \
|
||||||
|
update_freq=30 \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
script="$PLUGIN_DIR/calendar.sh"
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item separator_media right \
|
||||||
|
--set separator_media \
|
||||||
|
icon="|" \
|
||||||
|
label="" \
|
||||||
|
background.drawing=off \
|
||||||
|
padding_left=5 \
|
||||||
|
padding_right=5
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item volume right \
|
||||||
|
--set volume \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
script="$PLUGIN_DIR/volume.sh" \
|
||||||
|
--subscribe volume volume_change
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item battery right \
|
||||||
|
--set battery \
|
||||||
|
update_freq=120 \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
script="$PLUGIN_DIR/battery.sh" \
|
||||||
|
--subscribe battery system_woke power_source_change
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item separator_sys right \
|
||||||
|
--set separator_sys \
|
||||||
|
icon="|" \
|
||||||
|
label="" \
|
||||||
|
background.drawing=off \
|
||||||
|
padding_left=5 \
|
||||||
|
padding_right=5
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item memory right \
|
||||||
|
--set memory \
|
||||||
|
update_freq=5 \
|
||||||
|
icon="🐏" \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
script="$PLUGIN_DIR/memory.sh"
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item cpu right \
|
||||||
|
--set cpu \
|
||||||
|
update_freq=2 \
|
||||||
|
icon="🧠" \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
script="$PLUGIN_DIR/cpu.sh"
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add item disk right \
|
||||||
|
--set disk \
|
||||||
|
update_freq=60 \
|
||||||
|
icon="💾" \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
script="$PLUGIN_DIR/disk.sh"
|
||||||
|
|
||||||
|
# Menu bar extras / system tray items (rightmost)
|
||||||
|
# Note: Requires Screen Recording permission for SketchyBar in System Settings
|
||||||
|
# Use 'sketchybar --query default_menu_items' to discover available items
|
||||||
|
|
||||||
|
# Bluetooth
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add alias "Control Center,Bluetooth" right \
|
||||||
|
--set "Control Center,Bluetooth" \
|
||||||
|
alias.update_freq=1 \
|
||||||
|
padding_left=0 \
|
||||||
|
padding_right=0
|
||||||
|
|
||||||
|
# WiFi
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --add alias "Control Center,WiFi" right \
|
||||||
|
--set "Control Center,WiFi" \
|
||||||
|
alias.update_freq=1 \
|
||||||
|
padding_left=0 \
|
||||||
|
padding_right=0
|
||||||
|
|
||||||
|
# Add other menu bar apps as discovered
|
||||||
|
# Common examples:
|
||||||
|
# - Cloudflare WARP: --add alias "Cloudflare WARP,Item-0" right
|
||||||
|
# - Notion Calendar: --add alias "Notion Calendar,Item-0" right
|
||||||
|
# Run 'sketchybar --query default_menu_items' to find exact names
|
||||||
|
|
||||||
|
# Update the bar
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --update
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar aerospace workspace plugin
|
||||||
|
home.file.".config/sketchybar/plugins/aerospace.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Colors
|
||||||
|
FOCUSED_COLOR=0xff285577
|
||||||
|
ITEM_BG=0xff333333
|
||||||
|
TEXT=0xffffffff
|
||||||
|
GRAY=0xff555555
|
||||||
|
|
||||||
|
# Get the currently focused workspace directly from aerospace
|
||||||
|
# Trim whitespace to ensure clean comparison
|
||||||
|
FOCUSED=$(${pkgs.aerospace}/bin/aerospace list-workspaces --focused | tr -d ' \n\r')
|
||||||
|
|
||||||
|
# Get list of empty workspaces
|
||||||
|
EMPTY_WORKSPACES=$(${pkgs.aerospace}/bin/aerospace list-workspaces --monitor all --empty)
|
||||||
|
|
||||||
|
# Clean up the workspace number parameter
|
||||||
|
WORKSPACE_NUM=$(echo "$1" | tr -d ' \n\r')
|
||||||
|
|
||||||
|
# Check if workspace has windows (is NOT empty)
|
||||||
|
IS_EMPTY=false
|
||||||
|
if echo "$EMPTY_WORKSPACES" | grep -q "^$WORKSPACE_NUM$"; then
|
||||||
|
IS_EMPTY=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if this workspace is focused
|
||||||
|
IS_FOCUSED=false
|
||||||
|
if [ "$WORKSPACE_NUM" = "$FOCUSED" ]; then
|
||||||
|
IS_FOCUSED=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Determine visibility and styling
|
||||||
|
# Always show focused workspace (even if empty) with fixed width
|
||||||
|
# Hide non-focused empty workspaces by setting width to 0 (collapsed)
|
||||||
|
# Show non-focused non-empty workspaces with fixed width and inactive styling
|
||||||
|
|
||||||
|
if [ "$IS_FOCUSED" = "true" ]; then
|
||||||
|
# Focused workspace - always show with focused styling
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set space.$WORKSPACE_NUM \
|
||||||
|
drawing=on \
|
||||||
|
width=32 \
|
||||||
|
icon.padding_left=13 \
|
||||||
|
icon.padding_right=11 \
|
||||||
|
icon.align=center \
|
||||||
|
background.color=$FOCUSED_COLOR \
|
||||||
|
background.drawing=on \
|
||||||
|
icon.color=$TEXT
|
||||||
|
elif [ "$IS_EMPTY" = "true" ]; then
|
||||||
|
# Empty workspace (not focused) - hide by turning off drawing
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set space.$WORKSPACE_NUM \
|
||||||
|
drawing=off
|
||||||
|
else
|
||||||
|
# Non-empty workspace (not focused) - show with inactive styling
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set space.$WORKSPACE_NUM \
|
||||||
|
drawing=on \
|
||||||
|
width=32 \
|
||||||
|
icon.padding_left=13 \
|
||||||
|
icon.padding_right=11 \
|
||||||
|
icon.align=center \
|
||||||
|
background.color=$ITEM_BG \
|
||||||
|
background.drawing=on \
|
||||||
|
icon.color=$GRAY
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar CPU monitoring plugin
|
||||||
|
home.file.".config/sketchybar/plugins/cpu.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
CORE_COUNT=$(sysctl -n machdep.cpu.thread_count)
|
||||||
|
CPU_INFO=$(ps -eo pcpu,user)
|
||||||
|
CPU_SYS=$(echo "$CPU_INFO" | grep -v $(whoami) | sed "s/[^ 0-9\.]//g" | awk "{sum+=\$1} END {print sum/(100.0 * $CORE_COUNT)}")
|
||||||
|
CPU_USER=$(echo "$CPU_INFO" | grep $(whoami) | sed "s/[^ 0-9\.]//g" | awk "{sum+=\$1} END {print sum/(100.0 * $CORE_COUNT)}")
|
||||||
|
CPU_PERCENT="$(echo "$CPU_SYS $CPU_USER" | awk '{printf "%.0f\n", ($1 + $2)*100}')"
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set $NAME label="$CPU_PERCENT%"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar memory monitoring plugin
|
||||||
|
home.file.".config/sketchybar/plugins/memory.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
MEMORY_STATS=$(vm_stat)
|
||||||
|
PAGES_FREE=$(echo "$MEMORY_STATS" | grep "Pages free" | awk '{print $3}' | tr -d '.')
|
||||||
|
PAGES_ACTIVE=$(echo "$MEMORY_STATS" | grep "Pages active" | awk '{print $3}' | tr -d '.')
|
||||||
|
PAGES_INACTIVE=$(echo "$MEMORY_STATS" | grep "Pages inactive" | awk '{print $3}' | tr -d '.')
|
||||||
|
PAGES_WIRED=$(echo "$MEMORY_STATS" | grep "Pages wired down" | awk '{print $4}' | tr -d '.')
|
||||||
|
PAGES_COMPRESSED=$(echo "$MEMORY_STATS" | grep "Pages stored in compressor" | awk '{print $5}' | tr -d '.')
|
||||||
|
|
||||||
|
TOTAL_PAGES=$((PAGES_FREE + PAGES_ACTIVE + PAGES_INACTIVE + PAGES_WIRED + PAGES_COMPRESSED))
|
||||||
|
USED_PAGES=$((PAGES_ACTIVE + PAGES_INACTIVE + PAGES_WIRED + PAGES_COMPRESSED))
|
||||||
|
MEMORY_PERCENT=$((USED_PAGES * 100 / TOTAL_PAGES))
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set $NAME label="$MEMORY_PERCENT%"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar disk monitoring plugin
|
||||||
|
home.file.".config/sketchybar/plugins/disk.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
DISK_USAGE=$(df -H / | grep -v Filesystem | awk '{print $5}')
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set $NAME label="$DISK_USAGE"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar battery monitoring plugin
|
||||||
|
home.file.".config/sketchybar/plugins/battery.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
PERCENTAGE=$(pmset -g batt | grep -Eo "\d+%" | cut -d% -f1)
|
||||||
|
CHARGING=$(pmset -g batt | grep 'AC Power')
|
||||||
|
|
||||||
|
if [ "$PERCENTAGE" = "" ]; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Select icon based on battery level
|
||||||
|
case ''${PERCENTAGE} in
|
||||||
|
9[0-9]|100) ICON="🔋"
|
||||||
|
;;
|
||||||
|
[6-8][0-9]) ICON="🔋"
|
||||||
|
;;
|
||||||
|
[3-5][0-9]) ICON="🔋"
|
||||||
|
;;
|
||||||
|
[1-2][0-9]) ICON="🔋"
|
||||||
|
;;
|
||||||
|
*) ICON="🪫"
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Show charging icon if connected to power
|
||||||
|
if [[ $CHARGING != "" ]]; then
|
||||||
|
ICON="⚡"
|
||||||
|
fi
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set $NAME icon="$ICON" label="''${PERCENTAGE}%"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar volume monitoring plugin
|
||||||
|
home.file.".config/sketchybar/plugins/volume.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ "$SENDER" = "volume_change" ]; then
|
||||||
|
VOLUME=$(osascript -e "output volume of (get volume settings)")
|
||||||
|
MUTED=$(osascript -e "output muted of (get volume settings)")
|
||||||
|
|
||||||
|
if [ "$MUTED" = "true" ]; then
|
||||||
|
ICON="🔇"
|
||||||
|
LABEL=""
|
||||||
|
else
|
||||||
|
case $VOLUME in
|
||||||
|
[6-9][0-9]|100) ICON="🔊"
|
||||||
|
;;
|
||||||
|
[3-5][0-9]) ICON="🔉"
|
||||||
|
;;
|
||||||
|
*) ICON="🔈"
|
||||||
|
esac
|
||||||
|
LABEL="$VOLUME%"
|
||||||
|
fi
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set $NAME icon="$ICON" label="$LABEL"
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# SketchyBar calendar/clock plugin
|
||||||
|
home.file.".config/sketchybar/plugins/calendar.sh" = mkIf cfg.sketchybar.enable {
|
||||||
|
executable = true;
|
||||||
|
text = ''
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
${pkgs.sketchybar}/bin/sketchybar --set $NAME label="$(date '+%Y-%m-%d %H:%M')"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
# Launchd agent for auto-starting sketchybar
|
||||||
|
launchd.agents.sketchybar = mkIf cfg.sketchybar.enable {
|
||||||
|
enable = true;
|
||||||
|
config = {
|
||||||
|
ProgramArguments = [ "${pkgs.sketchybar}/bin/sketchybar" ];
|
||||||
|
RunAtLoad = true;
|
||||||
|
KeepAlive = true;
|
||||||
|
StandardOutPath = "/tmp/sketchybar.log";
|
||||||
|
StandardErrorPath = "/tmp/sketchybar.err.log";
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
7
home/roles/base-darwin/default.nix
Normal file
7
home/roles/base-darwin/default.nix
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
# Base imports for Darwin home configurations
|
||||||
|
# Includes Darwin-specific roles that only work on macOS
|
||||||
|
imports = [
|
||||||
|
../aerospace
|
||||||
|
];
|
||||||
|
}
|
||||||
8
home/roles/base-linux/default.nix
Normal file
8
home/roles/base-linux/default.nix
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
# Base imports for Linux home configurations
|
||||||
|
# Includes Linux-specific roles that require Linux-only home-manager modules
|
||||||
|
imports = [
|
||||||
|
../plasma-manager
|
||||||
|
../i3+sway
|
||||||
|
];
|
||||||
|
}
|
||||||
@@ -14,7 +14,8 @@ in
|
|||||||
home.packages = [
|
home.packages = [
|
||||||
# Communication apps
|
# Communication apps
|
||||||
pkgs.element-desktop
|
pkgs.element-desktop
|
||||||
#pkgs.fluffychat #marked insecure as of nixos 25.05
|
# Re-enabled in 25.11 after security issues were resolved
|
||||||
|
pkgs.fluffychat
|
||||||
pkgs.nextcloud-talk-desktop
|
pkgs.nextcloud-talk-desktop
|
||||||
|
|
||||||
# For logging back into google chat
|
# For logging back into google chat
|
||||||
|
|||||||
@@ -1,4 +1,7 @@
|
|||||||
{
|
{
|
||||||
|
# Shared roles that work across all platforms (Linux, Darwin, etc.)
|
||||||
|
# Platform-specific roles are imported via base-linux or base-darwin
|
||||||
|
# in each home configuration file
|
||||||
imports = [
|
imports = [
|
||||||
./base
|
./base
|
||||||
./communication
|
./communication
|
||||||
@@ -12,9 +15,6 @@
|
|||||||
./office
|
./office
|
||||||
./sync
|
./sync
|
||||||
./tmux
|
./tmux
|
||||||
./plasma-manager
|
|
||||||
./emacs
|
./emacs
|
||||||
./aerospace
|
|
||||||
./i3+sway
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -327,6 +327,7 @@ in {
|
|||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
extraOptions = [ "--unsupported-gpu" ];
|
||||||
config = recursiveUpdate base_sway_config cfg.extraSwayConfig;
|
config = recursiveUpdate base_sway_config cfg.extraSwayConfig;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -39,12 +39,7 @@ with lib;
|
|||||||
services.xserver.videoDrivers = [ "amdgpu" ];
|
services.xserver.videoDrivers = [ "amdgpu" ];
|
||||||
hardware.graphics.enable = true;
|
hardware.graphics.enable = true;
|
||||||
hardware.graphics.enable32Bit = true;
|
hardware.graphics.enable32Bit = true;
|
||||||
hardware.graphics.extraPackages = with pkgs; [
|
# RADV (AMD's Vulkan driver) is now enabled by default, amdvlk was removed
|
||||||
amdvlk
|
|
||||||
];
|
|
||||||
hardware.graphics.extraPackages32 = with pkgs; [
|
|
||||||
driversi686Linux.amdvlk
|
|
||||||
];
|
|
||||||
|
|
||||||
# This option defines the first version of NixOS you have installed on this particular machine,
|
# This option defines the first version of NixOS you have installed on this particular machine,
|
||||||
# and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions.
|
# and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions.
|
||||||
|
|||||||
@@ -1,10 +1,6 @@
|
|||||||
{ config, lib, pkgs, ... }:
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
{
|
{
|
||||||
imports = [
|
|
||||||
../../modules/aerospace.nix
|
|
||||||
];
|
|
||||||
|
|
||||||
# Basic system configuration for macOS work laptop
|
# Basic system configuration for macOS work laptop
|
||||||
system.stateVersion = 6;
|
system.stateVersion = 6;
|
||||||
|
|
||||||
@@ -18,12 +14,6 @@
|
|||||||
NSGlobalDomain.AppleShowAllExtensions = true;
|
NSGlobalDomain.AppleShowAllExtensions = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
# Enable aerospace system settings
|
|
||||||
services.aerospace = {
|
|
||||||
enable = true;
|
|
||||||
enableSpansDisplays = true; # Default, but shown for clarity
|
|
||||||
};
|
|
||||||
|
|
||||||
# TODO: Find a way to not duplicate this
|
# TODO: Find a way to not duplicate this
|
||||||
launchd.user.envVariables = {
|
launchd.user.envVariables = {
|
||||||
# DOOM Emacs environment variables
|
# DOOM Emacs environment variables
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
|
../../roles/desktop/steamos.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
roles = {
|
roles = {
|
||||||
|
|||||||
@@ -36,7 +36,7 @@
|
|||||||
extraPackages = with pkgs; [
|
extraPackages = with pkgs; [
|
||||||
mesa
|
mesa
|
||||||
libvdpau-va-gl
|
libvdpau-va-gl
|
||||||
vaapiVdpau
|
libva-vdpau-driver
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
environment.sessionVariables = {
|
environment.sessionVariables = {
|
||||||
|
|||||||
@@ -1,30 +0,0 @@
|
|||||||
{ config, lib, pkgs, ... }:
|
|
||||||
|
|
||||||
with lib;
|
|
||||||
|
|
||||||
let
|
|
||||||
cfg = config.services.aerospace;
|
|
||||||
in
|
|
||||||
{
|
|
||||||
options.services.aerospace = {
|
|
||||||
enable = mkEnableOption "AeroSpace window manager system configuration";
|
|
||||||
|
|
||||||
enableSpansDisplays = mkOption {
|
|
||||||
type = types.bool;
|
|
||||||
default = true;
|
|
||||||
description = ''
|
|
||||||
Configure macOS Spaces to span displays (required for aerospace multi-monitor support).
|
|
||||||
When enabled, sets com.apple.spaces.spans-displays to true.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
|
||||||
# Configure spaces to span displays (required for aerospace multi-monitor support)
|
|
||||||
system.defaults.CustomUserPreferences = mkIf cfg.enableSpansDisplays {
|
|
||||||
"com.apple.spaces" = {
|
|
||||||
spans-displays = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
@@ -22,6 +22,5 @@ with lib;
|
|||||||
./kde.nix
|
./kde.nix
|
||||||
./programs.nix
|
./programs.nix
|
||||||
./sddm.nix
|
./sddm.nix
|
||||||
./steamos.nix
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ in
|
|||||||
# Emulators
|
# Emulators
|
||||||
dolphin-emu
|
dolphin-emu
|
||||||
|
|
||||||
# Waiting for 25.11 where the binary build has been fixed
|
# Re-enabled in 25.11 after binary build was fixed
|
||||||
#dolphin-emu-primehack
|
dolphin-emu-primehack
|
||||||
|
|
||||||
# Experimenting with just using the steam version + downloading
|
# Experimenting with just using the steam version + downloading
|
||||||
# indiviudal cores
|
# indiviudal cores
|
||||||
@@ -30,14 +30,6 @@ in
|
|||||||
dedicatedServer.openFirewall = true;
|
dedicatedServer.openFirewall = true;
|
||||||
localNetworkGameTransfers.openFirewall = true;
|
localNetworkGameTransfers.openFirewall = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
# TODO: Remove me once dolphin-emu and dolphin-emu-primehack update
|
|
||||||
# dependencies to mbedtls from mbedtls_2 (which is currently)
|
|
||||||
# unmaintained
|
|
||||||
nixpkgs.config.permittedInsecurePackages = [ "mbedtls-2.28.10" ];
|
|
||||||
warnings = [
|
|
||||||
"Using insecure mbedtls-2.28.10 for Dolphin Emu - check for updates regularly"
|
|
||||||
];
|
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,64 +0,0 @@
|
|||||||
{ lib, config, ... }:
|
|
||||||
|
|
||||||
# Minimal Jovian compatibility layer for NixOS stable (25.05)
|
|
||||||
# Defines only the Jovian options used by roles/desktop/steamos.nix
|
|
||||||
# No actual implementation - just option definitions to prevent evaluation errors
|
|
||||||
# REMOVE THIS FILE when all systems are on NixOS 25.11+ or unstable
|
|
||||||
|
|
||||||
with lib;
|
|
||||||
|
|
||||||
let
|
|
||||||
nixosVersion = config.system.nixos.release;
|
|
||||||
isCompatibleVersion = versionOlder nixosVersion "25.11";
|
|
||||||
in
|
|
||||||
{
|
|
||||||
options.jovian = {
|
|
||||||
steam = {
|
|
||||||
enable = mkEnableOption "Steam (jovian-compat stub)";
|
|
||||||
|
|
||||||
autoStart = mkOption {
|
|
||||||
type = types.bool;
|
|
||||||
default = false;
|
|
||||||
description = "Auto-start Steam (jovian-compat stub)";
|
|
||||||
};
|
|
||||||
|
|
||||||
user = mkOption {
|
|
||||||
type = types.str;
|
|
||||||
default = "user";
|
|
||||||
description = "Steam user (jovian-compat stub)";
|
|
||||||
};
|
|
||||||
|
|
||||||
desktopSession = mkOption {
|
|
||||||
type = types.nullOr types.str;
|
|
||||||
default = null;
|
|
||||||
description = "Desktop session (jovian-compat stub)";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
decky-loader = {
|
|
||||||
enable = mkEnableOption "Decky Loader (jovian-compat stub)";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = mkMerge [
|
|
||||||
{
|
|
||||||
assertions = [
|
|
||||||
{
|
|
||||||
assertion = isCompatibleVersion;
|
|
||||||
message = ''
|
|
||||||
The Jovian compatibility shim (roles/jovian-compat.nix) is only needed for NixOS 25.05 and earlier.
|
|
||||||
You are running NixOS ${nixosVersion}.
|
|
||||||
Please remove 'roles/jovian-compat.nix' from your flake.nix nixosModules list.
|
|
||||||
'';
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
||||||
# No config implementation - these options do nothing on stable systems
|
|
||||||
# steamos role is only enabled on nix-deck which uses unstable anyway
|
|
||||||
(mkIf config.jovian.steam.enable {
|
|
||||||
warnings = [
|
|
||||||
"Jovian is enabled but you're using the compatibility stub. This won't work correctly. Use NixOS unstable for Jovian support."
|
|
||||||
];
|
|
||||||
})
|
|
||||||
];
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user