mirror of
https://github.com/nix-community/nixvim.git
synced 2025-06-21 00:25:42 +02:00
plugins/dressing: init
This commit is contained in:
parent
b4a30dd1d6
commit
e521e37f51
3 changed files with 510 additions and 0 deletions
|
@ -140,6 +140,7 @@
|
|||
./utils/cursorline.nix
|
||||
./utils/dashboard.nix
|
||||
./utils/direnv.nix
|
||||
./utils/dressing.nix
|
||||
./utils/easyescape.nix
|
||||
./utils/emmet.nix
|
||||
./utils/endwise.nix
|
||||
|
|
403
plugins/utils/dressing.nix
Normal file
403
plugins/utils/dressing.nix
Normal file
|
@ -0,0 +1,403 @@
|
|||
{
|
||||
config,
|
||||
lib,
|
||||
helpers,
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
with lib;
|
||||
helpers.neovim-plugin.mkNeovimPlugin config {
|
||||
name = "dressing";
|
||||
originalName = "dressing.nvim";
|
||||
defaultPackage = pkgs.vimPlugins.dressing-nvim;
|
||||
|
||||
maintainers = [helpers.maintainers.AndresBermeoMarinelli];
|
||||
|
||||
settingsOptions = let
|
||||
intOrRatio = with types; either ints.unsigned (numbers.between 0.0 1.0);
|
||||
in {
|
||||
input = {
|
||||
enabled = helpers.defaultNullOpts.mkBool true ''
|
||||
Enable the `vim.ui.input` implementation.
|
||||
'';
|
||||
|
||||
default_prompt = helpers.defaultNullOpts.mkStr "Input" ''
|
||||
Default prompt string for `vim.ui.input`.
|
||||
'';
|
||||
|
||||
trim_prompt = helpers.defaultNullOpts.mkBool true ''
|
||||
Trim trailing `:` from prompt.
|
||||
'';
|
||||
|
||||
title_pos = helpers.defaultNullOpts.mkEnumFirstDefault ["left" "right" "center"] ''
|
||||
Position of title.
|
||||
'';
|
||||
|
||||
insert_only = helpers.defaultNullOpts.mkBool true ''
|
||||
When true, `<Esc>` will close the modal.
|
||||
'';
|
||||
|
||||
start_in_insert = helpers.defaultNullOpts.mkBool true ''
|
||||
When true, input will start in insert mode.
|
||||
'';
|
||||
|
||||
border = helpers.defaultNullOpts.mkBorder "rounded" "the input window" "";
|
||||
|
||||
relative = helpers.defaultNullOpts.mkEnumFirstDefault ["cursor" "win" "editor"] ''
|
||||
Affects the dimensions of the window with respect to this setting.
|
||||
If 'editor' or 'win', will default to being centered.
|
||||
'';
|
||||
|
||||
prefer_width = helpers.defaultNullOpts.mkNullable intOrRatio "40" ''
|
||||
Can be an integer or a float between 0 and 1 (e.g. 0.4 for 40%).
|
||||
'';
|
||||
|
||||
width = helpers.defaultNullOpts.mkNullable intOrRatio "null" ''
|
||||
Can be an integer or a float between 0 and 1 (e.g. 0.4 for 40%).
|
||||
'';
|
||||
|
||||
max_width =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with types;
|
||||
either
|
||||
intOrRatio
|
||||
(listOf intOrRatio)
|
||||
)
|
||||
"[140 0.9]"
|
||||
''
|
||||
Max width of window.
|
||||
|
||||
Can be a list of mixed types, e.g. `[140 0.9]` means "less than 140 columns or 90% of
|
||||
total."
|
||||
'';
|
||||
|
||||
min_width =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with types;
|
||||
either
|
||||
intOrRatio
|
||||
(listOf intOrRatio)
|
||||
)
|
||||
"[20 0.2]"
|
||||
''
|
||||
Min width of window.
|
||||
|
||||
Can be a list of mixed types, e.g. `[140 0.9]` means "less than 140 columns or 90% of
|
||||
total."
|
||||
'';
|
||||
|
||||
buf_options = helpers.defaultNullOpts.mkAttrsOf types.anything "{}" ''
|
||||
An attribute set of neovim buffer options.
|
||||
'';
|
||||
|
||||
win_options =
|
||||
helpers.defaultNullOpts.mkAttrsOf types.anything
|
||||
''
|
||||
{
|
||||
wrap = false;
|
||||
list = true;
|
||||
listchars = "precedes:...,extends:...";
|
||||
sidescrolloff = 0;
|
||||
}
|
||||
''
|
||||
"An attribute set of window options.";
|
||||
|
||||
mappings =
|
||||
helpers.defaultNullOpts.mkAttrsOf
|
||||
(
|
||||
with types;
|
||||
attrsOf
|
||||
(either str (enum [false]))
|
||||
)
|
||||
''
|
||||
{
|
||||
n = {
|
||||
"<Esc>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
};
|
||||
i = {
|
||||
"<C-c>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
"<Up>" = "HistoryPrev";
|
||||
"<Down>" = "HistoryNext";
|
||||
};
|
||||
}
|
||||
''
|
||||
''
|
||||
Mappings for defined modes.
|
||||
|
||||
To disable a default mapping in a specific mode, set it to `false`.
|
||||
'';
|
||||
|
||||
override = helpers.defaultNullOpts.mkLuaFn "function(conf) return conf end" ''
|
||||
Lua function that takes config that is passed to nvim_open_win.
|
||||
Used to customize the layout.
|
||||
'';
|
||||
|
||||
get_config = helpers.defaultNullOpts.mkLuaFn "null" ''
|
||||
This can be a function that accepts the opts parameter that is passed in to 'vim.select'
|
||||
or 'vim.input'. It must return either nil or config values to use in place of the global
|
||||
config values for that module.
|
||||
|
||||
See `:h dressing_get_config` for more info.
|
||||
'';
|
||||
};
|
||||
|
||||
select = {
|
||||
enabled = helpers.defaultNullOpts.mkBool true ''
|
||||
Enable the vim.ui.select implementation.
|
||||
'';
|
||||
|
||||
backend =
|
||||
helpers.defaultNullOpts.mkListOf types.str
|
||||
''
|
||||
["telescope" "fzf_lua" "fzf" "builtin" "nui"]
|
||||
''
|
||||
"Priority list of preferred vim.select implementations. ";
|
||||
|
||||
trim_prompt = helpers.defaultNullOpts.mkBool true ''
|
||||
Trim trailing `:` from prompt.
|
||||
'';
|
||||
|
||||
telescope =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with helpers.nixvimTypes;
|
||||
either
|
||||
strLua
|
||||
(attrsOf anything)
|
||||
)
|
||||
"null"
|
||||
''
|
||||
Options for telescope selector.
|
||||
|
||||
Can be a raw lua string like:
|
||||
|
||||
`telescope = \'\'require("telescope.themes").get_ivy({})\'\'`
|
||||
|
||||
or an attribute set of telescope settings.
|
||||
'';
|
||||
|
||||
fzf = {
|
||||
window =
|
||||
helpers.defaultNullOpts.mkAttrsOf types.anything
|
||||
''
|
||||
{
|
||||
width = 0.5;
|
||||
height = 0.4;
|
||||
}
|
||||
''
|
||||
"Window options for fzf selector. ";
|
||||
};
|
||||
|
||||
fzf_lua = helpers.defaultNullOpts.mkAttrsOf types.anything "{}" ''
|
||||
Options for fzf-lua selector.
|
||||
'';
|
||||
|
||||
nui =
|
||||
helpers.defaultNullOpts.mkAttrsOf types.anything
|
||||
''
|
||||
{
|
||||
position = "50%";
|
||||
size = null;
|
||||
relative = "editor";
|
||||
border = {
|
||||
style = "rounded";
|
||||
};
|
||||
buf_options = {
|
||||
swapfile = false;
|
||||
filetype = "DressingSelect";
|
||||
};
|
||||
win_options = {
|
||||
winblend = 0;
|
||||
};
|
||||
max_width = 80;
|
||||
max_height = 40;
|
||||
min_width = 40;
|
||||
min_height = 10;
|
||||
}
|
||||
''
|
||||
"Options for nui selector. ";
|
||||
|
||||
builtin = {
|
||||
show_numbers = helpers.defaultNullOpts.mkBool true ''
|
||||
Display numbers for options and set up keymaps.
|
||||
'';
|
||||
|
||||
border = helpers.defaultNullOpts.mkBorder "rounded" "the select window" "";
|
||||
|
||||
relative = helpers.defaultNullOpts.mkEnumFirstDefault ["editor" "win" "cursor"] ''
|
||||
Affects the dimensions of the window with respect to this setting.
|
||||
If 'editor' or 'win', will default to being centered.
|
||||
'';
|
||||
|
||||
buf_options = helpers.defaultNullOpts.mkAttrsOf types.anything "{}" ''
|
||||
An attribute set of buffer options.
|
||||
'';
|
||||
|
||||
win_options =
|
||||
helpers.defaultNullOpts.mkAttrsOf types.anything
|
||||
''
|
||||
{
|
||||
cursorline = true;
|
||||
cursorlineopt = "both";
|
||||
}
|
||||
''
|
||||
"An attribute set of window options.";
|
||||
|
||||
width = helpers.defaultNullOpts.mkNullable intOrRatio "null" ''
|
||||
Can be an integer or a float between 0 and 1 (e.g. 0.4 for 40%).
|
||||
'';
|
||||
|
||||
max_width =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with types;
|
||||
either
|
||||
intOrRatio
|
||||
(listOf intOrRatio)
|
||||
)
|
||||
"[140 0.8]"
|
||||
''
|
||||
Max width of window.
|
||||
|
||||
Can be a list of mixed types, e.g. `[140 0.8]` means "less than 140 columns or 80%
|
||||
of total."
|
||||
'';
|
||||
|
||||
min_width =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with types;
|
||||
either
|
||||
intOrRatio
|
||||
(listOf intOrRatio)
|
||||
)
|
||||
"[40 0.2]"
|
||||
''
|
||||
Min width of window.
|
||||
|
||||
Can be a list of mixed types, e.g. `[40 0.2]` means "less than 40 columns or 20%
|
||||
of total."
|
||||
'';
|
||||
|
||||
height = helpers.defaultNullOpts.mkNullable intOrRatio "null" ''
|
||||
Can be an integer or a float between 0 and 1 (e.g. 0.4 for 40%).
|
||||
'';
|
||||
|
||||
max_height =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with types;
|
||||
either
|
||||
intOrRatio
|
||||
(listOf intOrRatio)
|
||||
)
|
||||
"0.9"
|
||||
''
|
||||
Max height of window.
|
||||
|
||||
Can be a list of mixed types, e.g. `[140 0.8]` means "less than 140 rows or 80%
|
||||
of total."
|
||||
'';
|
||||
|
||||
min_height =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(
|
||||
with types;
|
||||
either
|
||||
intOrRatio
|
||||
(listOf intOrRatio)
|
||||
)
|
||||
"[10 0.2]"
|
||||
''
|
||||
Min height of window.
|
||||
|
||||
Can be a list of mixed types, e.g. `[10 0.2]` means "less than 10 rows or 20%
|
||||
of total."
|
||||
'';
|
||||
|
||||
mappings =
|
||||
helpers.defaultNullOpts.mkAttrsOf
|
||||
(
|
||||
with types;
|
||||
either str (enum [false])
|
||||
)
|
||||
''
|
||||
{
|
||||
"<Esc>" = "Close";
|
||||
"<C-c>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
}
|
||||
''
|
||||
''
|
||||
Mappings in normal mode for the builtin selector.
|
||||
|
||||
To disable a default mapping in a specific mode, set it to `false`.
|
||||
'';
|
||||
|
||||
override = helpers.defaultNullOpts.mkLuaFn "function(conf) return conf end" ''
|
||||
Lua function that takes config that is passed to nvim_open_win.
|
||||
Used to customize the layout.
|
||||
'';
|
||||
};
|
||||
|
||||
format_item_override = helpers.defaultNullOpts.mkAttrsOf helpers.nixvimTypes.strLuaFn "{}" ''
|
||||
Override the formatting/display for a specific "kind" when using vim.ui.select.
|
||||
For example, code actions from vim.lsp.buf.code_action use a kind="codeaction".
|
||||
You can override the format function when selecting for that kind, e.g.
|
||||
|
||||
```nix
|
||||
{
|
||||
codeaction = \'\'
|
||||
function(action_tuple)
|
||||
local title = action_tuple[2].title:gsub("\r\n", "\\r\\n")
|
||||
local client = vim.lsp.get_client_by_id(action_tuple[1])
|
||||
return string.format("%s\t[%s]", title:gsub("\n", "\\n"), client.name)
|
||||
end
|
||||
\'\';
|
||||
}
|
||||
```
|
||||
'';
|
||||
|
||||
get_config = helpers.defaultNullOpts.mkLuaFn "null" ''
|
||||
This can be a function that accepts the opts parameter that is passed in to 'vim.select'
|
||||
or 'vim.input'. It must return either nil or config values to use in place of the global
|
||||
config values for that module.
|
||||
|
||||
See `:h dressing_get_config` for more info.
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
settingsExample = {
|
||||
input = {
|
||||
enabled = true;
|
||||
mappings = {
|
||||
n = {
|
||||
"<Esc>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
};
|
||||
i = {
|
||||
"<C-c>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
"<Up>" = "HistoryPrev";
|
||||
"<Down>" = "HistoryNext";
|
||||
};
|
||||
};
|
||||
};
|
||||
select = {
|
||||
enabled = true;
|
||||
backend = ["telescope" "fzf_lua" "fzf" "builtin" "nui"];
|
||||
builtin = {
|
||||
mappings = {
|
||||
"<Esc>" = "Close";
|
||||
"<C-c>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
106
tests/test-sources/plugins/utils/dressing.nix
Normal file
106
tests/test-sources/plugins/utils/dressing.nix
Normal file
|
@ -0,0 +1,106 @@
|
|||
{
|
||||
empty = {
|
||||
plugins.dressing.enable = true;
|
||||
};
|
||||
|
||||
defaults = {
|
||||
plugins.dressing = {
|
||||
enable = true;
|
||||
|
||||
settings = {
|
||||
input = {
|
||||
enabled = true;
|
||||
default_prompt = "Input";
|
||||
trim_prompt = true;
|
||||
title_pos = "left";
|
||||
insert_only = true;
|
||||
start_in_insert = true;
|
||||
border = "rounded";
|
||||
relative = "cursor";
|
||||
prefer_width = 40;
|
||||
width = null;
|
||||
max_width = [140 0.9];
|
||||
min_width = [20 0.2];
|
||||
win_options = {
|
||||
wrap = false;
|
||||
list = true;
|
||||
listchars = "precedes:...,extends:...";
|
||||
sidescrolloff = 0;
|
||||
};
|
||||
mappings = {
|
||||
n = {
|
||||
"<Esc>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
};
|
||||
i = {
|
||||
"<C-c>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
"<Up>" = "HistoryPrev";
|
||||
"<Down>" = "HistoryNext";
|
||||
};
|
||||
};
|
||||
override = "function(conf) return conf end";
|
||||
get_config = null;
|
||||
};
|
||||
select = {
|
||||
enabled = true;
|
||||
backend = ["telescope" "fzf_lua" "fzf" "builtin" "nui"];
|
||||
trim_prompt = true;
|
||||
telescope = null;
|
||||
fzf.window = {
|
||||
width = 0.5;
|
||||
height = 0.4;
|
||||
};
|
||||
fzf_lua = {};
|
||||
nui = {
|
||||
position = "50%";
|
||||
size = null;
|
||||
relative = "editor";
|
||||
border = {
|
||||
style = "rounded";
|
||||
};
|
||||
buf_options = {
|
||||
swapfile = false;
|
||||
filetype = "DressingSelect";
|
||||
};
|
||||
win_options = {
|
||||
winblend = 0;
|
||||
};
|
||||
max_width = 80;
|
||||
max_height = 40;
|
||||
min_width = 40;
|
||||
min_height = 10;
|
||||
};
|
||||
builtin = {
|
||||
show_numbers = true;
|
||||
border = "rounded";
|
||||
relative = "editor";
|
||||
|
||||
buf_options = {};
|
||||
win_options = {
|
||||
cursorline = true;
|
||||
cursorlineopt = "both";
|
||||
};
|
||||
|
||||
width = null;
|
||||
max_width = [140 0.8];
|
||||
min_width = [40 0.2];
|
||||
height = null;
|
||||
max_height = 0.9;
|
||||
min_height = [10 0.2];
|
||||
|
||||
mappings = {
|
||||
"<Esc>" = "Close";
|
||||
"<C-c>" = "Close";
|
||||
"<CR>" = "Confirm";
|
||||
};
|
||||
|
||||
override = "function(conf) return conf end";
|
||||
};
|
||||
format_item_override = {};
|
||||
get_config = null;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue