Make own modules toggleble with enable option
This commit is contained in:
parent
98e36877ba
commit
be015b5a06
|
|
@ -295,11 +295,11 @@
|
||||||
"nixpkgs": "nixpkgs_4"
|
"nixpkgs": "nixpkgs_4"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1706470195,
|
"lastModified": 1706712950,
|
||||||
"narHash": "sha256-SBdC0Xx7iOxjYKgIlHWfoH6oRIae1CBRZcIRIO5Iymc=",
|
"narHash": "sha256-17TOvi0vKtelaRCZJvDaXk7YTDphqYwUMtxyZmWtAF4=",
|
||||||
"ref": "refs/heads/master",
|
"ref": "refs/heads/master",
|
||||||
"rev": "148f7fe77452628d33cc431421a7819f3365cb03",
|
"rev": "edeed6fbbd204fb3eb9bd2a6342a6d142c8b7dac",
|
||||||
"revCount": 6,
|
"revCount": 8,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "ssh://gitea@pi1.odie.intranet/odie/neovim-flake"
|
"url": "ssh://gitea@pi1.odie.intranet/odie/neovim-flake"
|
||||||
},
|
},
|
||||||
|
|
|
||||||
36
flake.nix
36
flake.nix
|
|
@ -8,12 +8,12 @@
|
||||||
home-manager = {
|
home-manager = {
|
||||||
url = "github:nix-community/home-manager";
|
url = "github:nix-community/home-manager";
|
||||||
};
|
};
|
||||||
neovim = {
|
|
||||||
url = "git+ssh://gitea@pi1.odie.intranet/odie/neovim-flake";
|
|
||||||
};
|
|
||||||
neovim-nightly-overlay = {
|
neovim-nightly-overlay = {
|
||||||
url = "github:nix-community/neovim-nightly-overlay";
|
url = "github:nix-community/neovim-nightly-overlay";
|
||||||
};
|
};
|
||||||
|
neovim = {
|
||||||
|
url = "git+ssh://gitea@pi1.odie.intranet/odie/neovim-flake";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = inputs@{ self, nixpkgs, flake-utils, home-manager, ... }:
|
outputs = inputs@{ self, nixpkgs, flake-utils, home-manager, ... }:
|
||||||
|
|
@ -32,29 +32,26 @@
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
] ++ inputOverlays;
|
] ++ inputOverlays;
|
||||||
localLib = {
|
|
||||||
mkPkgs = system:
|
mkPkgs = system:
|
||||||
import nixpkgs {
|
import nixpkgs {
|
||||||
inherit system overlays;
|
inherit system overlays;
|
||||||
};
|
};
|
||||||
mkHomeManagerConfiguration = user: modules: system:
|
|
||||||
{
|
|
||||||
${user} = home-manager.lib.homeManagerConfiguration {
|
|
||||||
pkgs = (localLib.mkPkgs system).unstable; # Home-manager requires 'pkgs' instance
|
|
||||||
extraSpecialArgs = { inherit inputs outputs; };
|
|
||||||
inherit modules;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
in
|
in
|
||||||
{
|
rec {
|
||||||
homeConfigurations = localLib.mkHomeManagerConfiguration "odie" [
|
homeManagerModules = [
|
||||||
(import ./modules)
|
(import ./modules)
|
||||||
] "x86_64-linux";
|
];
|
||||||
|
homeConfigurations = {
|
||||||
|
"odie@asgard" = home-manager.lib.homeManagerConfiguration {
|
||||||
|
pkgs = (mkPkgs "x86_64-linux").unstable;
|
||||||
|
extraSpecialArgs = { inherit inputs outputs; };
|
||||||
|
modules = homeManagerModules;
|
||||||
|
};
|
||||||
|
};
|
||||||
packages = flake-utils.lib.eachDefaultSystem
|
packages = flake-utils.lib.eachDefaultSystem
|
||||||
(system:
|
(system:
|
||||||
let
|
let
|
||||||
pkgs = localLib.mkPkgs system;
|
pkgs = mkPkgs system;
|
||||||
in
|
in
|
||||||
with pkgs; {
|
with pkgs; {
|
||||||
inherit (unstable) hello;
|
inherit (unstable) hello;
|
||||||
|
|
@ -62,13 +59,10 @@
|
||||||
);
|
);
|
||||||
} // flake-utils.lib.eachDefaultSystem (system:
|
} // flake-utils.lib.eachDefaultSystem (system:
|
||||||
let
|
let
|
||||||
pkgs = localLib.mkPkgs system;
|
pkgs = mkPkgs system;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
formatter = pkgs.alejandra;
|
formatter = pkgs.alejandra;
|
||||||
packages = with pkgs; {
|
|
||||||
inherit (unstable) hello;
|
|
||||||
};
|
|
||||||
devShells = {
|
devShells = {
|
||||||
default = pkgs.mkShell {
|
default = pkgs.mkShell {
|
||||||
name = "home-manager";
|
name = "home-manager";
|
||||||
|
|
|
||||||
|
|
@ -5,32 +5,21 @@
|
||||||
language.base = "de_DE.UTF-8";
|
language.base = "de_DE.UTF-8";
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
home-manager
|
home-manager
|
||||||
#neovim-ide
|
|
||||||
];
|
];
|
||||||
sessionVariables = {
|
|
||||||
MANPAGER = "sh -c 'col -bx | bat -l man -p'";
|
|
||||||
MANROFFOPT = "-c";
|
|
||||||
};
|
|
||||||
shellAliases = {
|
|
||||||
cat = "bat";
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./shell
|
./shell
|
||||||
./neovim.nix
|
./neovim-ide.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
programs = {
|
programs = {
|
||||||
bat.enable = true;
|
neovim-ide.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
services = {
|
services = {
|
||||||
ssh-agent.enable = true;
|
ssh-agent.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
home = {
|
|
||||||
};
|
|
||||||
|
|
||||||
home.stateVersion = "23.05";
|
home.stateVersion = "23.05";
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,10 @@
|
||||||
|
{ pkgs, config, lib, ... }: {
|
||||||
|
options = {
|
||||||
|
programs.neovim-ide.enable = lib.mkEnableOption "neovim-ide";
|
||||||
|
};
|
||||||
|
config = lib.mkIf config.programs.neovim-ide.enable {
|
||||||
|
home = {
|
||||||
|
packages = with pkgs; [ neovim-ide ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
{ pkgs, ... }: {
|
|
||||||
home = {
|
|
||||||
packages = with pkgs; [ neovim-ide ];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -0,0 +1,14 @@
|
||||||
|
{ config, lib, pkgs, ... }: lib.mkIf config.programs.bat.enable {
|
||||||
|
home = {
|
||||||
|
packages = with pkgs; [
|
||||||
|
bat
|
||||||
|
];
|
||||||
|
sessionVariables = {
|
||||||
|
MANPAGER = "sh -c 'col -bx | bat -l man -p'";
|
||||||
|
MANROFFOPT = "-c";
|
||||||
|
};
|
||||||
|
shellAliases = {
|
||||||
|
cat = "bat";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
_: {
|
{ config, lib, ... }: lib.mkIf config.programs.btop.enable {
|
||||||
programs.btop = {
|
programs.btop = {
|
||||||
enable = true;
|
|
||||||
settings = {
|
settings = {
|
||||||
color_theme = "Default";
|
color_theme = "Default";
|
||||||
theme_background = false;
|
theme_background = false;
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
_: {
|
{ lib, ... }: with lib; {
|
||||||
imports = [
|
imports = [
|
||||||
./direnv.nix
|
./direnv.nix
|
||||||
./fzf.nix
|
./fzf.nix
|
||||||
|
|
@ -11,5 +11,21 @@ _: {
|
||||||
./btop.nix
|
./btop.nix
|
||||||
./zoxide.nix
|
./zoxide.nix
|
||||||
./ssh.nix
|
./ssh.nix
|
||||||
|
./bat.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
programs = {
|
||||||
|
bat.enable = mkDefault true;
|
||||||
|
btop.enable = mkDefault true;
|
||||||
|
direnv.enable = mkDefault true;
|
||||||
|
fzf.enable = mkDefault true;
|
||||||
|
git.enable = mkDefault true;
|
||||||
|
lf.enable = mkDefault true;
|
||||||
|
lsd.enable = mkDefault true;
|
||||||
|
ssh.enable = mkDefault true;
|
||||||
|
starship.enable = mkDefault true;
|
||||||
|
tmux.enable = mkDefault true;
|
||||||
|
zoxide.enable = mkDefault true;
|
||||||
|
zsh.enable = mkDefault true;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,6 @@
|
||||||
{ pkgs, ... }: {
|
{ pkgs, lib, config, ... }: lib.mkIf config.programs.direnv.enable {
|
||||||
programs.direnv = {
|
programs.direnv = {
|
||||||
enable = true;
|
|
||||||
enableZshIntegration = true;
|
enableZshIntegration = true;
|
||||||
enableBashIntegration = true;
|
|
||||||
config = {
|
config = {
|
||||||
global = {
|
global = {
|
||||||
disable_stdin = true;
|
disable_stdin = true;
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
_: {
|
{ config, lib, ... }: lib.mkIf config.programs.fzf.enable {
|
||||||
programs = {
|
programs = {
|
||||||
fzf = {
|
fzf = {
|
||||||
enable = true;
|
|
||||||
enableZshIntegration = true;
|
enableZshIntegration = true;
|
||||||
defaultCommand = "fd --type f";
|
defaultCommand = "fd --type f";
|
||||||
defaultOptions = [
|
defaultOptions = [
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,13 @@
|
||||||
{
|
{ config
|
||||||
config,
|
, pkgs
|
||||||
pkgs,
|
, lib
|
||||||
...
|
, ...
|
||||||
}: {
|
}: lib.mkIf config.programs.git.enable {
|
||||||
home = {
|
home = {
|
||||||
packages = with pkgs; [ pre-commit ];
|
packages = with pkgs; [ pre-commit ];
|
||||||
};
|
};
|
||||||
programs = {
|
programs = {
|
||||||
git = {
|
git = {
|
||||||
enable = true;
|
|
||||||
userName = "Patrick Neff";
|
userName = "Patrick Neff";
|
||||||
userEmail = "odie86@gmail.com";
|
userEmail = "odie86@gmail.com";
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
{pkgs, ...}: {
|
{ pkgs, config, lib, ... }: lib.mkIf config.programs.lf.enable {
|
||||||
home = {
|
home = {
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
chafa
|
chafa
|
||||||
|
|
@ -14,7 +14,6 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
programs.lf = {
|
programs.lf = {
|
||||||
enable = true;
|
|
||||||
commands = {
|
commands = {
|
||||||
get-mime-type = "%xdg-mime query filetype \"$f\"";
|
get-mime-type = "%xdg-mime query filetype \"$f\"";
|
||||||
open = ''
|
open = ''
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
_: {
|
{lib, config, ...}: lib.mkIf config.programs.lsd.enable {
|
||||||
programs = {
|
programs = {
|
||||||
lsd = {
|
lsd = {
|
||||||
enable = true;
|
|
||||||
enableAliases = true;
|
enableAliases = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,7 @@
|
||||||
{ pkgs, ... }: {
|
{ pkgs, config, lib, ... }: lib.mkIf config.programs.ssh.enable {
|
||||||
home.packages = with pkgs; [ tea ];
|
home.packages = with pkgs; [ tea ];
|
||||||
programs = {
|
programs = {
|
||||||
ssh = {
|
ssh = {
|
||||||
enable = true;
|
|
||||||
addKeysToAgent = "yes";
|
addKeysToAgent = "yes";
|
||||||
forwardAgent = true;
|
forwardAgent = true;
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,7 @@
|
||||||
{ lib, ... }:
|
{ lib, config, ... }:
|
||||||
{
|
lib.mkIf config.programs.starship.enable {
|
||||||
programs = {
|
programs = {
|
||||||
starship = {
|
starship = {
|
||||||
enable = true;
|
|
||||||
enableZshIntegration = true;
|
enableZshIntegration = true;
|
||||||
settings = {
|
settings = {
|
||||||
add_newline = false;
|
add_newline = false;
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
let
|
let
|
||||||
localLib = pkgs.callPackage ../../lib { };
|
localLib = pkgs.callPackage ../../lib { };
|
||||||
catppuccin = pkgs.callPackage ../../pkgs/tmuxPlugins/catppuccin.nix {
|
catppuccin = pkgs.callPackage ../../pkgs/tmuxPlugins/catppuccin.nix {
|
||||||
|
|
@ -6,8 +6,11 @@ let
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
programs.tmux = {
|
options = {
|
||||||
enable = true;
|
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
programs.tmux = lib.mkIf config.programs.tmux.enable {
|
||||||
newSession = true;
|
newSession = true;
|
||||||
mouse = true;
|
mouse = true;
|
||||||
keyMode = "vi";
|
keyMode = "vi";
|
||||||
|
|
@ -63,15 +66,15 @@ in
|
||||||
|
|
||||||
is_vim="ps -o state= -o comm= -t '#{pane_tty}' | grep -iqE '^[^TXZ ]+ +(\\S+\\/)?g?\.?(view|n?vim?x?)(-wrapped)?(diff)?$'"
|
is_vim="ps -o state= -o comm= -t '#{pane_tty}' | grep -iqE '^[^TXZ ]+ +(\\S+\\/)?g?\.?(view|n?vim?x?)(-wrapped)?(diff)?$'"
|
||||||
|
|
||||||
bind-key -n 'C-h' if-shell "$is_vim" 'send-keys C-h' { if -F '#{pane_at_left}' "" 'select-pane -L' }
|
bind-key -n 'C-h' if-shell "$is_vim" 'send-keys C-h' 'select-pane -L'
|
||||||
bind-key -n 'C-j' if-shell "$is_vim" 'send-keys C-j' { if -F '#{pane_at_bottom}' "" 'select-pane -D' }
|
bind-key -n 'C-j' if-shell "$is_vim" 'send-keys C-j' 'select-pane -D'
|
||||||
bind-key -n 'C-k' if-shell "$is_vim" 'send-keys C-k' { if -F '#{pane_at_top}' "" 'select-pane -U' }
|
bind-key -n 'C-k' if-shell "$is_vim" 'send-keys C-k' 'select-pane -U'
|
||||||
bind-key -n 'C-l' if-shell "$is_vim" 'send-keys C-l' { if -F '#{pane_at_right}' "" 'select-pane -R' }
|
bind-key -n 'C-l' if-shell "$is_vim" 'send-keys C-l' 'select-pane -R'
|
||||||
|
|
||||||
bind-key -T copy-mode-vi 'C-h' if -F '#{pane_at_left}' "" 'select-pane -L'
|
bind-key -T copy-mode-vi 'C-h' 'select-pane -L'
|
||||||
bind-key -T copy-mode-vi 'C-j' if -F '#{pane_at_bottom}' "" 'select-pane -D'
|
bind-key -T copy-mode-vi 'C-j' 'select-pane -D'
|
||||||
bind-key -T copy-mode-vi 'C-k' if -F '#{pane_at_top}' "" 'select-pane -U'
|
bind-key -T copy-mode-vi 'C-k' 'select-pane -U'
|
||||||
bind-key -T copy-mode-vi 'C-l' if -F '#{pane_at_right}' "" 'select-pane -R'
|
bind-key -T copy-mode-vi 'C-l' 'select-pane -R'
|
||||||
|
|
||||||
bind -n 'M-h' if-shell "$is_vim" 'send-keys M-h' 'resize-pane -L 1'
|
bind -n 'M-h' if-shell "$is_vim" 'send-keys M-h' 'resize-pane -L 1'
|
||||||
bind -n 'M-j' if-shell "$is_vim" 'send-keys M-j' 'resize-pane -D 1'
|
bind -n 'M-j' if-shell "$is_vim" 'send-keys M-j' 'resize-pane -D 1'
|
||||||
|
|
@ -84,4 +87,5 @@ in
|
||||||
bind-key -T copy-mode-vi M-l resize-pane -R 1
|
bind-key -T copy-mode-vi M-l resize-pane -R 1
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
_: {
|
{ config, lib, ... }: lib.mkIf config.programs.zoxide.enable {
|
||||||
programs = {
|
programs = {
|
||||||
zoxide = {
|
zoxide = {
|
||||||
enable = true;
|
|
||||||
enableZshIntegration = true;
|
enableZshIntegration = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
{ config, ... }: {
|
{ config, lib, ... }: lib.mkIf config.programs.zsh.enable {
|
||||||
programs = {
|
programs = {
|
||||||
zsh = {
|
zsh = {
|
||||||
enable = true;
|
|
||||||
defaultKeymap = "emacs";
|
defaultKeymap = "emacs";
|
||||||
dotDir = ".config/zsh";
|
dotDir = ".config/zsh";
|
||||||
shellAliases = {
|
shellAliases = {
|
||||||
|
|
|
||||||
Reference in New Issue