nvim-config/lua/kickstart/plugins/which-key.lua

59 lines
2.8 KiB
Lua
Raw Normal View History

-- NOTE: Plugins can also be configured to run Lua code when they are loaded.
--
-- This is often very useful to both group configuration, as well as handle
-- lazy loading plugins that don't need to be loaded immediately at startup.
--
-- For example, in the following configuration, we use:
-- event = 'VimEnter'
--
-- which loads which-key before all the UI elements are loaded. Events can be
-- normal autocommands events (`:help autocmd-events`).
--
-- Then, because we use the `config` key, the configuration only runs
-- after the plugin has been loaded:
-- config = function() ... end
return {
{ -- Useful plugin to show you pending keybinds.
'folke/which-key.nvim',
event = 'VimEnter', -- Sets the loading event to 'VimEnter'
config = function() -- This is the function that runs, AFTER loading
require('which-key').setup()
-- Document existing key chains
require('which-key').register {
['<leader>r'] = { name = '[R]ename', _ = 'which_key_ignore' },
['<leader>s'] = { name = '[S]earch', _ = 'which_key_ignore' },
['<leader>w'] = { name = '[W]orkspace', _ = 'which_key_ignore' },
2024-07-03 10:39:17 +00:00
['<leader>g'] = { name = '[G]it/[G]lobal', _ = 'which_key_ignore' },
2024-04-05 18:31:21 +00:00
['<leader>b'] = { name = '[B]uffer/[B]reakpoint', _ = 'which_key_ignore' },
2024-04-11 06:59:28 +00:00
['<leader>c'] = { name = '[C]ode/[C]odeium/[C]hange', _ = 'which_key_ignore' },
2024-04-08 13:09:38 +00:00
['<leader>cd'] = { name = '[D]irectory', _ = 'which_key_ignore' },
2024-04-05 18:31:21 +00:00
['<leader>d'] = { name = '[D]ocument/[D]elete', _ = 'which_key_ignore' },
['<leader>h'] = { name = 'Git [H]unk/[H]arpoon', _ = 'which_key_ignore' },
2024-04-05 18:31:21 +00:00
['<leader>t'] = { name = '[T]oggle', _ = 'which_key_ignore' },
['<leader>dn'] = { name = '[N]o', _ = 'which_key_ignore' },
2024-04-30 06:59:28 +00:00
['<leader>l'] = { name = '[L]ist', _ = 'which_key_ignore' },
['<leader>f'] = { name = '[F]ormat/[F]ile', _ = 'which_key_ignore' },
['<leader>o'] = { name = '[O]verseer', _ = 'which_key_ignore' },
}
-- register which-key VISUAL mode
-- required for visual <leader>hs (hunk stage) to work
require('which-key').register({
['<leader>'] = { name = 'VISUAL <leader>' },
['<leader>h'] = { 'Git [H]unk' },
2024-04-03 18:38:51 +00:00
['<leader>d'] = { name = '[D]elete', _ = 'which_key_ignore' },
2024-04-03 18:39:35 +00:00
['<leader>p'] = { name = '[P]aste', _ = 'which_key_ignore' },
2024-04-05 18:31:21 +00:00
['<leader>t'] = { name = '[T]oggle', _ = 'which_key_ignore' },
2024-04-03 18:38:51 +00:00
['<leader>dn'] = { name = '[N]o', _ = 'which_key_ignore' },
2024-04-03 18:39:35 +00:00
['<leader>pn'] = { name = '[N]o', _ = 'which_key_ignore' },
2024-04-30 06:59:28 +00:00
['<leader>l'] = { name = '[L]ist', _ = 'which_key_ignore' },
['<leader>f'] = { name = '[F]ormat/[F]ile', _ = 'which_key_ignore' },
2024-07-03 10:39:17 +00:00
['<leader>g'] = { name = '[G]lobal', _ = 'which_key_ignore' },
}, { mode = 'v' })
end,
},
}
-- vim: ts=2 sts=2 sw=2 et