mirror of
https://github.com/nix-community/home-manager.git
synced 2025-11-08 19:46:05 +01:00
treewide: implement auto importing for modules
Reduce maintenance burden and increase efficiency by automatically importing modules following a specific convention. Co-authored-by: awwpotato <awwpotato@voidq.com> Signed-off-by: Austin Horstman <khaneliman12@gmail.com>
This commit is contained in:
parent
fefeb0e928
commit
4fca600cb1
461 changed files with 72 additions and 474 deletions
|
|
@ -1,111 +0,0 @@
|
|||
{
|
||||
pkgs,
|
||||
lib,
|
||||
config,
|
||||
...
|
||||
}:
|
||||
|
||||
let
|
||||
inherit (lib)
|
||||
mkEnableOption
|
||||
mkIf
|
||||
mkMerge
|
||||
mkOption
|
||||
mkPackageOption
|
||||
types
|
||||
;
|
||||
|
||||
cfg = config.programs.sesh;
|
||||
tomlFormat = pkgs.formats.toml { };
|
||||
in
|
||||
{
|
||||
meta.maintainers = [ lib.hm.maintainers.michaelvanstraten ];
|
||||
|
||||
options.programs.sesh = {
|
||||
enable = mkEnableOption "the sesh terminal session manager";
|
||||
|
||||
package = mkPackageOption pkgs "sesh" { };
|
||||
fzfPackage = mkPackageOption pkgs "fzf" { nullable = true; };
|
||||
zoxidePackage = mkPackageOption pkgs "zoxide" { nullable = true; };
|
||||
|
||||
settings = mkOption {
|
||||
type = types.submodule { freeformType = tomlFormat.type; };
|
||||
default = { };
|
||||
description = ''
|
||||
Configuration for sesh, written to `~/.config/sesh/sesh.toml`.
|
||||
|
||||
See the [sesh documentation](https://github.com/joshmedeski/sesh#configuration) for available options.
|
||||
'';
|
||||
};
|
||||
|
||||
enableAlias = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
description = "Whether to enable a shell alias `s` to quickly launch sessions.";
|
||||
};
|
||||
|
||||
enableTmuxIntegration = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
description = "Enable Tmux integration with sesh.";
|
||||
};
|
||||
|
||||
tmuxKey = mkOption {
|
||||
type = types.str;
|
||||
default = "s";
|
||||
description = "Keybinding for invoking sesh in Tmux.";
|
||||
};
|
||||
|
||||
icons = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
description = ''
|
||||
Display icons next to results ({option}`--icons` argument).
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
config =
|
||||
let
|
||||
args = lib.escapeShellArgs (lib.optional cfg.icons "--icons");
|
||||
fzf-args = lib.escapeShellArgs (lib.optional cfg.icons "--ansi");
|
||||
in
|
||||
mkIf cfg.enable (mkMerge [
|
||||
{
|
||||
home.packages = [ cfg.package ];
|
||||
home.file.".config/sesh/sesh.toml".source = tomlFormat.generate "sesh.toml" cfg.settings;
|
||||
}
|
||||
|
||||
(mkIf cfg.enableAlias {
|
||||
home.packages = lib.mkIf (cfg.fzfPackage != null) [ cfg.fzfPackage ];
|
||||
home.shellAliases.s = "sesh connect $(sesh list ${args} | fzf ${fzf-args})";
|
||||
})
|
||||
|
||||
(mkIf cfg.enableTmuxIntegration {
|
||||
assertions = [
|
||||
{
|
||||
assertion = config.programs.fzf.tmux.enableShellIntegration;
|
||||
message = "To use Tmux integration with sesh, enable `programs.fzf.tmux.enableShellIntegration`.";
|
||||
}
|
||||
];
|
||||
|
||||
home.packages = lib.mkIf (cfg.zoxidePackage != null) [ cfg.zoxidePackage ];
|
||||
|
||||
programs.tmux.extraConfig = ''
|
||||
bind-key "${cfg.tmuxKey}" run-shell "sesh connect \"$(
|
||||
sesh list ${args} | fzf-tmux -p 55%,60% \
|
||||
--no-sort --ansi --border-label ' sesh ' --prompt '⚡ ' \
|
||||
--header ' ^a all ^t tmux ^g configs ^x zoxide ^d tmux kill ^f find' \
|
||||
--bind 'tab:down,btab:up' \
|
||||
--bind 'ctrl-a:change-prompt(⚡ )+reload(sesh list ${args})' \
|
||||
--bind 'ctrl-t:change-prompt(🪟 )+reload(sesh list ${args} -t)' \
|
||||
--bind 'ctrl-g:change-prompt(⚙️ )+reload(sesh list ${args} -c)' \
|
||||
--bind 'ctrl-x:change-prompt(📁 )+reload(sesh list ${args} -z)' \
|
||||
--bind 'ctrl-f:change-prompt(🔎 )+reload(fd -H -d 2 -t d -E .Trash . ~)' \
|
||||
--bind 'ctrl-d:execute(tmux kill-session -t {})+change-prompt(⚡ )+reload(sesh list ${args})' \
|
||||
-- ${fzf-args}
|
||||
)\""
|
||||
'';
|
||||
})
|
||||
]);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue