Compare commits

...

40 Commits

Author SHA1 Message Date
Armel van Ravels
3631f7887e Add image support to nvim 2026-03-16 10:47:45 +01:00
a7898aadcb Add ripgrep and drop annoying postman 2026-03-13 13:27:49 +01:00
Armel van Ravels
19184a2fe1 Update flake.lock 2026-03-12 08:58:37 +01:00
17040c195e Merge pull request 'Add postman' (#41) from feature/postman into master
Reviewed-on: #41
2026-03-09 14:29:51 +01:00
Armel van Ravels
56f668131a Add postman 2026-03-09 14:28:41 +01:00
da33f01ee8 Remove zsh banner as it is annoying 2026-02-11 22:36:07 +01:00
bf310bf40d Enable intelephense 2026-02-11 22:33:58 +01:00
a4868a8ab8 Add lualine with git branch 2026-02-11 14:17:10 +01:00
95ceb82f0f Add neo-tree to nvim 2026-02-11 13:21:13 +01:00
808e150bc6 Merge pull request 'Add nvim' (#33) from feature/neovim into master
Reviewed-on: #33
2026-02-11 12:22:32 +01:00
f440300cea Add nvim 2026-02-11 12:21:51 +01:00
0d7a1b06e8 Add file browser 2026-02-11 10:22:06 +01:00
eaf7043af3 Merge pull request 'master > home' (#35) from master into home
Reviewed-on: #35
2026-02-07 11:39:18 +01:00
29fc5d439a Merge pull request 'Add libre office' (#34) from feature/libreoffice into master
Reviewed-on: #34
2026-02-07 11:38:52 +01:00
5079c03620 Add libre office 2026-02-07 11:38:04 +01:00
c7a7277b15 Set home e-mail address 2026-02-05 20:32:41 +01:00
Armel van Ravels
9a01791c95 Remove git prune alias but keep git config 2026-02-05 17:17:05 +01:00
Armel van Ravels
eb1c9e9fb4 Real git prune alias 2026-02-05 17:04:50 +01:00
bc9dfc098e Merge pull request 'add git-prune alias' (#32) from feature/zsh-gitprune-alias into master
Reviewed-on: #32
2026-02-05 14:48:19 +01:00
fd5e8f39da add git-prune alias 2026-02-05 14:45:41 +01:00
5eba1e82d2 Add speedcrunch 2026-02-03 10:10:38 +01:00
7ca09caddd Show hide waybar 2026-02-02 16:28:54 +01:00
1577f066b2 fastfetch config for zsh init 2026-02-01 21:54:16 +01:00
1a5b256f23 No logo fastfetch 2026-01-31 22:45:25 +01:00
4385000181 Merge pull request 'Add fastfetch as motd of zsh' (#31) from feature/fastfetch-motd into master
Reviewed-on: #31
2026-01-31 22:40:42 +01:00
2cad286227 Add fastfetch as motd of zsh 2026-01-31 22:39:43 +01:00
77d4a53df2 Add direnv config 2026-01-30 17:22:19 +01:00
e8d58b71d6 Merge pull request 'Set compact dark theme in firefox' (#30) from feature/firefox-theme into master
Reviewed-on: #30
2026-01-30 10:41:49 +01:00
591068d563 Set compact dark theme in firefox 2026-01-30 10:40:14 +01:00
9b0fca4ca9 Add next/prev media keys 2026-01-30 08:42:23 +01:00
685f71825a Merge pull request 'OBS does not belong in home-manager' (#29) from chore/drop-obs into master
Reviewed-on: #29
2026-01-29 21:32:09 +01:00
5e05329302 OBS does not belong in home-manager 2026-01-29 21:31:50 +01:00
bfdc46add8 Merge pull request 'Add media button keybindings' (#28) from feature/media-buttons into master
Reviewed-on: #28
2026-01-29 21:23:50 +01:00
e742d73bdb Add media button keybindings 2026-01-29 21:23:26 +01:00
55e78f1803 Merge pull request 'Add volume icon to waybar' (#27) from feature/volume-waybar into master
Reviewed-on: #27
2026-01-29 21:10:20 +01:00
27a70d70eb Add volume icon to waybar 2026-01-29 21:09:49 +01:00
4e4590786a Merge pull request 'Fix ssh with kitty' (#26) from bugfix/kitten-ssh into master
Reviewed-on: #26
2026-01-27 16:22:32 +01:00
Armel van Ravels
3b74603a75 Fix ssh with kitty 2026-01-27 16:20:54 +01:00
902cde2e00 Merge pull request 'Add obs studio' (#25) from feature/obs into master
Reviewed-on: #25
2026-01-26 20:28:19 +01:00
319d08982e Add obs studio 2026-01-26 20:28:02 +01:00
14 changed files with 279 additions and 10 deletions

12
flake.lock generated
View File

@@ -7,11 +7,11 @@
]
},
"locked": {
"lastModified": 1767910483,
"narHash": "sha256-MOU5YdVu4DVwuT5ztXgQpPuRRBjSjUGIdUzOQr9iQOY=",
"lastModified": 1773264488,
"narHash": "sha256-rK0507bDuWBrZo+0zts9bCs/+RRUEHuvFE5DHWPxX/Q=",
"owner": "nix-community",
"repo": "home-manager",
"rev": "82fb7dedaad83e5e279127a38ef410bcfac6d77c",
"rev": "5c0f63f8d55040a7eed69df7e3fcdd15dfb5a04c",
"type": "github"
},
"original": {
@@ -23,11 +23,11 @@
},
"nixpkgs": {
"locked": {
"lastModified": 1767799921,
"narHash": "sha256-r4GVX+FToWVE2My8VVZH4V0pTIpnu2ZE8/Z4uxGEMBE=",
"lastModified": 1773068389,
"narHash": "sha256-vMrm7Pk2hjBRPnCSjhq1pH0bg350Z+pXhqZ9ICiqqCs=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "d351d0653aeb7877273920cd3e823994e7579b0b",
"rev": "44bae273f9f82d480273bab26f5c50de3724f52f",
"type": "github"
},
"original": {

View File

@@ -15,6 +15,10 @@
./programs/direnv.nix
./programs/firefox.nix
./programs/tmux.nix
./programs/git.nix
./programs/libreoffice.nix
./programs/nvim.nix
./programs/ripgrep.nix
./wm/rofi.nix
./wm/cursor.nix
./wm/dconf.nix

View File

@@ -6,8 +6,8 @@
enableZshIntegration = true;
nix-direnv.enable = true;
};
home.sessionVariables = {
DIRENV_CACHE = "${config.home.homeDirectory}/.cache/direnv";
home.file.".config/direnv/direnvrc" = {
source = ./direnv/direnvrc;
};
}

15
programs/direnv/direnvrc Normal file
View File

@@ -0,0 +1,15 @@
# Place in ~/.config/direnv/direnvrc
# Two things to know:
# * `direnv_layour_dir` is called once for every {.direnvrc,.envrc} sourced
# * The indicator for a different direnv file being sourced is a different $PWD value
# This means we can hash $PWD to get a fully unique cache path for any given environment
: ${XDG_CACHE_HOME:=$HOME/.cache}
declare -A direnv_layout_dirs
direnv_layout_dir() {
echo "${direnv_layout_dirs[$PWD]:=$(
echo -n "$XDG_CACHE_HOME"/direnv/layouts/
echo -n "$PWD" | sha1sum | cut -d ' ' -f 1
)}"
}

View File

@@ -0,0 +1,12 @@
{
"$schema": "https://github.com/fastfetch-cli/fastfetch/raw/master/doc/json_schema.json",
"modules": [
"os",
"uptime",
"cpu",
"gpu",
"memory",
"swap",
"disk",
]
}

View File

@@ -4,6 +4,12 @@
programs.firefox = {
enable = true;
profiles.default = {
settings = {
"extensions.activeThemeID" = "firefox-compact-dark@mozilla.org";
};
};
policies = {
# From https://discourse.nixos.org/t/declare-firefox-extensions-and-settings/36265/17
ExtensionSettings = with builtins;

11
programs/git.nix Normal file
View File

@@ -0,0 +1,11 @@
{ pkgs, ... } :
{
programs.git = {
enable = true;
settings.user = {
name = "Armel van Ravels";
email = "armel@armel.nl";
};
};
}

11
programs/libreoffice.nix Normal file
View File

@@ -0,0 +1,11 @@
{ pkgs, ... }:
{
home.packages = with pkgs; [
libreoffice
hunspell
hunspellDicts.en_US
hunspellDicts.nl_NL
];
}

158
programs/nvim.nix Normal file
View File

@@ -0,0 +1,158 @@
{ pkgs, ... }:
{
programs.neovim = {
enable = true;
extraLuaPackages = ps: [ ps.magick ];
extraPackages = [
pkgs.ueberzugpp
pkgs.imagemagick
];
plugins = with pkgs.vimPlugins; [
neo-tree-nvim
catppuccin-nvim
tokyonight-nvim
nvim-lspconfig
nvim-cmp
cmp-nvim-lsp
cmp-buffer
cmp-path
plenary-nvim
telescope-nvim
(nvim-treesitter.withAllGrammars)
vim-nix
lualine-nvim
image-nvim
];
extraLuaConfig = ''
vim.cmd("colorscheme catppuccin-mocha")
-- Basic settings
vim.o.number = true
vim.o.relativenumber = true
-- =========================
-- LSP (Neovim 0.11+ way)
-- =========================
-- Add cmp capabilities
local capabilities = require("cmp_nvim_lsp").default_capabilities()
vim.lsp.config("nil_ls", {
capabilities = capabilities,
})
-- PHP LSP
vim.lsp.config("intelephense", {
capabilities = capabilities,
})
vim.lsp.enable("intelephense")
vim.lsp.enable("nil_ls")
-- =========================
-- nvim-cmp
-- =========================
local cmp = require("cmp")
cmp.setup({
mapping = cmp.mapping.preset.insert({
["<C-Space>"] = cmp.mapping.complete(),
["<CR>"] = cmp.mapping.confirm({ select = true }),
}),
sources = {
{ name = "nvim_lsp" },
{ name = "buffer" },
{ name = "path" },
}
})
-- =========================
-- Telescope
-- =========================
local builtin = require("telescope.builtin")
vim.keymap.set("n", "<leader>ff", builtin.find_files, {})
vim.keymap.set("n", "<leader>fg", builtin.live_grep, {})
-- =========================
-- Lualine (status line with Git branch)
-- =========================
require('lualine').setup {
options = {
theme = 'catppuccin', -- match your colorscheme
section_separators = {'', ''},
component_separators = {'', ''},
},
sections = {
lualine_a = {'mode'},
lualine_b = {'branch'}, -- shows Git branch here
lualine_c = {'filename'},
lualine_x = {'encoding', 'fileformat', 'filetype'},
lualine_y = {'progress'},
lualine_z = {'location'}
}
}
-- =========================
-- image-nvim
-- =========================
require("image").setup({
backend = "ueberzug", -- or "ueberzug" or "sixel"
processor = "magick_cli", -- or "magick_rock"
integrations = {
markdown = {
enabled = true,
clear_in_insert_mode = false,
download_remote_images = true,
only_render_image_at_cursor = false,
only_render_image_at_cursor_mode = "popup", -- or "inline"
floating_windows = false, -- if true, images will be rendered in floating markdown windows
filetypes = { "markdown", "vimwiki" }, -- markdown extensions (ie. quarto) can go here
},
asciidoc = {
enabled = true,
clear_in_insert_mode = false,
download_remote_images = true,
only_render_image_at_cursor = false,
only_render_image_at_cursor_mode = "popup",
floating_windows = false,
filetypes = { "asciidoc", "adoc" },
},
neorg = {
enabled = true,
filetypes = { "norg" },
},
rst = {
enabled = true,
},
typst = {
enabled = true,
filetypes = { "typst" },
},
html = {
enabled = false,
},
css = {
enabled = false,
},
},
max_width = nil,
max_height = nil,
max_width_window_percentage = nil,
max_height_window_percentage = 50,
scale_factor = 1.0,
window_overlap_clear_enabled = false, -- toggles images when windows are overlapped
window_overlap_clear_ft_ignore = { "cmp_menu", "cmp_docs", "snacks_notif", "scrollview", "scrollview_sign" },
editor_only_render_when_focused = false, -- auto show/hide images when the editor gains/looses focus
tmux_show_only_in_active_window = false, -- auto show/hide images in the correct Tmux window (needs visual-activity off)
hijack_file_patterns = { "*.png", "*.jpg", "*.jpeg", "*.gif", "*.webp", "*.avif" }, -- render image files as images when opened
})
'';
};
}

8
programs/ripgrep.nix Normal file
View File

@@ -0,0 +1,8 @@
{ pkgs, ... }:
{
home.packages = with pkgs; [
ripgrep
];
}

View File

@@ -1,11 +1,19 @@
{ pkgs, ... }:
{
home.file.".zsh/fastfetch.jsonc".source =
./fastfetch/config.jsonc;
programs.zsh = {
enable = true;
oh-my-zsh = {
enable = true;
theme = "agnoster";
};
initContent = ''
# Use kitty's ssh helper if running inside kitty
[ "$TERM" = "xterm-kitty" ] && alias ssh="kitty +kitten ssh"
'';
};
}

View File

@@ -5,6 +5,8 @@
bzmenu
hyprshot
hyprlock
playerctl
speedcrunch
];
wayland.windowManager.hyprland = {
@@ -21,6 +23,7 @@
"$terminal" = "kitty";
"$menu" = "rofi -show drun";
"$bluetoothMenu" = "bzmenu --launcher rofi";
"$files" = "rofi -show filebrowser";
### BASIC LAYOUT
general = {
@@ -75,11 +78,15 @@
"$mod, RETURN, exec, $terminal"
"$mod, D, exec, $menu"
"$mod, B, exec, $bluetoothMenu"
"$mod, G, exec, $files"
"$mod, Q, killactive"
"$mod, F, fullscreen"
"$mod, M, exit"
"$mod, L, exec, hyprlock"
# show/hide waybar
"$mod, W, exec, pkill -SIGUSR1 -f '^waybar$'"
# Focus
"$mod, LEFT, movefocus, l"
"$mod, RIGHT, movefocus, r"
@@ -115,6 +122,16 @@
# Hyprshot
"$mod, Z, exec, hyprshot -m region"
# Media keys
", XF86AudioPlay, exec, playerctl play-pause"
", XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"
", XF86AudioRaiseVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+"
", XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"
", XF86AudioNext, exec, playerctl next"
", XF86AudioPrev, exec, playerctl previous"
", XF86Calculator, exec, speedcrunch"
];
bindm = [

View File

@@ -1,6 +1,10 @@
{ pkgs, ... }:
{
home.packages = [
pkgs.rofi-file-browser
];
programs.rofi = {
enable = true;
theme = "material";

View File

@@ -21,11 +21,26 @@
];
modules-right = [
"pulseaudio"
"cpu"
"tray"
"clock"
];
pulseaudio = {
format = "{icon} {volume}%";
format-muted = "󰝟 muted";
tooltip = false;
scroll-step = 5;
format-icons = {
default = [ "󰕿" "󰖀" "󰕾" ];
};
on-click = "wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle";
};
mpris = {
player = "spotify";
format = "{player_icon} {artist} - {title}";
@@ -35,7 +50,7 @@
};
cpu = {
format = "{usage}% ";
format = " {usage}%";
tooltip = false;
};