WIP
This commit is contained in:
parent
ac964dcee9
commit
9b0035c59a
4 changed files with 616 additions and 272 deletions
389
daniel.nix
389
daniel.nix
|
@ -1,4 +1,8 @@
|
||||||
{ pkgs, lib, ... }: {
|
{pkgs, lib, ...}: let
|
||||||
|
email = "daniel@lyte.dev";
|
||||||
|
name = "Daniel Flanagan";
|
||||||
|
in
|
||||||
|
{
|
||||||
# TODO: email access?
|
# TODO: email access?
|
||||||
# accounts.email.accounts = {
|
# accounts.email.accounts = {
|
||||||
# google = {
|
# google = {
|
||||||
|
@ -6,25 +10,357 @@
|
||||||
# };
|
# };
|
||||||
# };
|
# };
|
||||||
|
|
||||||
home.username = "daniel";
|
home = {
|
||||||
home.homeDirectory = lib.mkDefault "/home/daniel/.home";
|
username = "daniel";
|
||||||
home.stateVersion = "23.05";
|
homeDirectory = lib.mkDefault "/home/daniel/.home";
|
||||||
|
stateVersion = "23.05";
|
||||||
|
|
||||||
home.packages = [
|
packages = [
|
||||||
pkgs.rtx
|
# I use rtx for managing the following programs' versions instead of nix:
|
||||||
# I use this for managing the following programs' versions instead of nix:
|
|
||||||
# kubectl, aws
|
# kubectl, aws
|
||||||
|
pkgs.rtx
|
||||||
|
|
||||||
# TODO: os-specific scripts? macOS versus Linux (arch or nixos? do I need to distinguish at that point?)
|
# TODO: os-specific scripts? macOS versus Linux (arch or nixos? do I need to distinguish at that point?)
|
||||||
(pkgs.buildEnv { name = "my-scripts"; paths = [ ./scripts ]; })
|
(pkgs.buildEnv { name = "my-scripts"; paths = [ ./scripts ]; })
|
||||||
];
|
];
|
||||||
|
|
||||||
programs.password-store = {
|
file = {
|
||||||
|
".iex.exs" = {
|
||||||
|
enable = true;
|
||||||
|
text = ''
|
||||||
|
Application.put_env(:elixir, :ansi_enabled, true)
|
||||||
|
|
||||||
|
# PROTIP: to break, `#iex:break`
|
||||||
|
|
||||||
|
IEx.configure(
|
||||||
|
colors: [enabled: true],
|
||||||
|
inspect: [
|
||||||
|
pretty: true,
|
||||||
|
printable_limit: :infinity,
|
||||||
|
limit: :infinity
|
||||||
|
],
|
||||||
|
default_prompt:
|
||||||
|
[
|
||||||
|
# ANSI CHA, move cursor to column 1
|
||||||
|
"\e[G",
|
||||||
|
:magenta,
|
||||||
|
# IEx prompt variable
|
||||||
|
"%prefix",
|
||||||
|
"#",
|
||||||
|
# IEx prompt variable
|
||||||
|
"%counter",
|
||||||
|
# plain string
|
||||||
|
">",
|
||||||
|
:reset
|
||||||
|
]
|
||||||
|
|> IO.ANSI.format()
|
||||||
|
|> IO.chardata_to_string()
|
||||||
|
)
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
pointerCursor = {
|
||||||
|
name = "Catppuccin-Mocha-Sapphire-Cursors";
|
||||||
|
package = pkgs.catppuccin-cursors.mochaSapphire;
|
||||||
|
size = 64; # TODO: this doesn't seem to work -- at least in Sway
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
programs = {
|
||||||
|
password-store = {
|
||||||
enable = true;
|
enable = true;
|
||||||
package = (pkgs.pass.withExtensions (exts: [ exts.pass-otp ]));
|
package = (pkgs.pass.withExtensions (exts: [ exts.pass-otp ]));
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.zellij = {
|
git = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
userEmail = email;
|
||||||
|
userName = name;
|
||||||
|
|
||||||
|
delta = {
|
||||||
|
enable = true;
|
||||||
|
options = { };
|
||||||
|
};
|
||||||
|
|
||||||
|
lfs = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
signing = {
|
||||||
|
signByDefault = true;
|
||||||
|
key = "daniel@lyte.dev";
|
||||||
|
};
|
||||||
|
|
||||||
|
extraConfig = {
|
||||||
|
push = {
|
||||||
|
autoSetupRemote = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
branch = {
|
||||||
|
autoSeupMerge = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
sendemail = {
|
||||||
|
smtpserver = "smtp.mailgun.org";
|
||||||
|
smtpuser = "daniel@lyte.dev";
|
||||||
|
smtrpencryption = "tls";
|
||||||
|
smtpserverport = 587;
|
||||||
|
};
|
||||||
|
|
||||||
|
url = {
|
||||||
|
"git@git.hq.bill.com:" = {
|
||||||
|
insteadOf = "https://git.hq.bill.com";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
aliases = {
|
||||||
|
a = "add";
|
||||||
|
A = "add - A";
|
||||||
|
ac = "commit - a";
|
||||||
|
b = "rev-parse - -symbolic-full-name HEAD";
|
||||||
|
c = "commit";
|
||||||
|
cm = "commit - m";
|
||||||
|
cnv = "commit - -no-verify";
|
||||||
|
co = "checkoutd";
|
||||||
|
d = "diff";
|
||||||
|
ds = "diff - -staged";
|
||||||
|
dt = "difftool ";
|
||||||
|
f = "fetch";
|
||||||
|
l = "log - -graph - -abbrev-commit - -decorate - -oneline - -all";
|
||||||
|
plainlog = " log - -pretty=format:'%h %ad%x09%an%x09%s' --date=short --decorate";
|
||||||
|
ls = "ls-files";
|
||||||
|
mm = "merge master";
|
||||||
|
p = "push";
|
||||||
|
pf = "push --force-with-lease";
|
||||||
|
pl = "pull";
|
||||||
|
rim = "rebase -i master";
|
||||||
|
s = "status";
|
||||||
|
sur = "submodule update --remote";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
gitui = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
helix = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.helix;
|
||||||
|
languages = {
|
||||||
|
language-server = {
|
||||||
|
lexical = {
|
||||||
|
command = "lexical";
|
||||||
|
args = [ "start" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
language = [
|
||||||
|
{
|
||||||
|
name = "elixir";
|
||||||
|
language-servers = [ "elixir-ls" "lexical" ];
|
||||||
|
auto-format = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "html";
|
||||||
|
auto-format = false;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "nix";
|
||||||
|
auto-format = true;
|
||||||
|
formatter = {
|
||||||
|
command = "nixpkgs-fmt";
|
||||||
|
args = [ ];
|
||||||
|
};
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "fish";
|
||||||
|
auto-format = true;
|
||||||
|
indent = {
|
||||||
|
tab-width = 2;
|
||||||
|
unit = "\t";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
# TODO: deno:
|
||||||
|
#[[language]]
|
||||||
|
#name = "javascript"
|
||||||
|
#scope = "source.js"
|
||||||
|
#injection-regex = "^(js|javascript)$"
|
||||||
|
#file-types = [ "js", "jsx", "mjs" ]
|
||||||
|
#shebangs = [ "deno", "node" ]
|
||||||
|
#roots = [ "deno.jsonc", "deno.json", "package.json", "tsconfig.json" ]
|
||||||
|
#comment-token = "//"
|
||||||
|
# config = { enable = true, lint = true, unstable = true }
|
||||||
|
# language-server = { command = "typescript-language-server", args = ["--stdio"], language-id = "javascript" }
|
||||||
|
#indent = {
|
||||||
|
#tab-width = 2, unit = "\t" }
|
||||||
|
#auto-format = true
|
||||||
|
|
||||||
|
# [[language]]
|
||||||
|
# name = "jsx"
|
||||||
|
# scope = "source.jsx"
|
||||||
|
# injection-regex = "jsx"
|
||||||
|
# file-types = ["jsx"]
|
||||||
|
# shebangs = ["deno", "node"]
|
||||||
|
# roots = ["deno.jsonc", "deno.json", "package.json", "tsconfig.json"]
|
||||||
|
# comment-token = "//"
|
||||||
|
# config = { enable = true, lint = true, unstable = true }
|
||||||
|
# language-server = { command = "deno", args = ["lsp"], language-id = "javascriptreact" }
|
||||||
|
# indent = { tab-width = 2, unit = " " }
|
||||||
|
# grammar = "javascript"
|
||||||
|
# auto-format = true
|
||||||
|
|
||||||
|
# [[language]]
|
||||||
|
# name = "typescript"
|
||||||
|
# scope = "source.ts"
|
||||||
|
# injection-regex = "^(ts|typescript)$"
|
||||||
|
# file-types = ["ts"]
|
||||||
|
# shebangs = ["deno", "node"]
|
||||||
|
# roots = ["deno.jsonc", "deno.json", "package.json", "tsconfig.json"]
|
||||||
|
# config = { enable = true, lint = true, unstable = true }
|
||||||
|
# language-server = { command = "deno", args = ["lsp"], language-id = "typescript" }
|
||||||
|
# indent = { tab-width = 2, unit = " " }
|
||||||
|
# auto-format = true
|
||||||
|
|
||||||
|
# [[language]]
|
||||||
|
# name = "tsx"
|
||||||
|
# scope = "source.tsx"
|
||||||
|
# injection-regex = "^(tsx)$" # |typescript
|
||||||
|
# file-types = ["tsx"]
|
||||||
|
# shebangs = ["deno", "node"]
|
||||||
|
# roots = ["deno.jsonc", "deno.json", "package.json", "tsconfig.json"]
|
||||||
|
# config = { enable = true, lint = true, unstable = true }
|
||||||
|
# language-server = { command = "deno", args = ["lsp"], language-id = "typescriptreact" }
|
||||||
|
# indent = { tab-width = 2, unit = " " }
|
||||||
|
# auto-format = true
|
||||||
|
|
||||||
|
# [[language]]
|
||||||
|
# name = "jsonc"
|
||||||
|
# scope = "source.jsonc"
|
||||||
|
# injection-regex = "^(jsonc)$"
|
||||||
|
# file-types = ["jsonc"]
|
||||||
|
# shebangs = ["deno", "node"]
|
||||||
|
# roots = ["deno.jsonc", "deno.json", "package.json", "tsconfig.json"]
|
||||||
|
# config = { enable = true, lint = true, unstable = true }
|
||||||
|
# language-server = { command = "deno", args = ["lsp"], language-id = "jsonc" }
|
||||||
|
# indent = { tab-width = 2, unit = " " }
|
||||||
|
# auto-format = true
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
theme = "custom";
|
||||||
|
|
||||||
|
editor = {
|
||||||
|
soft-wrap.enable = true;
|
||||||
|
auto-pairs = false;
|
||||||
|
auto-save = false;
|
||||||
|
completion-trigger-len = 1;
|
||||||
|
color-modes = false;
|
||||||
|
bufferline = "multiple";
|
||||||
|
scrolloff = 8;
|
||||||
|
rulers = [80 120];
|
||||||
|
cursorline = true;
|
||||||
|
|
||||||
|
cursor-shape = {
|
||||||
|
normal = "block";
|
||||||
|
insert = "bar";
|
||||||
|
select = "underline";
|
||||||
|
};
|
||||||
|
|
||||||
|
file-picker.hidden = false;
|
||||||
|
indent-guides = {
|
||||||
|
render = true;
|
||||||
|
character = "▏";
|
||||||
|
};
|
||||||
|
|
||||||
|
lsp = {
|
||||||
|
display-messages = true;
|
||||||
|
display-inlay-hints = true;
|
||||||
|
};
|
||||||
|
statusline = {
|
||||||
|
left = ["mode" "spinner" "selections" "primary-selection-length" "position" "position-percentage" "diagnostics" "workspace-diagnostics"];
|
||||||
|
center = ["file-name"];
|
||||||
|
right = [ "version-control" "total-line-numbers" "file-encoding"];
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
keys = {
|
||||||
|
|
||||||
|
insert = {
|
||||||
|
j = { k = "normal_mode"; j = "normal_mode"; K = "normal_mode"; J = "normal_mode"; };
|
||||||
|
};
|
||||||
|
|
||||||
|
normal = {
|
||||||
|
D = "kill_to_line_end";
|
||||||
|
"^" = "goto_line_start";
|
||||||
|
"C-k" = "jump_view_up";
|
||||||
|
"C-j" = "jump_view_down";
|
||||||
|
"C-h" = "jump_view_left";
|
||||||
|
"C-l" = "jump_view_right";
|
||||||
|
"C-q" = ":quit-all!";
|
||||||
|
"L" = "repeat_last_motion";
|
||||||
|
space = {
|
||||||
|
q = ":reflow 80";
|
||||||
|
Q = ":reflow 120";
|
||||||
|
v = ":run-shell-command fish -c 'env > /tmp/env'";
|
||||||
|
C = ":bc!";
|
||||||
|
h = ":toggle lsp.display-inlay-hints";
|
||||||
|
# O = ["select_textobject_inner WORD", ":pipe-to xargs xdg-open"];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
select = {
|
||||||
|
space = { q = ":reflow 80"; Q = ":reflow 120"; };
|
||||||
|
"L" = "repeat_last_motion";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
themes = {
|
||||||
|
custom = {
|
||||||
|
"inherits" = "catppuccin_mocha";
|
||||||
|
|
||||||
|
"ui.background" = "default";
|
||||||
|
|
||||||
|
# "ui.cursorline.primary" = { bg = "default" }
|
||||||
|
# "ui.cursorline.secondary" = { bg = "default" }
|
||||||
|
# "ui.cursorcolumn.primary" = { bg = "default" }
|
||||||
|
# "ui.cursorcolumn.secondary" = { bg = "default" }
|
||||||
|
# "ui.virtual.ruler" = { bg = "default" }
|
||||||
|
|
||||||
|
"ui.bufferline.active" = {
|
||||||
|
fg = "sapphire";
|
||||||
|
bg = "base";
|
||||||
|
underline = {
|
||||||
|
color = "sapphire";
|
||||||
|
style = "";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
bat = {
|
||||||
|
enable = true;
|
||||||
|
config = {
|
||||||
|
theme = "Catppuccin-mocha";
|
||||||
|
};
|
||||||
|
themes = {
|
||||||
|
"Catppuccin-mocha" = builtins.readFile (pkgs.fetchFromGitHub
|
||||||
|
{
|
||||||
|
owner = "catppuccin";
|
||||||
|
repo = "bat";
|
||||||
|
rev = "477622171ec0529505b0ca3cada68fc9433648c6";
|
||||||
|
sha256 = "6WVKQErGdaqb++oaXnY3i6/GuH2FhTgK0v4TN4Y0Wbw=";
|
||||||
|
} + "/Catppuccin-mocha.tmTheme");
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
zellij = {
|
||||||
# TODO: enable after port config
|
# TODO: enable after port config
|
||||||
enable = false;
|
enable = false;
|
||||||
enableFishIntegration = true;
|
enableFishIntegration = true;
|
||||||
|
@ -33,7 +369,7 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.broot = {
|
broot = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enableFishIntegration = true;
|
enableFishIntegration = true;
|
||||||
settings = {
|
settings = {
|
||||||
|
@ -137,12 +473,16 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.home-manager.enable = true;
|
home-manager = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
programs.direnv.enable = true;
|
direnv = {
|
||||||
programs.direnv.nix-direnv.enable = true;
|
enable = true;
|
||||||
|
nix-direnv.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
programs.fish = {
|
fish = {
|
||||||
enable = true;
|
enable = true;
|
||||||
# I load long scripts from files for a better editing experience
|
# I load long scripts from files for a better editing experience
|
||||||
shellInit = builtins.readFile ./fish/shellInit.fish;
|
shellInit = builtins.readFile ./fish/shellInit.fish;
|
||||||
|
@ -219,6 +559,7 @@
|
||||||
"........" = "d ../../../../../../..";
|
"........" = "d ../../../../../../..";
|
||||||
"........." = "d ../../../../../../../..";
|
"........." = "d ../../../../../../../..";
|
||||||
cat = "bat";
|
cat = "bat";
|
||||||
|
p = "ping";
|
||||||
dc = "docker compose";
|
dc = "docker compose";
|
||||||
k = "kubectl";
|
k = "kubectl";
|
||||||
kg = "kubectl get";
|
kg = "kubectl get";
|
||||||
|
@ -228,25 +569,21 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.exa.enable = true;
|
exa = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
programs.skim = {
|
skim = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enableFishIntegration = true;
|
enableFishIntegration = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.nix-index = {
|
nix-index = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enableFishIntegration = true;
|
enableFishIntegration = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
home.pointerCursor = {
|
firefox = {
|
||||||
name = "Catppuccin-Mocha-Sapphire-Cursors";
|
|
||||||
package = pkgs.catppuccin-cursors.mochaSapphire;
|
|
||||||
size = 64; # TODO: this doesn't seem to work -- at least in Sway
|
|
||||||
};
|
|
||||||
|
|
||||||
programs.firefox = {
|
|
||||||
# TODO: enable dark theme by default
|
# TODO: enable dark theme by default
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
||||||
|
@ -291,6 +628,7 @@
|
||||||
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
|
||||||
# wayland.windowManager.sway = {
|
# wayland.windowManager.sway = {
|
||||||
# enable = true;
|
# enable = true;
|
||||||
|
@ -298,3 +636,6 @@
|
||||||
# maybe we can share somehow so things for nix-y systems and non-nix-y systems alike
|
# maybe we can share somehow so things for nix-y systems and non-nix-y systems alike
|
||||||
# am I going to _have_ non-nix systems anymore?
|
# am I going to _have_ non-nix systems anymore?
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
{
|
{
|
||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05";
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05";
|
||||||
|
# nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixpkgs-channels/nixos-unstable";
|
||||||
api-lyte-dev.url = "git+ssh://gitea@git.lyte.dev/lytedev/api.lyte.dev.git";
|
api-lyte-dev.url = "git+ssh://gitea@git.lyte.dev/lytedev/api.lyte.dev.git";
|
||||||
home-manager.url = "github:nix-community/home-manager/release-23.05";
|
home-manager.url = "github:nix-community/home-manager/release-23.05";
|
||||||
disko.url = "github:nix-community/disko/master";
|
disko.url = "github:nix-community/disko/master";
|
||||||
|
|
20
home.nix
20
home.nix
|
@ -1,17 +1,15 @@
|
||||||
inputs:
|
inputs @ { nixpkgs, home-manager, ... }:
|
||||||
let
|
let
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
pkgs = inputs.nixpkgs.legacyPackages.${system};
|
overlay = final: prev: {
|
||||||
in
|
helix = prev.helix // inputs.helix.packages.${system}.helix;
|
||||||
{
|
rtx = prev.rtx // inputs.rtx.packages.${system}.rtx;
|
||||||
|
};
|
||||||
|
pkgs = import nixpkgs { inherit system; overlays = [ overlay ]; };
|
||||||
|
in {
|
||||||
# TODO: per arch?
|
# TODO: per arch?
|
||||||
daniel = inputs.home-manager.lib.homeManagerConfiguration {
|
daniel = home-manager.lib.homeManagerConfiguration {
|
||||||
inherit pkgs;
|
inherit pkgs;
|
||||||
modules = [
|
modules = [ import ./daniel.nix pkgs ];
|
||||||
(import
|
|
||||||
./daniel.nix
|
|
||||||
|
|
||||||
pkgs)
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,6 +64,10 @@ in
|
||||||
plugins = with pkgs.xfce; [ thunar-archive-plugin thunar-volman ];
|
plugins = with pkgs.xfce; [ thunar-archive-plugin thunar-volman ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
services.gvfs = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
brightnessctl
|
brightnessctl
|
||||||
feh
|
feh
|
||||||
|
|
Loading…
Reference in a new issue