From 8aeef79b636e60a4470b0bb13b1f6fb317ca1deb Mon Sep 17 00:00:00 2001 From: Manuel Sanchez Pinar Date: Sat, 30 Dec 2023 10:26:56 +0100 Subject: [PATCH] feat(keybinds): add `opts` arg to `remap(_event)` --- lua/neorg/modules/core/keybinds/module.lua | 32 ++++++++++++++++------ 1 file changed, 24 insertions(+), 8 deletions(-) diff --git a/lua/neorg/modules/core/keybinds/module.lua b/lua/neorg/modules/core/keybinds/module.lua index 2b6ff515f..cc252c27f 100644 --- a/lua/neorg/modules/core/keybinds/module.lua +++ b/lua/neorg/modules/core/keybinds/module.lua @@ -228,7 +228,13 @@ module.public = { bound_keys[neorg_mode][mode][key] = bound_keys[neorg_mode][mode][key] and nil end, - remap = function(neorg_mode, mode, key, new_rhs) + --- Remaps a key to a specific Neorg mode + ---@param neorg_mode string #The Neorg mode to bind to + ---@param mode string #The Neovim mode to bind to, e.g. `n` or `i` etc. + ---@param key string #The lhs value from `:h vim.keymap.set` + ---@param new_rhs string|function #The rhs value from `:h vim.keymap.set` + ---@param opts table #The table value from `:h vim.keymap.set` + remap = function(neorg_mode, mode, key, new_rhs, opts) if neorg_mode ~= "all" and current_mode ~= neorg_mode then return end @@ -237,12 +243,24 @@ module.public = { bound_keys[neorg_mode][mode] = bound_keys[neorg_mode][mode] or {} bound_keys[neorg_mode][mode][key] = bound_keys[neorg_mode][mode][key] or {} - local opts = bound_keys[neorg_mode][mode][key].opts - - payload.map(neorg_mode, mode, key, new_rhs, opts) + payload.map( + neorg_mode, + mode, + key, + new_rhs, + vim.tbl_deep_extend("force", bound_keys[neorg_mode][mode][key].opts or {}, opts or {}) + ) end, - remap_event = function(neorg_mode, mode, key, new_event) + --- Remaps a key to a specific Neorg keybind. + -- `remap()` binds to any rhs value, whilst `remap_event()` is essentially a wrapper + -- for Neorg keybind `neorg_mode` `expr` + ---@param neorg_mode string #The Neorg mode to bind to + ---@param mode string #The Neovim mode to bind to, e.g. `n` or `i` etc. + ---@param key string #The lhs value from `:h vim.keymap.set` + ---@param new_event string #The Neorg event to bind to (e.g. `core.dirman.new.note`) + ---@param opts table #The table value from `:h vim.keymap.set` + remap_event = function(neorg_mode, mode, key, new_event, opts) if neorg_mode ~= "all" and current_mode ~= neorg_mode then return end @@ -251,14 +269,12 @@ module.public = { bound_keys[neorg_mode][mode] = bound_keys[neorg_mode][mode] or {} bound_keys[neorg_mode][mode][key] = bound_keys[neorg_mode][mode][key] or {} - local opts = bound_keys[neorg_mode][mode][key].opts - payload.map( neorg_mode, mode, key, "Neorg keybind " .. neorg_mode .. " " .. new_event .. "", - opts + vim.tbl_deep_extend("force", bound_keys[neorg_mode][mode][key].opts or {}, opts or {}) ) end,