Working on reshuffling
This commit is contained in:
+7
-6
@@ -1365,11 +1365,13 @@ in
|
|||||||
lib.mkEnableOption "Enable Zsh terminal with Oh-My-Zsh";
|
lib.mkEnableOption "Enable Zsh terminal with Oh-My-Zsh";
|
||||||
|
|
||||||
# Wrap everything in config if enabled
|
# Wrap everything in config if enabled
|
||||||
config = lib.mkIf (config.enableZsh or false) (let
|
config = { config, ... }: let
|
||||||
|
# Enable flag now safely references the toggle option
|
||||||
|
enableProgram = config.enableZsh or false;
|
||||||
|
|
||||||
# Safe reference to defaultUser inside mkIf
|
# Safe reference to defaultUser inside mkIf
|
||||||
username = config.defaultUser or "henrov";
|
username = config.defaultUser or "henrov";
|
||||||
in
|
in lib.mkIf enableProgram {
|
||||||
{
|
|
||||||
myApps = {
|
myApps = {
|
||||||
zsh = {
|
zsh = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -1422,9 +1424,8 @@ in
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
});
|
};
|
||||||
}
|
}#+END_SRC
|
||||||
#+END_SRC
|
|
||||||
|
|
||||||
** =generated/modules/apps/emacs/emacs.nix=
|
** =generated/modules/apps/emacs/emacs.nix=
|
||||||
This sets up the emacs terminal
|
This sets up the emacs terminal
|
||||||
|
|||||||
@@ -1,87 +0,0 @@
|
|||||||
{ lib, ... }:
|
|
||||||
|
|
||||||
{
|
|
||||||
flake.nixosModules.emacs = { config, pkgs, lib, ... }:
|
|
||||||
|
|
||||||
{
|
|
||||||
# Optie om de module aan/uit te zetten
|
|
||||||
options.mySystem.system.emacs.enable = lib.mkEnableOption "Enable Emacs config";
|
|
||||||
|
|
||||||
config = lib.mkIf (config.mySystem.system.emacs.enable or false) {
|
|
||||||
# System packages (optioneel)
|
|
||||||
environment.systemPackages = with pkgs; [
|
|
||||||
# Voeg systeem-brede packages toe als je wilt
|
|
||||||
];
|
|
||||||
|
|
||||||
# Home Manager configuratie
|
|
||||||
home-manager.users.henrov = {
|
|
||||||
programs.emacs = {
|
|
||||||
enable = true;
|
|
||||||
package = pkgs.emacs-pgtk.override { withTreeSitter = true; };
|
|
||||||
|
|
||||||
extraPackages = epkgs: with epkgs; [
|
|
||||||
# Tree-sitter and language support
|
|
||||||
manualPackages.treesit-grammars.with-all-grammars
|
|
||||||
rust-mode
|
|
||||||
rustic
|
|
||||||
nix-mode
|
|
||||||
hcl-mode
|
|
||||||
|
|
||||||
# UI/UX and navigation
|
|
||||||
nerd-icons
|
|
||||||
doom-modeline
|
|
||||||
diminish
|
|
||||||
eldoc
|
|
||||||
eldoc-box
|
|
||||||
pulsar
|
|
||||||
which-key
|
|
||||||
avy
|
|
||||||
consult
|
|
||||||
vertico
|
|
||||||
marginalia
|
|
||||||
crux
|
|
||||||
shell-pop
|
|
||||||
|
|
||||||
# Completion and snippets
|
|
||||||
nerd-icons-corfu
|
|
||||||
corfu
|
|
||||||
cape
|
|
||||||
orderless
|
|
||||||
yasnippet
|
|
||||||
yasnippet-snippets
|
|
||||||
|
|
||||||
# Utilities and tools
|
|
||||||
rg
|
|
||||||
exec-path-from-shell
|
|
||||||
eat
|
|
||||||
f
|
|
||||||
gptel
|
|
||||||
nixpkgs-fmt
|
|
||||||
envrc
|
|
||||||
|
|
||||||
# Theming
|
|
||||||
catppuccin-theme
|
|
||||||
|
|
||||||
# Git
|
|
||||||
magit
|
|
||||||
|
|
||||||
# Editing and workflow
|
|
||||||
expreg
|
|
||||||
vundo
|
|
||||||
puni
|
|
||||||
|
|
||||||
# Error and side panel support
|
|
||||||
sideline
|
|
||||||
sideline-flymake
|
|
||||||
sideline-eglot
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
home.sessionVariables = {
|
|
||||||
EDITOR = "emacs";
|
|
||||||
XDG_SCREENSHOTS_DIR = "~/screenshots";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
{ lib, ... }:
|
|
||||||
|
|
||||||
let
|
|
||||||
# --- Program-specific paths/assets ---
|
|
||||||
programName = "zsh";
|
|
||||||
programAssets = ../../../assets/system/conf/${programName};
|
|
||||||
programFiles = builtins.readDir programAssets;
|
|
||||||
files = lib.genAttrs (builtins.attrNames programFiles) (name: {
|
|
||||||
src = "${programAssets}/${name}";
|
|
||||||
});
|
|
||||||
in
|
|
||||||
{
|
|
||||||
# Top-level toggle for this program
|
|
||||||
options.enableZsh =
|
|
||||||
lib.mkEnableOption "Enable Zsh terminal with Oh-My-Zsh";
|
|
||||||
|
|
||||||
# Wrap everything in config if enabled
|
|
||||||
config = lib.mkIf (config.enableZsh or false) (let
|
|
||||||
# Safe reference to defaultUser inside mkIf
|
|
||||||
username = config.defaultUser or "henrov";
|
|
||||||
in
|
|
||||||
{
|
|
||||||
myApps = {
|
|
||||||
zsh = {
|
|
||||||
enable = true;
|
|
||||||
assetsDir = programAssets;
|
|
||||||
files = files;
|
|
||||||
user = username;
|
|
||||||
|
|
||||||
# Zsh-specific settings
|
|
||||||
ohMyZsh = {
|
|
||||||
enable = true;
|
|
||||||
theme = "catppuccin-mocha";
|
|
||||||
plugins = [
|
|
||||||
"git"
|
|
||||||
"docker"
|
|
||||||
"direnv"
|
|
||||||
"zsh-autosuggestions"
|
|
||||||
"zsh-completions"
|
|
||||||
"zsh-history-substring-search"
|
|
||||||
# zsh-syntax-highlighting is sourced in initExtra
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
initExtra = ''
|
|
||||||
# Catppuccin Mocha colors
|
|
||||||
local mocha_base="#1E1E2E"
|
|
||||||
local mocha_surface0="#313244"
|
|
||||||
local mocha_text="#CDD6F4"
|
|
||||||
local mocha_lavender="#B4BEFE"
|
|
||||||
local mocha_blue="#89B4FA"
|
|
||||||
local mocha_sapphire="#74C7EC"
|
|
||||||
local mocha_teal="#94D2D5"
|
|
||||||
local mocha_green="#A6E3A1"
|
|
||||||
local mocha_yellow="#F9E2AF"
|
|
||||||
local mocha_peach="#FAB387"
|
|
||||||
local mocha_maroon="#EBA0AC"
|
|
||||||
local mocha_red="#F38BA8"
|
|
||||||
local mocha_mauve="#CBA6F7"
|
|
||||||
local mocha_pink="#F5E2C7"
|
|
||||||
local mocha_flamingo="#F2CDCD"
|
|
||||||
local mocha_rosewater="#F5E0DC"
|
|
||||||
|
|
||||||
# Prompt
|
|
||||||
PROMPT='%{$fg[$mocha_blue]%}%n%{$reset_color%}@%{$fg[$mocha_peach]%}%m%{$reset_color%} %{$fg[$mocha_lavender]%}%~%{$reset_color%} %{$fg[$mocha_red]%}$%{$reset_color%} '
|
|
||||||
RPROMPT='%{$fg[$mocha_green]%}%T%{$reset_color%}'
|
|
||||||
|
|
||||||
# Source zsh-syntax-highlighting if present
|
|
||||||
if [ -f ${files."zsh-syntax-highlighting".src} ]; then
|
|
||||||
source ${files."zsh-syntax-highlighting".src}
|
|
||||||
fi
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user