-
-
Notifications
You must be signed in to change notification settings - Fork 298
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs/user-guide: add lazy-loading.md
- Loading branch information
1 parent
c181014
commit 6d5d4fc
Showing
2 changed files
with
95 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
# Lazy Loading | ||
|
||
> [!WARNING] | ||
> This is an experimental option and may not work as expected with all plugins. | ||
> The API may change without notice. > Please report any issues you encounter. | ||
> [!NOTE] | ||
> When the lazy loading functionality is enabled, the plugin's configuration is | ||
> routed to the enabled lazy provider. Options mentioned will be in relation to | ||
> the `${namespace}.${name}.lazyLoad` context. | ||
## Supported Lazy Loading Providers | ||
|
||
It is recommended to become familiar with lazy loading strategies supported by | ||
your provider in their upstream documentation and the corresponding plugin's | ||
support. | ||
|
||
Currently we only support **one** lazy loader: | ||
|
||
-lz.n: [`plugins.lz-n`](/plugins/lz-n/index.md) - | ||
[upstream docs](https://github.com/nvim-neorocks/lz.n?tab=readme-ov-file#plugin-spec) | ||
|
||
## Enabling Lazy Loading Per Plugin | ||
|
||
There are a couple different ways to enable lazy loading for a particular | ||
plugin. | ||
|
||
- `lazyLoad.enable` set to `true`. | ||
- `lazyLoad.settings` containing some configuration. | ||
|
||
If you are just wanting to store potential configuration without enabling it, | ||
you can explicitly disable it setting `lazyLoad.enable = false`. | ||
|
||
When a plugin has lazy loading enabled, the Lua configuration for your plugin | ||
will be passed along to the corresponding lazy provider instead. This behavior | ||
can be overridden by using the `lazyLoad.settings` option that will be passed to | ||
the provider. | ||
|
||
For `Lz.n`, that is the `lazyLoad.settings.after` option. | ||
|
||
## Configuring Triggers | ||
|
||
You need to define the trigger conditions in which a plugin will be loaded. This | ||
is done through the `lazyLoad.settings` option. | ||
|
||
```nix | ||
plugins = { | ||
grug-far = { | ||
enable = true; | ||
lazyLoad = { | ||
settings = { | ||
cmd = "GrugFar"; | ||
}; | ||
}; | ||
}; | ||
}; | ||
``` | ||
|
||
```nix | ||
plugins = { | ||
glow = { | ||
enable = true; | ||
lazyLoad.settings.ft = "markdown"; | ||
}; | ||
``` | ||
|
||
```nix | ||
plugins.toggleterm = { | ||
enable = true; | ||
lazyLoad = { | ||
settings = { | ||
cmd = "ToggleTerm"; | ||
keys = [ | ||
"<leader>tg" | ||
"<leader>gg" | ||
]; | ||
}; | ||
}; | ||
}; | ||
``` | ||
|
||
### Colorschemes | ||
|
||
Colorschemes do not require explicit settings configuration. In `lz-n`, we will | ||
set up the `colorscheme` trigger to the name of the `colorscheme` so that it is | ||
lazy loaded when the `colorscheme` is requested. | ||
|
||
```nix | ||
colorscheme = "catppuccin"; | ||
colorschemes.catppuccin = { | ||
enable = true; | ||
lazyLoad.enable = true; | ||
}; | ||
``` |