mirror of
https://github.com/nix-community/nixvim.git
synced 2025-06-21 00:25:42 +02:00
plugins/yazi: init
This commit is contained in:
parent
c46bd820ad
commit
4852f94f8c
3 changed files with 228 additions and 0 deletions
|
@ -42,6 +42,7 @@
|
|||
./filetrees/chadtree.nix
|
||||
./filetrees/neo-tree.nix
|
||||
./filetrees/nvim-tree.nix
|
||||
./filetrees/yazi.nix
|
||||
|
||||
./git/committia.nix
|
||||
./git/diffview.nix
|
||||
|
|
160
plugins/filetrees/yazi.nix
Normal file
160
plugins/filetrees/yazi.nix
Normal file
|
@ -0,0 +1,160 @@
|
|||
{
|
||||
lib,
|
||||
config,
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
let
|
||||
inherit (lib.nixvim) defaultNullOpts;
|
||||
types = lib.nixvim.nixvimTypes;
|
||||
in
|
||||
lib.nixvim.neovim-plugin.mkNeovimPlugin config {
|
||||
name = "yazi";
|
||||
originalName = "yazi.nvim";
|
||||
defaultPackage = pkgs.vimPlugins.yazi-nvim;
|
||||
|
||||
maintainers = [ lib.maintainers.khaneliman ];
|
||||
|
||||
description = ''
|
||||
Yazi is a blazing fast file manager for the terminal.
|
||||
This plugin allows you to open yazi in a floating window in Neovim.
|
||||
|
||||
Some default keybindings have additional dependencies you may need to install or enable.
|
||||
See the [upstream docs](https://github.com/mikavilpas/yazi.nvim?tab=readme-ov-file#%EF%B8%8F-keybindings) for details.
|
||||
'';
|
||||
|
||||
settingsOptions = {
|
||||
log_level = defaultNullOpts.mkLogLevel' {
|
||||
pluginDefault = "off";
|
||||
description = ''
|
||||
The log level to use. Off by default, but can be used to diagnose
|
||||
issues. You can find the location of the log file by running
|
||||
`:checkhealth yazi` in Neovim.
|
||||
'';
|
||||
};
|
||||
|
||||
open_for_directories = defaultNullOpts.mkBool false "";
|
||||
|
||||
use_ya_for_events_reading = defaultNullOpts.mkBool false ''
|
||||
Use the `ya` command to read events.
|
||||
|
||||
Allows more complex behaviors using the `ya` messaging system.
|
||||
'';
|
||||
|
||||
use_yazi_client_id_flag = defaultNullOpts.mkBool false "Allows passing which instance of yazi is being controlled.";
|
||||
|
||||
enable_mouse_support = defaultNullOpts.mkBool false "Enables mouse support.";
|
||||
|
||||
open_file_function = defaultNullOpts.mkLuaFn' {
|
||||
pluginDefault.__raw = ''
|
||||
function(chosen_file)
|
||||
vim.cmd(string.format("edit %s", vim.fn.fnameescape(chosen_file)))
|
||||
end
|
||||
'';
|
||||
description = ''
|
||||
What Neovim should do a when a file was opened (selected) in yazi.
|
||||
|
||||
Defaults to simply opening the file.
|
||||
'';
|
||||
};
|
||||
|
||||
clipboard_register = defaultNullOpts.mkStr "*" ''
|
||||
Some yazi.nvim commands copy text to the clipboard. This is the register
|
||||
yazi.nvim should use for copying. Defaults to "*", the system clipboard.
|
||||
'';
|
||||
|
||||
keymaps =
|
||||
defaultNullOpts.mkNullable (types.either types.attrs (types.enum [ false ]))
|
||||
{
|
||||
show_help = "<f1>";
|
||||
open_file_in_vertical_split = "<c-v>";
|
||||
open_file_in_horizontal_split = "<c-x>";
|
||||
open_file_in_tab = "<c-t>";
|
||||
grep_in_directory = "<c-s>";
|
||||
replace_in_directory = "<c-g>";
|
||||
cycle_open_buffers = "<tab>";
|
||||
copy_relative_path_to_selected_files = "<c-y>";
|
||||
send_to_quickfix_list = "<c-q>";
|
||||
}
|
||||
''
|
||||
Customize the keymaps that are active when yazi is open and focused.
|
||||
|
||||
Also:
|
||||
- use e.g. `open_file_in_tab = false` to disable a keymap
|
||||
- you can customize only some of the keymaps if you want
|
||||
- Set to `false` to disable all default keymaps.
|
||||
'';
|
||||
|
||||
set_keymappings_function = defaultNullOpts.mkLuaFn null ''
|
||||
Completely override the keymappings for yazi. This function will be
|
||||
called in the context of the yazi terminal buffer.
|
||||
'';
|
||||
|
||||
hooks = {
|
||||
yazi_opened = defaultNullOpts.mkLuaFn' {
|
||||
pluginDefault.__raw = ''
|
||||
function(preselected_path, yazi_buffer_id, config)
|
||||
end
|
||||
'';
|
||||
description = ''
|
||||
If you want to execute a custom action when yazi has been opened,
|
||||
you can define it here.
|
||||
'';
|
||||
};
|
||||
|
||||
yazi_closed_successfully = defaultNullOpts.mkLuaFn' {
|
||||
pluginDefault.__raw = ''
|
||||
function(chosen_file, config, state)
|
||||
end
|
||||
'';
|
||||
description = "When yazi was successfully closed";
|
||||
};
|
||||
|
||||
yazi_opened_multiple_files = defaultNullOpts.mkLuaFn' {
|
||||
pluginDefault.__raw = ''
|
||||
function(chosen_files)
|
||||
vim.cmd("args" .. table.concat(chosen_files, " "))
|
||||
end
|
||||
'';
|
||||
description = ''
|
||||
When yazi opened multiple files. The default is to send them to the
|
||||
quickfix list, but if you want to change that, you can define it here
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
highlight_groups = defaultNullOpts.mkAttributeSet { hovered_buffer = null; } ''
|
||||
Add highlight groups to different yazi events.
|
||||
|
||||
NOTE: this only works if `use_ya_for_events_reading` is enabled, etc.
|
||||
'';
|
||||
|
||||
floating_window_scaling_factor =
|
||||
defaultNullOpts.mkNum 0.9
|
||||
"The floating window scaling factor. 1 means 100%, 0.9 means 90%, etc.";
|
||||
|
||||
yazi_floating_window_winblend = defaultNullOpts.mkNullableWithRaw' {
|
||||
type = types.ints.between 0 100;
|
||||
pluginDefault = 0;
|
||||
description = "`0` for fully opaque and `100` for fully transparent. See :h winblend";
|
||||
};
|
||||
|
||||
yazi_floating_window_border = defaultNullOpts.mkBorder "rounded" "yazi" ''
|
||||
The type of border to use for the floating window.
|
||||
|
||||
Supports all available border types from `vim.api.keyset.win_config.border`.
|
||||
'';
|
||||
};
|
||||
|
||||
settingsExample = {
|
||||
log_level = "debug";
|
||||
open_for_directories = true;
|
||||
enable_mouse_support = true;
|
||||
floating_window_scaling_factor = 0.5;
|
||||
yazi_floating_window_border = "single";
|
||||
yazi_floating_window_winblend = 50;
|
||||
};
|
||||
|
||||
# TODO: remove when https://github.com/NixOS/nixpkgs/pull/333506 is available
|
||||
extraPlugins = with pkgs.vimPlugins; [ plenary-nvim ];
|
||||
}
|
67
tests/test-sources/plugins/filetrees/yazi.nix
Normal file
67
tests/test-sources/plugins/filetrees/yazi.nix
Normal file
|
@ -0,0 +1,67 @@
|
|||
{
|
||||
empty = {
|
||||
plugins.yazi.enable = true;
|
||||
};
|
||||
|
||||
defaults = {
|
||||
plugins.yazi = {
|
||||
enable = true;
|
||||
|
||||
settings = {
|
||||
log_level = "off";
|
||||
open_for_directories = false;
|
||||
use_ya_for_events_reading = false;
|
||||
use_yazi_client_id_flag = false;
|
||||
enable_mouse_support = false;
|
||||
|
||||
open_file_function.__raw = ''
|
||||
function(chosen_file)
|
||||
vim.cmd(string.format("edit %s", vim.fn.fnameescape(chosen_file)))
|
||||
end
|
||||
'';
|
||||
|
||||
clipboard_register = "*";
|
||||
|
||||
keymaps = {
|
||||
show_help = "<f1>";
|
||||
open_file_in_vertical_split = "<c-v>";
|
||||
open_file_in_horizontal_split = "<c-x>";
|
||||
open_file_in_tab = "<c-t>";
|
||||
grep_in_directory = "<c-s>";
|
||||
replace_in_directory = "<c-g>";
|
||||
cycle_open_buffers = "<tab>";
|
||||
copy_relative_path_to_selected_files = "<c-y>";
|
||||
send_to_quickfix_list = "<c-q>";
|
||||
};
|
||||
|
||||
set_keymappings_function = null;
|
||||
|
||||
hooks = {
|
||||
yazi_opened.__raw = ''
|
||||
function(preselected_path, yazi_buffer_id, config)
|
||||
end
|
||||
'';
|
||||
|
||||
yazi_closed_successfully.__raw = ''
|
||||
function(chosen_file, config, state)
|
||||
end
|
||||
'';
|
||||
|
||||
yazi_opened_multiple_files.__raw = ''
|
||||
function(chosen_files)
|
||||
vim.cmd("args" .. table.concat(chosen_files, " "))
|
||||
end
|
||||
'';
|
||||
};
|
||||
|
||||
highlight_groups = {
|
||||
hovered_buffer = null;
|
||||
};
|
||||
|
||||
floating_window_scaling_factor = 0.9;
|
||||
yazi_floating_window_winblend = 0;
|
||||
yazi_floating_window_border = "rounded";
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue