mirror of
https://github.com/nix-community/nixvim.git
synced 2025-06-20 16:15:43 +02:00
313 lines
8.1 KiB
Nix
313 lines
8.1 KiB
Nix
{
|
|
lib,
|
|
helpers,
|
|
...
|
|
}:
|
|
with lib;
|
|
lib.nixvim.plugins.mkNeovimPlugin {
|
|
name = "edgy";
|
|
packPathName = "edgy.nvim";
|
|
package = "edgy-nvim";
|
|
|
|
maintainers = [ maintainers.GaetanLepage ];
|
|
|
|
extraConfig = {
|
|
# Those options are strongly recommended by the plugin author:
|
|
# https://github.com/folke/edgy.nvim?tab=readme-ov-file#-installation
|
|
opts = {
|
|
laststatus = mkDefault 3;
|
|
splitkeep = mkDefault "screen";
|
|
};
|
|
};
|
|
|
|
settingsOptions =
|
|
let
|
|
viewOpts = {
|
|
ft = helpers.mkNullOrStr ''
|
|
File type of the view.
|
|
'';
|
|
|
|
filter = helpers.mkNullOrLuaFn ''
|
|
Optional function to filter buffers and windows.
|
|
|
|
`fun(buf:buffer, win:window)`
|
|
'';
|
|
|
|
title = helpers.mkNullOrStr ''
|
|
Optional title of the view.
|
|
Defaults to the capitalized filetype.
|
|
'';
|
|
|
|
size = helpers.mkNullOrOption types.ints.unsigned ''
|
|
Size of the short edge of the edgebar.
|
|
For edgebars, this is the minimum width.
|
|
For panels, minimum height.
|
|
'';
|
|
|
|
pinned = helpers.mkNullOrOption types.bool ''
|
|
If true, the view will always be shown in the edgebar even when it has no windows.
|
|
'';
|
|
|
|
open = helpers.mkNullOrStr ''
|
|
Function or command to open a pinned view.
|
|
'';
|
|
|
|
wo = helpers.mkNullOrOption (with types; attrsOf anything) ''
|
|
View-specific window options.
|
|
'';
|
|
};
|
|
|
|
mkViewOptsOption =
|
|
name:
|
|
helpers.defaultNullOpts.mkListOf (
|
|
with types;
|
|
either str (submodule {
|
|
options = viewOpts;
|
|
})
|
|
) [ ] "List of the ${name} edgebar configurations.";
|
|
in
|
|
{
|
|
left = mkViewOptsOption "left";
|
|
bottom = mkViewOptsOption "bottom";
|
|
right = mkViewOptsOption "right";
|
|
top = mkViewOptsOption "top";
|
|
|
|
options =
|
|
mapAttrs
|
|
(_: defaultSize: {
|
|
size = helpers.defaultNullOpts.mkUnsignedInt defaultSize ''
|
|
Size of the short edge of the edgebar.
|
|
For edgebars, this is the minimum width.
|
|
For panels, minimum height.
|
|
'';
|
|
|
|
wo = helpers.mkNullOrOption (with types; attrsOf anything) ''
|
|
View-specific window options.
|
|
'';
|
|
})
|
|
{
|
|
left = 30;
|
|
bottom = 10;
|
|
right = 30;
|
|
top = 10;
|
|
};
|
|
|
|
animate = {
|
|
enabled = helpers.defaultNullOpts.mkBool true ''
|
|
Whether to enable animations.
|
|
'';
|
|
|
|
fps = helpers.defaultNullOpts.mkUnsignedInt 100 ''
|
|
Frames per second.
|
|
'';
|
|
|
|
cps = helpers.defaultNullOpts.mkUnsignedInt 120 ''
|
|
Cells per second.
|
|
'';
|
|
|
|
on_begin = helpers.defaultNullOpts.mkLuaFn ''
|
|
function()
|
|
vim.g.minianimate_disable = true
|
|
end
|
|
'' "Callback for the beginning of animations.";
|
|
|
|
on_end = helpers.defaultNullOpts.mkLuaFn ''
|
|
function()
|
|
vim.g.minianimate_disable = false
|
|
end
|
|
'' "Callback for the ending of animations.";
|
|
|
|
# This option accepts an attrs or a lua string.
|
|
# Hence, we convert the string to raw lua in `apply`.
|
|
spinner =
|
|
let
|
|
defaultFrames = [
|
|
"⠋"
|
|
"⠙"
|
|
"⠹"
|
|
"⠸"
|
|
"⠼"
|
|
"⠴"
|
|
"⠦"
|
|
"⠧"
|
|
"⠇"
|
|
"⠏"
|
|
];
|
|
in
|
|
helpers.mkNullOrOption' {
|
|
type =
|
|
with lib.types;
|
|
either strLua (submodule {
|
|
freeformType = attrsOf anything;
|
|
options = {
|
|
frames = helpers.defaultNullOpts.mkListOf types.str defaultFrames ''
|
|
Frame characters.
|
|
'';
|
|
|
|
interval = helpers.defaultNullOpts.mkUnsignedInt 80 ''
|
|
Interval time between two consecutive frames.
|
|
'';
|
|
};
|
|
});
|
|
default = null;
|
|
example = "require('noice.util.spinners').spinners.circleFull";
|
|
description = "Spinner for pinned views that are loading.";
|
|
pluginDefault = {
|
|
frames = defaultFrames;
|
|
interval = 80;
|
|
};
|
|
};
|
|
};
|
|
|
|
exit_when_last = helpers.defaultNullOpts.mkBool false ''
|
|
Enable this to exit Neovim when only edgy windows are left.
|
|
'';
|
|
|
|
close_when_all_hidden = helpers.defaultNullOpts.mkBool true ''
|
|
Close edgy when all windows are hidden instead of opening one of them.
|
|
Disable to always keep at least one edgy split visible in each open section.
|
|
'';
|
|
|
|
wo = helpers.defaultNullOpts.mkAttrsOf types.anything {
|
|
winbar = true;
|
|
winfixwidth = true;
|
|
winfixheight = false;
|
|
winhighlight = "WinBar:EdgyWinBar,Normal:EdgyNormal";
|
|
spell = false;
|
|
signcolumn = "no";
|
|
} "Global window options for edgebar windows.";
|
|
|
|
# This option accepts an attrs or a lua string.
|
|
# Hence, we convert the string to raw lua in `apply`.
|
|
keys = helpers.defaultNullOpts.mkAttrsOf' {
|
|
type = with lib.types; either strLuaFn (enum [ false ]);
|
|
description = ''
|
|
Buffer-local keymaps to be added to edgebar buffers.
|
|
Existing buffer-local keymaps will never be overridden.
|
|
|
|
Each value is either:
|
|
- A function declaration (as a raw lua string)
|
|
-> `fun(win:Edgy.Window)`
|
|
- `false` to disable this mapping.
|
|
'';
|
|
pluginDefault = {
|
|
q = ''
|
|
function(win)
|
|
win:close()
|
|
end
|
|
'';
|
|
"<c-q>" = ''
|
|
function(win)
|
|
win:hide()
|
|
end
|
|
'';
|
|
Q = ''
|
|
function(win)
|
|
win.view.edgebar:close()
|
|
end
|
|
'';
|
|
"]w" = ''
|
|
function(win)
|
|
win:next({ visible = true, focus = true })
|
|
end
|
|
'';
|
|
"[w" = ''
|
|
function(win)
|
|
win:prev({ visible = true, focus = true })
|
|
end
|
|
'';
|
|
"]W" = ''
|
|
function(win)
|
|
win:next({ pinned = false, focus = true })
|
|
end
|
|
'';
|
|
"[W" = ''
|
|
function(win)
|
|
win:prev({ pinned = false, focus = true })
|
|
end
|
|
'';
|
|
"<c-w>>" = ''
|
|
function(win)
|
|
win:resize("width", 2)
|
|
end
|
|
'';
|
|
"<c-w><lt>" = ''
|
|
function(win)
|
|
win:resize("width", -2)
|
|
end
|
|
'';
|
|
"<c-w>+" = ''
|
|
function(win)
|
|
win:resize("height", 2)
|
|
end
|
|
'';
|
|
"<c-w>-" = ''
|
|
function(win)
|
|
win:resize("height", -2)
|
|
end
|
|
'';
|
|
"<c-w>=" = ''
|
|
function(win)
|
|
win.view.edgebar:equalize()
|
|
end
|
|
'';
|
|
};
|
|
};
|
|
|
|
icons = {
|
|
closed = helpers.defaultNullOpts.mkStr " " ''
|
|
Icon for closed edgebars.
|
|
'';
|
|
|
|
open = helpers.defaultNullOpts.mkStr " " ''
|
|
Icon for opened edgebars.
|
|
'';
|
|
};
|
|
};
|
|
|
|
settingsExample = {
|
|
animate.enabled = false;
|
|
wo = {
|
|
winbar = false;
|
|
winfixwidth = false;
|
|
winfixheight = false;
|
|
winhighlight = "";
|
|
spell = false;
|
|
signcolumn = "no";
|
|
};
|
|
bottom = [
|
|
{
|
|
ft = "toggleterm";
|
|
size = 30;
|
|
filter = ''
|
|
function(buf, win)
|
|
return vim.api.nvim_win_get_config(win).relative == ""
|
|
end
|
|
'';
|
|
}
|
|
{
|
|
ft = "help";
|
|
size = 20;
|
|
filter = ''
|
|
function(buf)
|
|
return vim.bo[buf].buftype == "help"
|
|
end
|
|
'';
|
|
}
|
|
];
|
|
left = [
|
|
{
|
|
title = "nvimtree";
|
|
ft = "NvimTree";
|
|
size = 30;
|
|
}
|
|
{
|
|
ft = "Outline";
|
|
open = "SymbolsOutline";
|
|
}
|
|
{ ft = "dapui_scopes"; }
|
|
{ ft = "dapui_breakpoints"; }
|
|
{ ft = "dap-repl"; }
|
|
];
|
|
};
|
|
}
|