mirror of
https://github.com/nix-community/nixvim.git
synced 2025-06-21 00:25:42 +02:00
Update the extraConfig function to access settings through opts parameter instead of direct import. Also remove the unused options import for cleaner code.
259 lines
7.3 KiB
Nix
259 lines
7.3 KiB
Nix
{ lib, ... }:
|
|
let
|
|
inherit (lib)
|
|
id
|
|
literalMD
|
|
mkMerge
|
|
mkOption
|
|
optional
|
|
types
|
|
;
|
|
inherit (lib.nixvim)
|
|
defaultNullOpts
|
|
mkNullOrLuaFn
|
|
mkNullOrOption'
|
|
nestedLiteralLua
|
|
toLuaObject
|
|
;
|
|
inherit (lib.nixvim.keymaps) mkMapOptionSubmodule;
|
|
in
|
|
lib.nixvim.plugins.mkNeovimPlugin {
|
|
name = "lz-n";
|
|
packPathName = "lz.n";
|
|
|
|
maintainers = with lib.maintainers; [
|
|
HeitorAugustoLN
|
|
psfloyd
|
|
];
|
|
|
|
# NOTE: We want to load lz.n as early as possible so that triggers are respected
|
|
configLocation = "extraConfigLuaPre";
|
|
|
|
settingsDescription = ''
|
|
Options provided to `vim.g.lz_n`.
|
|
|
|
`{ load = "fun"; }` -> `vim.g.lz_n = { load = fun, }`
|
|
'';
|
|
|
|
settingsOptions = {
|
|
load = defaultNullOpts.mkLuaFn "vim.cmd.packadd" ''
|
|
Function used by `lz.n` to load plugins.
|
|
'';
|
|
};
|
|
|
|
callSetup = false; # Does not use setup
|
|
|
|
extraOptions =
|
|
let
|
|
lzPluginType = types.submodule {
|
|
freeformType = types.attrsOf types.anything;
|
|
options = {
|
|
__unkeyed-1 = mkOption {
|
|
type = types.str;
|
|
description = ''
|
|
The "unkeyed" attribute is the plugin's name.
|
|
This is passed to `load` function and should normally match the repo name of the plugin.
|
|
|
|
More specifically, this is the name of the folder in `/pack/opt/{name}` that is loaded with `load` (`packadd` by default).
|
|
See `:h packadd`.
|
|
'';
|
|
};
|
|
|
|
enabled = defaultNullOpts.mkStrLuaFnOr types.bool true ''
|
|
When false, or if the function returns false, then this plugin will not be included in the spec.
|
|
This option corresponds to the `enabled` property of lz.n.
|
|
'';
|
|
|
|
beforeAll = mkNullOrLuaFn ''
|
|
Always executed before any plugins are loaded.
|
|
'';
|
|
|
|
before = mkNullOrLuaFn ''
|
|
Executed before this plugin is loaded.
|
|
'';
|
|
|
|
after = mkNullOrLuaFn ''
|
|
Executed after this plugin is loaded.
|
|
'';
|
|
|
|
load = mkNullOrLuaFn ''
|
|
Can be used to override the `vim.g.lz_n.load()` function for this plugin.
|
|
'';
|
|
|
|
priority = defaultNullOpts.mkUnsignedInt (literalMD "`50` (or `1000` if `colorscheme` is set)") ''
|
|
Only useful for start plugins (not lazy-loaded) to force loading certain plugins first.
|
|
'';
|
|
|
|
event = mkNullOrOption' {
|
|
type = types.anything;
|
|
description = ''
|
|
Lazy-load on event. Events can be specified as BufEnter or with a pattern like BufEnter *.lua
|
|
'';
|
|
example = [
|
|
"BufEnter *.lua"
|
|
"DeferredUIEnter"
|
|
];
|
|
};
|
|
|
|
cmd = mkNullOrOption' {
|
|
type = types.anything;
|
|
description = ''
|
|
Lazy-load on command.
|
|
'';
|
|
example = [
|
|
"Neotree"
|
|
"Telescope"
|
|
];
|
|
};
|
|
|
|
ft = mkNullOrOption' {
|
|
type = types.anything;
|
|
description = ''
|
|
Lazy-load on filetype.
|
|
'';
|
|
example = [ "tex" ];
|
|
};
|
|
|
|
colorscheme = mkNullOrOption' {
|
|
type = types.anything;
|
|
description = ''
|
|
Lazy-load on colorscheme.
|
|
'';
|
|
example = "onedarker";
|
|
};
|
|
|
|
keys = mkNullOrOption' {
|
|
type = types.listOf types.anything;
|
|
description = ''
|
|
Lazy-load on key mapping. Mode is `n` by default.
|
|
'';
|
|
example = [
|
|
"<C-a>"
|
|
[
|
|
"<C-x>"
|
|
"g<C-x>"
|
|
]
|
|
{
|
|
__unkeyed-1 = "<leader>fb";
|
|
__unkeyed-2 = "<CMD>Telescope buffers<CR>";
|
|
desc = "Telescope buffers";
|
|
}
|
|
{ __raw = "{ '<leader>ft', '<CMD>Neotree toggle<CR>', desc = 'NeoTree toggle' }"; }
|
|
];
|
|
};
|
|
};
|
|
};
|
|
in
|
|
{
|
|
keymaps = mkOption {
|
|
type = types.listOf (mkMapOptionSubmodule {
|
|
extraOptions.plugin = mkOption {
|
|
type = with types; either str lzPluginType;
|
|
example = "telescope.nvim";
|
|
description = ''
|
|
The plugin (name or spec) to lazy-load when the keymap is triggered.
|
|
|
|
> [!NOTE]
|
|
> This must match the name used in the `plugins` list or be a valid plugin that can be loaded.
|
|
'';
|
|
};
|
|
});
|
|
default = [ ];
|
|
example = [
|
|
{
|
|
plugin = "telescope.nvim";
|
|
key = "<leader>ff";
|
|
action = nestedLiteralLua "function() require('telescope.builtin').find_files() end";
|
|
options.desc = "Find files";
|
|
}
|
|
{
|
|
plugin = "neo-tree.nvim";
|
|
key = "<leader>ft";
|
|
action = "<CMD>Neotree toggle<CR>";
|
|
options.desc = "NeoTree toggle";
|
|
}
|
|
];
|
|
description = ''
|
|
Define keymaps that will use lz.n's `keymap(<plugin>).set` functionality.
|
|
This provides a more intuitive way to define lazy-loaded keymaps with the familiar `keymaps` option API style.
|
|
'';
|
|
};
|
|
|
|
plugins = mkOption {
|
|
description = ''
|
|
List of plugin specs provided to the `require('lz.n').load` function.
|
|
Plugin specs can be ${types.rawLua.description}.
|
|
'';
|
|
default = [ ];
|
|
type = types.listOf lzPluginType;
|
|
example = [
|
|
{
|
|
__unkeyed-1 = "neo-tree.nvim";
|
|
enabled = ''
|
|
function()
|
|
return true
|
|
end
|
|
'';
|
|
keys = [
|
|
{
|
|
__unkeyed-1 = "<leader>ft";
|
|
__unkeyed-2 = "<CMD>Neotree toggle<CR>";
|
|
desc = "NeoTree toggle";
|
|
}
|
|
];
|
|
after = ''
|
|
function()
|
|
require("neo-tree").setup()
|
|
end
|
|
'';
|
|
}
|
|
{
|
|
__unkeyed-1 = "telescope.nvim";
|
|
cmd = [ "Telescope" ];
|
|
keys = [
|
|
{
|
|
__unkeyed-1 = "<leader>fa";
|
|
__unkeyed-2 = "<CMD>Telescope autocommands<CR>";
|
|
desc = "Telescope autocommands";
|
|
}
|
|
{
|
|
__unkeyed-1 = "<leader>fb";
|
|
__unkeyed-2 = "<CMD>Telescope buffers<CR>";
|
|
desc = "Telescope buffers";
|
|
}
|
|
];
|
|
}
|
|
{
|
|
__unkeyed-1 = "onedarker.nvim";
|
|
colorscheme = [ "onedarker" ];
|
|
}
|
|
{
|
|
__raw = ''
|
|
{
|
|
"crates.nvim",
|
|
ft = "toml",
|
|
},
|
|
'';
|
|
}
|
|
];
|
|
};
|
|
};
|
|
|
|
extraConfig = cfg: opts: {
|
|
globals.lz_n = lib.modules.mkAliasAndWrapDefsWithPriority id opts.settings;
|
|
plugins.lz-n.luaConfig.content = mkMerge (
|
|
optional (cfg.plugins != [ ]) "require('lz.n').load(${toLuaObject cfg.plugins})"
|
|
++ map (
|
|
{
|
|
plugin,
|
|
mode,
|
|
key,
|
|
action,
|
|
options,
|
|
...
|
|
}:
|
|
"require('lz.n').keymap(${toLuaObject plugin}).set(${toLuaObject mode}, ${toLuaObject key}, ${toLuaObject action}, ${toLuaObject options})"
|
|
) cfg.keymaps
|
|
);
|
|
};
|
|
}
|