split out pkg installs to respective files

This commit is contained in:
Noa Aarts 2024-03-01 13:46:10 +01:00
parent 10dfbc3234
commit 89dc32e96a
8 changed files with 155 additions and 202 deletions

View file

@ -1,7 +1,9 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
home.packages = with pkgs; [
git
];
programs.git = { programs.git = {
enable = true; enable = true;
userName = "Noa Aarts"; userName = "Noa Aarts";

View file

@ -1,6 +1,19 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
# these are necessary for the config to function correctly
imports = [
./kitty.nix
./waybar.nix
./wofi.nix
];
home.packages = with pkgs; [
hyprland
# I always want these with hyprland anyways
dunst
wl-clipboard
];
wayland.windowManager.hyprland = { wayland.windowManager.hyprland = {
enable = true; enable = true;
settings = { settings = {

14
common/kitty.nix Normal file
View file

@ -0,0 +1,14 @@
{ config, pkgs, inputs, ... }:
{
home.packages = with pkgs; [
kitty
];
programs.kitty = {
enable = true;
settings = {
confirm_os_window_close = 0;
};
shellIntegration.enableZshIntegration = true;
};
}

View file

@ -1,6 +1,9 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
home.packages = with pkgs; [
waybar
];
programs.waybar = { programs.waybar = {
enable = true; enable = true;
settings = { settings = {

View file

@ -1,6 +1,44 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
home.packages = with pkgs; [
(writeShellScriptBin "wofi-launch" ''
${wofi}/bin/wofi --show drun
'')
(writeShellScriptBin "wofi-power" ''
lock="Lock"
logout="Logout"
poweroff="Poweroff"
reboot="Reboot"
sleep="Suspend"
selected_option=$(echo -e "$lock\n$logout\n$sleep\n$reboot\n$poweroff" | wofi --dmenu -i -p "Powermenu")
if [ "$selected_option" == "$lock" ]
then
echo "lock"
swaylock
elif [ "$selected_option" == "$logout" ]
then
echo "logout"
loginctl terminate-user `whoami`
elif [ "$selected_option" == "$poweroff" ]
then
echo "poweroff"
poweroff
elif [ "$selected_option" == "$reboot" ]
then
echo "reboot"
reboot
elif [ "$selected_option" == "$sleep" ]
then
echo "sleep"
suspend
else
echo "No match"
fi
'')
];
programs.wofi = { programs.wofi = {
enable = true; enable = true;
settings = { settings = {

View file

@ -1,6 +1,9 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
home.packages = with pkgs; [
zsh
];
programs.zsh = { programs.zsh = {
enable=true; enable=true;
shellAliases = { shellAliases = {
@ -21,12 +24,4 @@
}; };
}; };
programs.kitty = {
enable = true;
settings = {
confirm_os_window_close = 0;
};
shellIntegration.enableZshIntegration = true;
};
} }

View file

@ -4,10 +4,8 @@
imports = imports =
[ [
inputs.nixvim.homeManagerModules.nixvim inputs.nixvim.homeManagerModules.nixvim
../../common/wofi.nix
../../common/zsh.nix ../../common/zsh.nix
../../common/hyprland.nix ../../common/hyprland.nix
../../common/waybar.nix
../../common/git.nix ../../common/git.nix
../../common/nvim/nvim.nix ../../common/nvim/nvim.nix
]; ];
@ -48,10 +46,6 @@
]; ];
}) })
hyprland
dunst
waybar
wl-clipboard
dconf dconf
(symlinkJoin { (symlinkJoin {
@ -66,45 +60,8 @@
discord discord
]; ];
}) })
kitty
pipewire pipewire
lsd lsd
(writeShellScriptBin "wofi-launch" ''
${wofi}/bin/wofi --show drun
'')
(writeShellScriptBin "wofi-power" ''
lock="Lock"
logout="Logout"
poweroff="Poweroff"
reboot="Reboot"
sleep="Suspend"
selected_option=$(echo -e "$lock\n$logout\n$sleep\n$reboot\n$poweroff" | wofi --dmenu -i -p "Powermenu")
if [ "$selected_option" == "$lock" ]
then
echo "lock"
swaylock
elif [ "$selected_option" == "$logout" ]
then
echo "logout"
loginctl terminate-user `whoami`
elif [ "$selected_option" == "$poweroff" ]
then
echo "poweroff"
poweroff
elif [ "$selected_option" == "$reboot" ]
then
echo "reboot"
reboot
elif [ "$selected_option" == "$sleep" ]
then
echo "sleep"
suspend
else
echo "No match"
fi
'')
# Programming langs # Programming langs
go go
@ -148,8 +105,10 @@
TERM = "kitty"; TERM = "kitty";
}; };
xdg.userDirs.enable = true; xdg.userDirs = {
xdg.userDirs.createDirectories = true; enable = true;
createDirectories = true;
};
dconf = { dconf = {
enable = true; enable = true;

View file

@ -1,10 +1,15 @@
{ config, pkgs, inputs, ... }: { config, pkgs, inputs, ... }:
{ {
imports = imports =
[ [
inputs.nixvim.homeManagerModules.nixvim inputs.nixvim.homeManagerModules.nixvim
../../common/wofi.nix
../../common/zsh.nix
../../common/hyprland.nix
../../common/waybar.nix
../../common/git.nix
../../common/nvim/nvim.nix
]; ];
# Home Manager needs a bit of information about you and the paths it should # Home Manager needs a bit of information about you and the paths it should
# manage. # manage.
@ -24,9 +29,19 @@
# The home.packages option allows you to install Nix packages into your # The home.packages option allows you to install Nix packages into your
# environment. # environment.
home.packages = [ home.packages = with pkgs; [
file
unzip
zip
dig
mtr
kitty
lsd
]; ];
# Home Manager is pretty good at managing dotfiles. The primary way to manage # Home Manager is pretty good at managing dotfiles. The primary way to manage
# plain files is through 'home.file'. # plain files is through 'home.file'.
home.file = { home.file = {
@ -65,101 +80,15 @@
xdg.userDirs.enable = true; xdg.userDirs.enable = true;
xdg.userDirs.createDirectories = true; xdg.userDirs.createDirectories = true;
dconf = {
enable = true;
settings = {
"org/gnome/desktop/interface" = {
color-scheme = "prefer-dark";
};
};
};
# Let Home Manager install and manage itself. # Let Home Manager install and manage itself.
programs.home-manager.enable = true; programs.home-manager.enable = true;
# TODO move to seperate file
programs.zsh = {
enable=true;
shellAliases = {
ll = "lsd -l";
update = "sudo nixos-rebuild switch --flake /etc/nixos#default";
};
history = {
path = "${config.xdg.dataHome}/zsh/history";
size = 10000;
};
oh-my-zsh = {
enable = true;
plugins = [ "git" ];
theme = "frisk";
};
};
# TODO extend and move to seperate file
programs.git = {
enable = true;
userName = "Noa Aarts";
userEmail = "itepastra@gmail.com";
extraConfig = {
init = { defaultBranch = "main"; };
};
};
# TODO move to seperate file
# TODO create neovim config
programs.nixvim = {
enable = true;
vimAlias = true;
# Configure neovim options...
options = {
relativenumber = true;
incsearch = true;
};
# ...mappings...
keymaps = [
{
mode = "n";
key = "<C-s>";
action = ":w<CR>";
}
{
mode = "n";
key = "<esc>";
action = ":noh<CR>";
options.silent = true;
}
{
mode = "v";
key = ">";
action = ">gv";
}
{
mode = "v";
key = "<";
action = "<gv";
}
];
plugins = {
lsp = {
keymaps = {
silent = true;
diagnostic = {
"<leader>k" = "goto_prev";
"<leader>j" = "goto_next";
};
lspBuf = {
gd = "definition";
K = "hover";
};
};
};
};
# ... and even highlights and autocommands !
highlight.ExtraWhitespace.bg = "red";
match.ExtraWhitespace = "\\s\\+$";
autoCmd = [
{
event = "FileType";
pattern = "nix";
command = "setlocal tabstop=2 shiftwidth=2";
}
];
};
} }