rix101/modules/home-manager/reo101-shell/default.nix
reo101 ff04252a67
feat(darwin)!: update config
Add `nix` initialization script to shell's `extraConfig`
  - fixes `nix` when updating MacOS
Add `flameshot` to `brew` packages
Fix tilde (`~`) remapping
  - mysteriously switched after a restart, needed to swap
Add (noncompiling) `borders` (`JankyBorders`) config
Add `TODO` to `sketchybar` config
2024-05-11 22:57:00 +03:00

333 lines
9.4 KiB
Nix

{ lib, pkgs, config, ... }:
let
cfg = config.reo101.shell;
inherit (lib)
mkEnableOption mkOption types
mkIf optionals optionalString
mkMerge;
shellAliases = {
cp = "${pkgs.advcpmv}/bin/advcp -rvi";
mv = "${pkgs.advcpmv}/bin/advmv -vi";
rebuild =
let
rebuild_script = pkgs.writeShellScript "rebuild" ''
${
let
inherit (lib.strings)
hasInfix;
inherit (pkgs.hostPlatform)
isx86_64 isAarch64
isLinux isDarwin;
in
if isx86_64 && isLinux then
"sudo --validate && sudo nixos-rebuild"
else if isDarwin then
"darwin-rebuild"
else if isAarch64 then
"nix-on-droid"
else
"home-manager"
} --flake ${
if cfg.hostname != null
then "${cfg.flakePath}#${cfg.hostname}"
else "${cfg.flakePath}"
} ''$''\{1:-switch''\} "''$''\{@:2''\}" # |& nix run nixpkgs#nix-output-monitor
'';
in
"${rebuild_script}";
};
in
{
imports =
[
];
options =
{
reo101.shell = {
enable = mkEnableOption "reo101 shell setup";
username = mkOption {
description = "Username to be used (for prompt)";
type = types.str;
default = "${config.home.username}";
};
hostname = mkOption {
description = "Hostname to be used (for `rebuild`)";
type = types.nullOr types.str;
default = null;
};
shells = mkOption {
description = "Shells to be configured (first one is used for $SHELL)";
type =
lib.pipe
[
"nushell"
"zsh"
]
[
types.enum
types.listOf
];
default = [ "nushell" "zsh" ];
};
starship = mkOption {
description = "Use starship prompt";
type = types.bool;
default = true;
};
atuin = mkOption {
description = "Integrate with atuin";
type = types.bool;
default = true;
};
direnv = mkOption {
description = "Integrate with direnv";
type = types.bool;
default = true;
};
zoxide = mkOption {
description = "Integrate with zoxide";
type = types.bool;
default = true;
};
flakePath = mkOption {
description = "Flake path (for `rebuild`)";
type = types.str;
default = "${config.xdg.configHome}/rix101";
};
};
};
config =
mkIf cfg.enable {
home.packages = with pkgs;
builtins.concatLists [
(builtins.map
(lib.flip builtins.getAttr pkgs)
cfg.shells)
(optionals cfg.starship [
starship
])
(optionals cfg.atuin [
atuin
])
(optionals cfg.direnv [
direnv
])
(optionals cfg.zoxide [
zoxide
])
];
# Atuin
home.file."${config.xdg.configHome}/atuin/config.toml" = mkIf cfg.atuin {
# TODO: use pkgs.substituteAll
text = import ./atuin.nix {
keyPath = "${config.xdg.dataHome}/atuin/key";
};
};
# Direnv
programs.direnv = mkIf cfg.direnv {
enable = true;
enableNushellIntegration = builtins.elem "nushell" cfg.shells;
enableZshIntegration = builtins.elem "zsh" cfg.shells;
nix-direnv = {
enable = true;
};
};
# Starship
programs.starship = mkIf cfg.starship {
enable = true;
package = pkgs.starship;
settings = import ./starship.nix {
inherit (cfg) username;
};
};
# Zoxide
programs.zoxide = mkIf cfg.zoxide {
enable = true;
package = pkgs.zoxide;
enableNushellIntegration = builtins.elem "nushell" cfg.shells;
enableZshIntegration = builtins.elem "zsh" cfg.shells;
};
# Shell
home.sessionVariables = {
SHELL =
let
shellPackage = builtins.getAttr (builtins.head cfg.shells) pkgs;
in
"${shellPackage}/${shellPackage.shellPath}";
};
# Nushell
programs.nushell = mkMerge [
(mkIf (builtins.elem "nushell" cfg.shells) {
enable = true;
package = pkgs.nushell;
configFile.source = ./nushell/config.nu;
envFile.source = ./nushell/env.nu;
loginFile.source = ./nushell/login.nu;
inherit shellAliases;
environmentVariables = { };
})
(mkIf cfg.atuin {
extraEnv = ''
let atuin_cache = "${config.xdg.cacheHome}/atuin"
if not ($atuin_cache | path exists) {
mkdir $atuin_cache
}
${pkgs.atuin}/bin/atuin init nu | save --force ${config.xdg.cacheHome}/atuin/init.nu
'';
extraConfig = ''
source ${config.xdg.cacheHome}/atuin/init.nu
# Ctrl-R
$env.config = (
$env.config | upsert keybindings (
$env.config.keybindings
| append {
name: atuin
modifier: control
keycode: char_r
mode: [emacs, vi_normal, vi_insert]
event: { send: executehostcommand cmd: (_atuin_search_cmd) }
}
)
)
# Up
$env.config = (
$env.config | upsert keybindings (
$env.config.keybindings
| append {
name: atuin
modifier: none
keycode: up
mode: [emacs, vi_normal, vi_insert]
event: { send: executehostcommand cmd: (_atuin_search_cmd '--shell-up-key-binding') }
}
)
)
'';
})
];
# Zsh
programs.zsh = mkIf (builtins.elem "zsh" cfg.shells) {
enable = true;
package = pkgs.zsh;
enableCompletion = true;
dotDir = ".config/zsh";
shellAliases = shellAliases // {
ls = "${pkgs.lsd}/bin/lsd";
mkdir = "mkdir -vp";
};
history = {
size = 10000;
path = "${config.xdg.dataHome}/zsh/history";
};
initExtra =
builtins.concatStringsSep "\n"
[
''
function take() {
mkdir -p "''$''\{@''\}" && cd "''$''\{@''\}"
}
''
(optionalString cfg.atuin ''
export ATUIN_NOBIND="true"
eval "$(${pkgs.atuin}/bin/atuin init zsh)"
function zvm_after_init() {
# bindkey "^r" _atuin_search_widget
zvm_bindkey viins "^R" _atuin_search_widget
}
'')
# NOTE: done by `programs.direnv`
# (optionalString cfg.direnv ''
# eval "$(${pkgs.direnv}/bin/direnv hook zsh)"
# '')
# NOTE: done by `programs.zoxide`
# (optionalString cfg.zoxide ''
# eval "$(${pkgs.zoxide}/bin/zoxide init zsh)"
# '')
''
# Prevent macOS updates from destroying nix
if [ -e "/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh" ]; then
source "/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh"
fi
''
# cfg.extraConfig
];
plugins = [
{
name = "zsh-nix-shell";
file = "nix-shell.plugin.zsh";
src = pkgs.fetchFromGitHub {
owner = "chisui";
repo = "zsh-nix-shell";
rev = "v0.7.0";
sha256 = "sha256-oQpYKBt0gmOSBgay2HgbXiDoZo5FoUKwyHSlUrOAP5E=";
};
}
{
name = "fast-syntax-highlighting";
file = "fast-syntax-highlighting.plugin.zsh";
src = pkgs.fetchFromGitHub {
owner = "zdharma-continuum";
repo = "fast-syntax-highlighting";
rev = "cf318e06a9b7c9f2219d78f41b46fa6e06011fd9";
sha256 = "sha256-RVX9ZSzjBW3LpFs2W86lKI6vtcvDWP6EPxzeTcRZua4=";
};
}
{
name = "zsh-autosuggestions";
file = "zsh-autosuggestions.plugin.zsh";
src = pkgs.fetchFromGitHub {
owner = "zsh-users";
repo = "zsh-autosuggestions";
rev = "a411ef3e0992d4839f0732ebeb9823024afaaaa8";
sha256 = "sha256-KLUYpUu4DHRumQZ3w59m9aTW6TBKMCXl2UcKi4uMd7w=";
};
}
{
name = "zsh-vi-mode";
file = "zsh-vi-mode.plugin.zsh";
src = pkgs.fetchFromGitHub {
owner = "jeffreytse";
repo = "zsh-vi-mode";
rev = "1bda23100e8d140a19be0eed67395c64f6a6074c";
sha256 = "sha256-3arAa5EBG+U9cCauChX9K0KF3hkd+t04/trlWKk/gOw=";
};
}
];
};
};
meta = {
maintainers = with lib.maintainers; [ reo101 ];
};
}