keymappings.lua 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. local M = {}
  2. local generic_opts_any = { noremap = true, silent = true }
  3. local mode_adapters = {
  4. insert_mode = "i",
  5. normal_mode = "n",
  6. term_mode = "t",
  7. visual_mode = "v",
  8. visual_block_mode = "x",
  9. }
  10. -- Append key mappings to lunarvim's defaults for a given mode
  11. -- @param keymaps The table of key mappings containing a list per mode (normal_mode, insert_mode, ..)
  12. function M.append_to_defaults(keymaps)
  13. for mode, mappings in pairs(keymaps) do
  14. for k, v in ipairs(mappings) do
  15. lvim.keys[mode][k] = v
  16. end
  17. end
  18. end
  19. -- Load key mappings for a given mode
  20. -- @param mode The keymap mode, can be one of the keys of mode_adapters
  21. -- @param keymaps The list of key mappings
  22. -- @param opts The mapping options
  23. function M.load_mode(mode, keymaps, opts)
  24. mode = mode_adapters[mode] and mode_adapters[mode] or mode
  25. for k, v in pairs(keymaps) do
  26. vim.api.nvim_set_keymap(mode, k, v, opts)
  27. end
  28. end
  29. -- Load key mappings for all provided modes
  30. -- @param keymaps A list of key mappings for each mode
  31. -- @param opts The mapping options for each mode
  32. function M.load(keymaps, opts)
  33. for mode, mapping in pairs(keymaps) do
  34. M.load_mode(mode, mapping, opts[mode])
  35. end
  36. end
  37. function M.config()
  38. lvim.keys = {
  39. ---@usage change or add keymappings for insert mode
  40. insert_mode = {
  41. -- 'jk' for quitting insert mode
  42. ["jk"] = "<ESC>",
  43. -- 'kj' for quitting insert mode
  44. ["kj"] = "<ESC>",
  45. -- 'jj' for quitting insert mode
  46. ["jj"] = "<ESC>",
  47. -- Move current line / block with Alt-j/k ala vscode.
  48. ["<A-j>"] = "<Esc>:m .+1<CR>==gi",
  49. -- Move current line / block with Alt-j/k ala vscode.
  50. ["<A-k>"] = "<Esc>:m .-2<CR>==gi",
  51. -- navigation
  52. ["<A-Up>"] = "<C-\\><C-N><C-w>k",
  53. ["<A-Down>"] = "<C-\\><C-N><C-w>j",
  54. ["<A-Left>"] = "<C-\\><C-N><C-w>h",
  55. ["<A-Right>"] = "<C-\\><C-N><C-w>l",
  56. },
  57. ---@usage change or add keymappings for normal mode
  58. normal_mode = {
  59. -- Better window movement
  60. ["<C-h>"] = "<C-w>h",
  61. ["<C-j>"] = "<C-w>j",
  62. ["<C-k>"] = "<C-w>k",
  63. ["<C-l>"] = "<C-w>l",
  64. -- Resize with arrows
  65. ["<C-Up>"] = ":resize -2<CR>",
  66. ["<C-Down>"] = ":resize +2<CR>",
  67. ["<C-Left>"] = ":vertical resize -2<CR>",
  68. ["<C-Right>"] = ":vertical resize +2<CR>",
  69. -- Tab switch buffer
  70. ["<S-l>"] = ":BufferNext<CR>",
  71. ["<S-h>"] = ":BufferPrevious<CR>",
  72. -- Move current line / block with Alt-j/k a la vscode.
  73. ["<A-j>"] = ":m .+1<CR>==",
  74. ["<A-k>"] = ":m .-2<CR>==",
  75. -- QuickFix
  76. ["]q"] = ":cnext<CR>",
  77. ["[q"] = ":cprev<CR>",
  78. ["<C-q>"] = ":call QuickFixToggle()<CR>",
  79. },
  80. ---@usage change or add keymappings for terminal mode
  81. term_mode = {
  82. -- Terminal window navigation
  83. ["<C-h>"] = "<C-\\><C-N><C-w>h",
  84. ["<C-j>"] = "<C-\\><C-N><C-w>j",
  85. ["<C-k>"] = "<C-\\><C-N><C-w>k",
  86. ["<C-l>"] = "<C-\\><C-N><C-w>l",
  87. },
  88. ---@usage change or add keymappings for visual mode
  89. visual_mode = {
  90. -- Better indenting
  91. ["<"] = "<gv",
  92. [">"] = ">gv",
  93. -- ["p"] = '"0p',
  94. -- ["P"] = '"0P',
  95. },
  96. ---@usage change or add keymappings for visual block mode
  97. visual_block_mode = {
  98. -- Move selected line / block of text in visual mode
  99. ["K"] = ":move '<-2<CR>gv-gv",
  100. ["J"] = ":move '>+1<CR>gv-gv",
  101. -- Move current line / block with Alt-j/k ala vscode.
  102. ["<A-j>"] = ":m '>+1<CR>gv-gv",
  103. ["<A-k>"] = ":m '<-2<CR>gv-gv",
  104. },
  105. }
  106. if vim.fn.has "mac" == 1 then
  107. lvim.keys.normal_mode["<A-Up>"] = lvim.keys.normal_mode["<C-Up>"]
  108. lvim.keys.normal_mode["<A-Down>"] = lvim.keys.normal_mode["<C-Down>"]
  109. lvim.keys.normal_mode["<A-Left>"] = lvim.keys.normal_mode["<C-Left>"]
  110. lvim.keys.normal_mode["<A-Right>"] = lvim.keys.normal_mode["<C-Right>"]
  111. end
  112. end
  113. function M.print(mode)
  114. print "List of LunarVim's default keymappings (not including which-key)"
  115. if mode then
  116. print(vim.inspect(lvim.keys[mode]))
  117. else
  118. print(vim.inspect(lvim.keys))
  119. end
  120. end
  121. function M.setup()
  122. -- navigate tab completion with <c-j> and <c-k>
  123. -- runs conditionally
  124. vim.cmd 'inoremap <expr> <C-j> pumvisible() ? "\\<C-n>" : "\\<C-j>"'
  125. vim.cmd 'inoremap <expr> <C-k> pumvisible() ? "\\<C-p>" : "\\<C-k>"'
  126. local generic_opts = {
  127. insert_mode = generic_opts_any,
  128. normal_mode = generic_opts_any,
  129. visual_mode = generic_opts_any,
  130. visual_block_mode = generic_opts_any,
  131. term_mode = { silent = true },
  132. }
  133. vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader
  134. M.load(lvim.keys, generic_opts)
  135. end
  136. return M