init.lua 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. -- if not package.loaded['which-key'] then
  2. -- return
  3. -- end
  4. local status_ok, which_key = pcall(require, "which-key")
  5. if not status_ok then
  6. return
  7. end
  8. which_key.setup {
  9. plugins = {
  10. marks = true, -- shows a list of your marks on ' and `
  11. registers = true, -- shows your registers on " in NORMAL or <C-r> in INSERT mode
  12. -- the presets plugin, adds help for a bunch of default keybindings in Neovim
  13. -- No actual key bindings are created
  14. presets = {
  15. operators = false, -- adds help for operators like d, y, ...
  16. motions = false, -- adds help for motions
  17. text_objects = false, -- help for text objects triggered after entering an operator
  18. windows = true, -- default bindings on <c-w>
  19. nav = true, -- misc bindings to work with windows
  20. z = true, -- bindings for folds, spelling and others prefixed with z
  21. g = true, -- bindings for prefixed with g
  22. },
  23. },
  24. icons = {
  25. breadcrumb = "»", -- symbol used in the command line area that shows your active key combo
  26. separator = "➜", -- symbol used between a key and it's label
  27. group = "+", -- symbol prepended to a group
  28. },
  29. window = {
  30. border = "single", -- none, single, double, shadow
  31. position = "bottom", -- bottom, top
  32. margin = { 1, 0, 1, 0 }, -- extra window margin [top, right, bottom, left]
  33. padding = { 2, 2, 2, 2 }, -- extra window padding [top, right, bottom, left]
  34. },
  35. layout = {
  36. height = { min = 4, max = 25 }, -- min and max height of the columns
  37. width = { min = 20, max = 50 }, -- min and max width of the columns
  38. spacing = 3, -- spacing between columns
  39. },
  40. hidden = { "<silent>", "<cmd>", "<Cmd>", "<CR>", "call", "lua", "^:", "^ " }, -- hide mapping boilerplate
  41. show_help = true, -- show help message on the command line when the popup is visible
  42. }
  43. -- Set leader
  44. if O.leader_key == " " or O.leader_key == "space" then
  45. vim.api.nvim_set_keymap("n", "<Space>", "<NOP>", { noremap = true, silent = true })
  46. vim.g.mapleader = " "
  47. else
  48. vim.api.nvim_set_keymap("n", O.leader_key, "<NOP>", { noremap = true, silent = true })
  49. vim.g.mapleader = O.leader_key
  50. end
  51. local opts = {
  52. mode = "n", -- NORMAL mode
  53. prefix = "<leader>",
  54. buffer = nil, -- Global mappings. Specify a buffer number for buffer local mappings
  55. silent = true, -- use `silent` when creating keymaps
  56. noremap = true, -- use `noremap` when creating keymaps
  57. nowait = false, -- use `nowait` when creating keymaps
  58. }
  59. -- no hl
  60. vim.api.nvim_set_keymap("n", "<Leader>h", ':let @/=""<CR>', { noremap = true, silent = true })
  61. -- explorer
  62. vim.api.nvim_set_keymap(
  63. "n",
  64. "<Leader>e",
  65. ":lua require'lv-nvimtree'.toggle_tree()<CR>",
  66. { noremap = true, silent = true }
  67. )
  68. vim.api.nvim_set_keymap("n", "<Leader>f", ":Telescope find_files<CR>", { noremap = true, silent = true })
  69. -- dashboard
  70. vim.api.nvim_set_keymap("n", "<Leader>;", ":Dashboard<CR>", { noremap = true, silent = true })
  71. -- Comments
  72. vim.api.nvim_set_keymap("n", "<leader>/", ":CommentToggle<CR>", { noremap = true, silent = true })
  73. vim.api.nvim_set_keymap("v", "<leader>/", ":CommentToggle<CR>", { noremap = true, silent = true })
  74. -- close buffer
  75. vim.api.nvim_set_keymap("n", "<leader>c", ":BufferClose<CR>", { noremap = true, silent = true })
  76. -- open lv-config
  77. vim.api.nvim_set_keymap(
  78. "n",
  79. "<leader>.",
  80. ":e " .. CONFIG_PATH .. "/lv-config.lua<CR>",
  81. { noremap = true, silent = true }
  82. )
  83. local mappings = {
  84. ["."] = "LunarConfig",
  85. ["/"] = "Comment",
  86. ["c"] = "Close Buffer",
  87. ["e"] = "Explorer",
  88. ["f"] = "Find File",
  89. ["h"] = "No Highlight",
  90. [";"] = "Dashboard",
  91. b = {
  92. name = "Buffers",
  93. j = { "<cmd>BufferPick<cr>", "jump to buffer" },
  94. f = { "<cmd>Telescope buffers<cr>", "Find buffer" },
  95. w = { "<cmd>BufferWipeout<cr>", "wipeout buffer" },
  96. e = {
  97. "<cmd>BufferCloseAllButCurrent<cr>",
  98. "close all but current buffer",
  99. },
  100. h = { "<cmd>BufferCloseBuffersLeft<cr>", "close all buffers to the left" },
  101. l = {
  102. "<cmd>BufferCloseBuffersRight<cr>",
  103. "close all BufferLines to the right",
  104. },
  105. D = {
  106. "<cmd>BufferOrderByDirectory<cr>",
  107. "sort BufferLines automatically by directory",
  108. },
  109. L = {
  110. "<cmd>BufferOrderByLanguage<cr>",
  111. "sort BufferLines automatically by language",
  112. },
  113. },
  114. p = {
  115. name = "Packer",
  116. c = { "<cmd>PackerCompile<cr>", "Compile" },
  117. i = { "<cmd>PackerInstall<cr>", "Install" },
  118. r = { "<cmd>lua require('lv-utils').reload_lv_config()<cr>", "Reload" },
  119. s = { "<cmd>PackerSync<cr>", "Sync" },
  120. u = { "<cmd>PackerUpdate<cr>", "Update" },
  121. },
  122. -- " Available Debug Adapters:
  123. -- " https://microsoft.github.io/debug-adapter-protocol/implementors/adapters/
  124. -- " Adapter configuration and installation instructions:
  125. -- " https://github.com/mfussenegger/nvim-dap/wiki/Debug-Adapter-installation
  126. -- " Debug Adapter protocol:
  127. -- " https://microsoft.github.io/debug-adapter-protocol/
  128. -- " Debugging
  129. d = {
  130. name = "Debug",
  131. t = { "<cmd>lua require'dap'.toggle_breakpoint()<cr>", "Toggle Breakpoint" },
  132. b = { "<cmd>lua require'dap'.step_back()<cr>", "Step Back" },
  133. c = { "<cmd>lua require'dap'.continue()<cr>", "Continue" },
  134. C = { "<cmd>lua require'dap'.run_to_cursor()<cr>", "Run To Cursor" },
  135. d = { "<cmd>lua require'dap'.disconnect()<cr>", "Disconnect" },
  136. g = { "<cmd>lua require'dap'.session()<cr>", "Get Session" },
  137. i = { "<cmd>lua require'dap'.step_into()<cr>", "Step Into" },
  138. o = { "<cmd>lua require'dap'.step_over()<cr>", "Step Over" },
  139. u = { "<cmd>lua require'dap'.step_out()<cr>", "Step Out" },
  140. p = { "<cmd>lua require'dap'.pause.toggle()<cr>", "Pause" },
  141. r = { "<cmd>lua require'dap'.repl.toggle()<cr>", "Toggle Repl" },
  142. s = { "<cmd>lua require'dap'.continue()<cr>", "Start" },
  143. q = { "<cmd>lua require'dap'.stop()<cr>", "Quit" },
  144. },
  145. g = {
  146. name = "Git",
  147. j = { "<cmd>lua require 'gitsigns'.next_hunk()<cr>", "Next Hunk" },
  148. k = { "<cmd>lua require 'gitsigns'.prev_hunk()<cr>", "Prev Hunk" },
  149. l = { "<cmd>lua require 'gitsigns'.blame_line()<cr>", "Blame" },
  150. p = { "<cmd>lua require 'gitsigns'.preview_hunk()<cr>", "Preview Hunk" },
  151. r = { "<cmd>lua require 'gitsigns'.reset_hunk()<cr>", "Reset Hunk" },
  152. R = { "<cmd>lua require 'gitsigns'.reset_buffer()<cr>", "Reset Buffer" },
  153. s = { "<cmd>lua require 'gitsigns'.stage_hunk()<cr>", "Stage Hunk" },
  154. u = {
  155. "<cmd>lua require 'gitsigns'.undo_stage_hunk()<cr>",
  156. "Undo Stage Hunk",
  157. },
  158. o = { "<cmd>Telescope git_status<cr>", "Open changed file" },
  159. b = { "<cmd>Telescope git_branches<cr>", "Checkout branch" },
  160. c = { "<cmd>Telescope git_commits<cr>", "Checkout commit" },
  161. C = {
  162. "<cmd>Telescope git_bcommits<cr>",
  163. "Checkout commit(for current file)",
  164. },
  165. },
  166. l = {
  167. name = "LSP",
  168. a = { "<cmd>lua vim.lsp.buf.code_action()<cr>", "Code Action" },
  169. d = {
  170. "<cmd>Telescope lsp_document_diagnostics<cr>",
  171. "Document Diagnostics",
  172. },
  173. w = {
  174. "<cmd>Telescope lsp_workspace_diagnostics<cr>",
  175. "Workspace Diagnostics",
  176. },
  177. f = { "<cmd>Neoformat<cr>", "Format" },
  178. i = { "<cmd>LspInfo<cr>", "Info" },
  179. j = { "<cmd>lua vim.lsp.diagnostic.goto_next({popup_opts = {border = O.lsp.popup_border}})<cr>", "Next Diagnostic" },
  180. k = { "<cmd>lua vim.lsp.diagnostic.goto_prev({popup_opts = {border = O.lsp.popup_border}})<cr>", "Prev Diagnostic" },
  181. q = { "<cmd>Telescope quickfix<cr>", "Quickfix" },
  182. r = { "<cmd>lua vim.lsp.buf.rename()<cr>", "Rename" },
  183. s = {
  184. O.plugin.symbol_outline.active and "<cmd>SymbolsOutline<cr>" or "<cmd> Telescope lsp_document_symbols<cr>",
  185. "Document Symbols",
  186. },
  187. S = {
  188. "<cmd>Telescope lsp_dynamic_workspace_symbols<cr>",
  189. "Workspace Symbols",
  190. },
  191. },
  192. s = {
  193. name = "Search",
  194. b = { "<cmd>Telescope git_branches<cr>", "Checkout branch" },
  195. c = { "<cmd>Telescope colorscheme<cr>", "Colorscheme" },
  196. f = { "<cmd>Telescope find_files<cr>", "Find File" },
  197. h = { "<cmd>Telescope help_tags<cr>", "Find Help" },
  198. M = { "<cmd>Telescope man_pages<cr>", "Man Pages" },
  199. r = { "<cmd>Telescope oldfiles<cr>", "Open Recent File" },
  200. R = { "<cmd>Telescope registers<cr>", "Registers" },
  201. t = { "<cmd>Telescope live_grep<cr>", "Text" },
  202. },
  203. S = {
  204. name = "Session",
  205. s = { "<cmd>SessionSave<cr>", "Save Session" },
  206. l = { "<cmd>SessionLoad<cr>", "Load Session" },
  207. },
  208. T = {
  209. name = "Treesitter",
  210. i = { ":TSConfigInfo<cr>", "Info" },
  211. },
  212. }
  213. -- if O.plugin.trouble.active then
  214. -- mappings["d"] = {
  215. -- name = "Diagnostics",
  216. -- t = { "<cmd>TroubleToggle<cr>", "trouble" },
  217. -- w = { "<cmd>TroubleToggle lsp_workspace_diagnostics<cr>", "workspace" },
  218. -- d = { "<cmd>TroubleToggle lsp_document_diagnostics<cr>", "document" },
  219. -- q = { "<cmd>TroubleToggle quickfix<cr>", "quickfix" },
  220. -- l = { "<cmd>TroubleToggle loclist<cr>", "loclist" },
  221. -- r = { "<cmd>TroubleToggle lsp_references<cr>", "references" },
  222. -- }
  223. -- end
  224. if O.plugin.symbol_outline.active then
  225. vim.api.nvim_set_keymap("n", "<leader>o", ":SymbolsOutline<CR>", { noremap = true, silent = true })
  226. mappings["o"] = "Symbols outline"
  227. end
  228. if O.plugin.ts_playground.active then
  229. vim.api.nvim_set_keymap("n", "<leader>Th", ":TSHighlightCapturesUnderCursor<CR>", { noremap = true, silent = true })
  230. mappings[""] = "Highlight Capture"
  231. end
  232. if O.plugin.zen.active then
  233. vim.api.nvim_set_keymap("n", "<leader>z", ":ZenMode<CR>", { noremap = true, silent = true })
  234. mappings["z"] = "Zen"
  235. end
  236. if O.plugin.floatterm.active then
  237. vim.api.nvim_set_keymap("n", "<leader>gg", "<CMD>lua _G.__fterm_lazygit()<CR>", { noremap = true, silent = true })
  238. vim.api.nvim_set_keymap("n", "<A-i>", "<CMD>lua require('FTerm').toggle()<CR>", { noremap = true, silent = true })
  239. vim.api.nvim_set_keymap(
  240. "t",
  241. "<A-i>",
  242. "<C-\\><C-n><CMD>lua require('FTerm').toggle()<CR>",
  243. { noremap = true, silent = true }
  244. )
  245. vim.api.nvim_set_keymap("n", "<A-l>", "<CMD>lua _G.__fterm_lazygit()<CR>", { noremap = true, silent = true })
  246. vim.api.nvim_set_keymap(
  247. "t",
  248. "<A-l>",
  249. "<C-\\><C-n><CMD>lua _G.__fterm_lazygit()<CR>",
  250. { noremap = true, silent = true }
  251. )
  252. mappings["gg"] = "LazyGit"
  253. end
  254. if O.plugin.telescope_project.active then
  255. -- open projects
  256. vim.api.nvim_set_keymap(
  257. "n",
  258. "<leader>P",
  259. ":lua require'telescope'.extensions.project.project{}<CR>",
  260. { noremap = true, silent = true }
  261. )
  262. mappings["P"] = "Projects"
  263. end
  264. -- [";"] = "Dashboard",
  265. if O.lang.latex.active then
  266. mappings["L"] = {
  267. name = "+Latex",
  268. c = { "<cmd>VimtexCompile<cr>", "Toggle Compilation Mode" },
  269. f = { "<cmd>call vimtex#fzf#run()<cr>", "Fzf Find" },
  270. i = { "<cmd>VimtexInfo<cr>", "Project Information" },
  271. s = { "<cmd>VimtexStop<cr>", "Stop Project Compilation" },
  272. t = { "<cmd>VimtexTocToggle<cr>", "Toggle Table Of Content" },
  273. v = { "<cmd>VimtexView<cr>", "View PDF" },
  274. }
  275. end
  276. if O.lushmode then
  277. mappings["L"] = {
  278. name = "+Lush",
  279. l = { ":Lushify<cr>", "Lushify" },
  280. x = { ":lua require('lush').export_to_buffer(require('lush_theme.cool_name'))", "Lush Export" },
  281. t = { ":LushRunTutorial<cr>", "Lush Tutorial" },
  282. q = { ":LushRunQuickstart<cr>", "Lush Quickstart" },
  283. }
  284. end
  285. -- for _, v in pairs(O.user_which_key) do
  286. -- end
  287. for k, v in pairs(O.user_which_key) do
  288. mappings[k] = v
  289. -- table.insert(mappings, O.user_which_key[1])
  290. -- print(k)
  291. -- print(v)
  292. end
  293. local wk = require "which-key"
  294. wk.register(mappings, opts)