2020-10-12 00:22:58 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
cfg = config.programs.fzf;
|
|
|
|
|
2023-01-10 09:35:00 +00:00
|
|
|
renderedColors = colors:
|
|
|
|
concatStringsSep ","
|
|
|
|
(mapAttrsToList (name: value: "${name}:${value}") colors);
|
|
|
|
|
2020-10-12 00:22:58 +00:00
|
|
|
in {
|
2021-07-02 22:36:30 +00:00
|
|
|
imports = [
|
|
|
|
(mkRemovedOptionModule [ "programs" "fzf" "historyWidgetCommand" ]
|
|
|
|
"This option is no longer supported by fzf.")
|
|
|
|
];
|
|
|
|
|
2020-10-12 00:22:58 +00:00
|
|
|
options.programs.fzf = {
|
|
|
|
enable = mkEnableOption "fzf - a command-line fuzzy finder";
|
|
|
|
|
2021-07-02 22:36:30 +00:00
|
|
|
package = mkOption {
|
|
|
|
type = types.package;
|
|
|
|
default = pkgs.fzf;
|
2021-11-04 16:42:44 +00:00
|
|
|
defaultText = literalExpression "pkgs.fzf";
|
2021-07-02 22:36:30 +00:00
|
|
|
description = "Package providing the <command>fzf</command> tool.";
|
|
|
|
};
|
|
|
|
|
2020-10-12 00:22:58 +00:00
|
|
|
defaultCommand = mkOption {
|
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
|
|
|
example = "fd --type f";
|
|
|
|
description = ''
|
|
|
|
The command that gets executed as the default source for fzf
|
|
|
|
when running.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
defaultOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [ ];
|
|
|
|
example = [ "--height 40%" "--border" ];
|
|
|
|
description = ''
|
|
|
|
Extra command line options given to fzf by default.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
fileWidgetCommand = mkOption {
|
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
|
|
|
example = "fd --type f";
|
|
|
|
description = ''
|
|
|
|
The command that gets executed as the source for fzf for the
|
|
|
|
CTRL-T keybinding.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
fileWidgetOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [ ];
|
|
|
|
example = [ "--preview 'head {}'" ];
|
|
|
|
description = ''
|
|
|
|
Command line options for the CTRL-T keybinding.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
changeDirWidgetCommand = mkOption {
|
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
|
|
|
example = "fd --type d";
|
|
|
|
description = ''
|
|
|
|
The command that gets executed as the source for fzf for the
|
|
|
|
ALT-C keybinding.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
changeDirWidgetOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [ ];
|
|
|
|
example = [ "--preview 'tree -C {} | head -200'" ];
|
|
|
|
description = ''
|
|
|
|
Command line options for the ALT-C keybinding.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
historyWidgetOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [ ];
|
|
|
|
example = [ "--sort" "--exact" ];
|
|
|
|
description = ''
|
|
|
|
Command line options for the CTRL-R keybinding.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2023-01-10 09:35:00 +00:00
|
|
|
colors = mkOption {
|
|
|
|
type = types.attrsOf types.str;
|
|
|
|
default = { };
|
|
|
|
example = literalExpression ''
|
|
|
|
{
|
|
|
|
bg = "#1e1e1e";
|
|
|
|
"bg+" = "#1e1e1e";
|
|
|
|
fg = "#d4d4d4";
|
|
|
|
"fg+" = "#d4d4d4";
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Color scheme options added to <code>FZF_DEFAULT_OPTS</code>. See
|
|
|
|
<link xlink:href="https://github.com/junegunn/fzf/wiki/Color-schemes"/>
|
|
|
|
for documentation.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-07-02 22:36:30 +00:00
|
|
|
tmux = {
|
|
|
|
enableShellIntegration = mkEnableOption ''
|
|
|
|
setting <literal>FZF_TMUX=1</literal> which causes shell integration to use fzf-tmux
|
|
|
|
'';
|
|
|
|
|
|
|
|
shellIntegrationOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [ ];
|
2021-11-04 16:42:44 +00:00
|
|
|
example = literalExpression ''[ "-d 40%" ]'';
|
2021-07-02 22:36:30 +00:00
|
|
|
description = ''
|
|
|
|
If <option>programs.fzf.tmux.enableShellIntegration</option> is set to <literal>true</literal>,
|
|
|
|
shell integration will use these options for fzf-tmux.
|
|
|
|
See <command>fzf-tmux --help</command> for available options.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-10-12 00:22:58 +00:00
|
|
|
enableBashIntegration = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable Bash integration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
enableZshIntegration = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable Zsh integration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
enableFishIntegration = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable Fish integration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2021-07-02 22:36:30 +00:00
|
|
|
home.packages = [ cfg.package ];
|
2020-10-12 00:22:58 +00:00
|
|
|
|
|
|
|
home.sessionVariables = mapAttrs (n: v: toString v)
|
|
|
|
(filterAttrs (n: v: v != [ ] && v != null) {
|
|
|
|
FZF_ALT_C_COMMAND = cfg.changeDirWidgetCommand;
|
|
|
|
FZF_ALT_C_OPTS = cfg.changeDirWidgetOptions;
|
|
|
|
FZF_CTRL_R_OPTS = cfg.historyWidgetOptions;
|
|
|
|
FZF_CTRL_T_COMMAND = cfg.fileWidgetCommand;
|
|
|
|
FZF_CTRL_T_OPTS = cfg.fileWidgetOptions;
|
|
|
|
FZF_DEFAULT_COMMAND = cfg.defaultCommand;
|
2023-01-10 09:35:00 +00:00
|
|
|
FZF_DEFAULT_OPTS = cfg.defaultOptions
|
|
|
|
++ lib.optionals (cfg.colors != { })
|
|
|
|
[ "--color ${renderedColors cfg.colors}" ];
|
2021-07-02 22:36:30 +00:00
|
|
|
FZF_TMUX = if cfg.tmux.enableShellIntegration then "1" else null;
|
|
|
|
FZF_TMUX_OPTS = cfg.tmux.shellIntegrationOptions;
|
2020-10-12 00:22:58 +00:00
|
|
|
});
|
|
|
|
|
2021-11-04 16:42:44 +00:00
|
|
|
# Note, since fzf unconditionally binds C-r we use `mkOrder` to make the
|
|
|
|
# initialization show up a bit earlier. This is to make initialization of
|
|
|
|
# other history managers, like mcfly or atuin, take precedence.
|
|
|
|
programs.bash.initExtra = mkIf cfg.enableBashIntegration (mkOrder 200 ''
|
2020-10-12 00:22:58 +00:00
|
|
|
if [[ :$SHELLOPTS: =~ :(vi|emacs): ]]; then
|
2021-07-02 22:36:30 +00:00
|
|
|
. ${cfg.package}/share/fzf/completion.bash
|
|
|
|
. ${cfg.package}/share/fzf/key-bindings.bash
|
2020-10-12 00:22:58 +00:00
|
|
|
fi
|
2021-11-04 16:42:44 +00:00
|
|
|
'');
|
2020-10-12 00:22:58 +00:00
|
|
|
|
2021-11-04 16:42:44 +00:00
|
|
|
# Note, since fzf unconditionally binds C-r we use `mkOrder` to make the
|
|
|
|
# initialization show up a bit earlier. This is to make initialization of
|
|
|
|
# other history managers, like mcfly or atuin, take precedence.
|
|
|
|
programs.zsh.initExtra = mkIf cfg.enableZshIntegration (mkOrder 200 ''
|
2020-10-12 00:22:58 +00:00
|
|
|
if [[ $options[zle] = on ]]; then
|
2021-07-02 22:36:30 +00:00
|
|
|
. ${cfg.package}/share/fzf/completion.zsh
|
|
|
|
. ${cfg.package}/share/fzf/key-bindings.zsh
|
2020-10-12 00:22:58 +00:00
|
|
|
fi
|
2021-11-04 16:42:44 +00:00
|
|
|
'');
|
2020-10-12 00:22:58 +00:00
|
|
|
|
|
|
|
programs.fish.shellInit = mkIf cfg.enableFishIntegration ''
|
2021-07-02 22:36:30 +00:00
|
|
|
source ${cfg.package}/share/fzf/key-bindings.fish && fzf_key_bindings
|
2020-10-12 00:22:58 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
}
|