-
Notifications
You must be signed in to change notification settings - Fork 0
/
home.nix
323 lines (292 loc) · 8.62 KB
/
home.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
{
config,
pkgs,
inputs,
...
}: {
# Home Manager needs a bit of information about you and the
# paths it should manage.
home.username = "user";
home.homeDirectory = "/home/user";
programs.home-manager.enable = true;
#imports = [
# inputs.nixvim.homeManagerModules.nixvim
#];
# This value determines the Home Manager release that your
# configuration is compatible with. This helps avoid breakage
# when a new Home Manager release introduces backwards
# incompatible changes.
#
# You should not change this value, even if you update Home Manager. If you do
# want to update the value, then make sure to first check the Home Manager
# release notes.
home.stateVersion = "22.11"; # Please read the comment before changing.
# Allow non-free packages
nixpkgs.config.allowUnfree = true;
nixpkgs.config.joypixels.acceptLicense = true;
# Manage session variables
home.sessionVariables = {
# default editor
EDITOR = "nvim";
NIXPKGS_ALLOW_UNFREE = 1;
# sshaskpass
SSH_ASKPASS = "/home/user/.nix-profile/bin/ksshaskpass";
SSH_ASKPASS_REQUIRE = "prefer";
# Store git credentials in KDE Wallet
GIT_ASKPASS = "/home/user/.nix-profile/bin/ksshaskpass";
};
# The home.packages option allows you to install Nix packages into your
# environment.
home.packages = with pkgs; [
# # Adds the 'hello' command to your environment. It prints a friendly
# # "Hello, world!" when run.
# pkgs.hello
# # It is sometimes useful to fine-tune packages, for example, by applying
# # overrides. You can do that directly here, just don't forget the
# # parentheses. Maybe you want to install Nerd Fonts with a limited number of
# # fonts?
# (pkgs.nerdfonts.override { fonts = [ "FantasqueSansMono" ]; })
# # You can also create simple shell scripts directly inside your
# # configuration. For example, this adds a command 'my-hello' to your
# # environment:
# (pkgs.writeShellScriptBin "my-hello" ''
# echo "Hello, ${config.home.username}!"
# '')
xsel
wget
neofetch
htop
oh-my-zsh
git
chromium
plasma5Packages.qtstyleplugin-kvantum
kdeconnect
microsoft-edge
vivaldi
vivaldi-ffmpeg-codecs
x264
joypixels
rustc
cargo
unzip
ocs-url
nextcloud-client
duf
foliate
mpv
obsidian
dino
aria2
bitwarden
kitty-themes
p7zip
tdesktop
libreoffice-fresh
jetbrains-mono
yakuake
krita
filelight
inkscape
yt-dlp
ranger
libsForQt5.kwallet
libsForQt5.kwallet-pam
libsForQt5.kwalletmanager
libsForQt5.ksshaskpass
cachix
direnv
git-lfs
nix-direnv
zathura
starship
gnome.gnome-tweaks
gnome-extension-manager
ripgrep
inputs.nv.packages.x86_64-linux.default
inputs.nyaa.packages.x86_64-linux.default
];
nixpkgs.config.permittedInsecurePackages = [
"electron-25.9.0"
];
programs.bash = {
enable = false;
bashrcExtra = ''
. ~/.bashrc
eval "$(direnv hook bash)"
eval "$(starship init bash)"
'';
};
programs.zsh = {
enable = true;
enableCompletion = true;
autosuggestion.enable = true;
syntaxHighlighting.enable = true;
# enableBashCompletion = true;
oh-my-zsh = {
enable = true;
theme = "ys";
plugins = ["git" "colored-man-pages" "extract" "sudo"];
};
initExtra = ''
eval "$(direnv hook zsh)"
eval "$(starship init zsh)"
alias vv=nvim
alias yt-dlp-1080="yt-dlp -f 'bestvideo[height<=1080]+bestaudio/best[height<=1080]'"
'';
};
programs.kitty = {
enable = true;
keybindings = {
# Create a new window splitting the space used by the existing one so that
# the two windows are placed one above the other
"f5" = "launch --location=hsplit";
# Create a new window splitting the space used by the existing one so that
# the two windows are placed side by side
"f6" = "launch --location=vsplit";
# Create a new window splitting the space used by the existing one so that
# the two windows aew placed side by side if the existing window is wide or
# one above the other if the existing window is tall
"f4" = "launch --location=split";
# Rotate the current split, changing its split axis from vertical to
# horizontal or vice versa
"f7" = "layout_action rotate";
# Move the active window in the indicated direction
"shift+up" = "move_window up";
"shift+left" = "move_window left";
"shift+right" = "move_window right";
"shift+down" = "move_window down";
# Move the window to the indicated screen edge
"ctrl+shift+up" = "layout_action move_to_screen_edge top";
"ctrl+shift+left" = "layout_action move_to_screen_edge left";
"ctrl+shift+right" = "layout_action move_to_screen_edge right";
"ctrl+shift+down" = "layout_action move_to_screen_edge bottom";
# Switch focus to the neighboring window in the indicated direction
"ctrl+left" = "neighboring_window left";
"ctrl+right" = "neighboring_window right";
"ctrl+up" = "neighboring_window up";
"ctrl+down" = "neighboring_window down";
};
extraConfig = "include ~/.config/kitty/current-theme.conf
font_family JetBrainsMono Nerd Font
bold_font JetBrainsMono NF Bold
italic_font JetBrainsMono NF Italic
bold_italic_font JetBrainsMono NF Bold Italic
wayland_titlebar_color system
hide_window_decorations no
linux_display_server x11
enabled_layouts splits
confirm_os_window_close 0
";
};
programs.tmux = {
enable = true;
mouse = true;
plugins = with pkgs.tmuxPlugins; [
better-mouse-mode
#dracula
#gruvbox
#nord
#onedark-theme
#power-theme
resurrect
#tmux-colors-solarized
tmux-fzf
];
extraConfig = ''
set-option -g mouse on
set -g default-terminal "screen-256color"
'';
};
#programs.nixvim = import ./nixvim.nix pkgs;
programs.neovim = {
enable = false;
defaultEditor = true;
# coc.enable = true;
# extraLuaConfig = ''
# for _, source in ipairs {
# "astronvim.bootstrap",
# "astronvim.options",
# "astronvim.lazy",
# "astronvim.autocmds",
# "astronvim.mappings",
# } do
# local status_ok, fault = pcall(require, source)
# if not status_ok then vim.api.nvim_err_writeln("Failed to load " .. source .. "\n\n" .. fault
# ) end
# end
#
# if astronvim.default_colorscheme then
# if not pcall(vim.cmd.colorscheme, astronvim.default_colorscheme) then
# requrie("astronvim.utils").notify(
# "Error setting up colorscheme: " .. astronvim.default_colorscheme,
# vim.log.levels.ERROR
# )
# end
# end
#
# require("astronvim.utils").conditional_func(astronvim.user_opts("polish", nil, false), true)
# '';
#
# plugins = (with pkgs.vimPlugins; [
# rust-vim
# rust-tools-nvim
# coc-rust-analyzer
# nvim-treesitter-parsers.rust
# nvim-treesitter-parsers.cpp
# nvim-treesitter-parsers.c
# nvim-treesitter-parsers.latex
# coc-rls
# coc-clangd
# clangd_extensions-nvim
# vim-clang-format
# ]);
};
programs.vscode = {
enable = true;
extensions = with pkgs.vscode-extensions; [
arrterian.nix-env-selector
mkhl.direnv
jnoortheen.nix-ide
xaver.clang-format
llvm-vs-code-extensions.vscode-clangd
vadimcn.vscode-lldb
# ms-vscode.cpptools
colejcummins.llvm-syntax-highlighting
rust-lang.rust-analyzer
waderyan.gitblame
];
};
programs.bat = {
enable = true;
config = {
theme = "ansi";
};
};
services.mpris-proxy.enable = true;
# Home Manager is pretty good at managing dotfiles. The primary way to manage
# plain files is through 'home.file'.
#home.file = {
# # Building this configuration will create a copy of 'dotfiles/screenrc' in
# # the Nix store. Activating the configuration will then make '~/.screenrc' a
# # symlink to the Nix store copy.
# ".screenrc".source = dotfiles/screenrc;
# # You can also set the file content immediately.
# ".gradle/gradle.properties".text = ''
# org.gradle.console=verbose
# org.gradle.daemon.idletimeout=3600000
# '';
#};
home.file = {
".config/hypr".source = ./config/hypr;
};
# You can also manage environment variables but you will have to manually
# source
#
# ~/.nix-profile/etc/profile.d/hm-session-vars.sh
#
# or
#
# /etc/profiles/per-user/user/etc/profile.d/hm-session-vars.sh
#
# if you don't want to manage your shell through Home Manager.
}