| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331 | -- if not package.loaded['which-key'] then--  return-- endrequire("which-key").setup {  plugins = {    marks = true, -- shows a list of your marks on ' and `    registers = true, -- shows your registers on " in NORMAL or <C-r> in INSERT mode    -- the presets plugin, adds help for a bunch of default keybindings in Neovim    -- No actual key bindings are created    presets = {      operators = false, -- adds help for operators like d, y, ...      motions = false, -- adds help for motions      text_objects = false, -- help for text objects triggered after entering an operator      windows = true, -- default bindings on <c-w>      nav = true, -- misc bindings to work with windows      z = true, -- bindings for folds, spelling and others prefixed with z      g = true, -- bindings for prefixed with g    },  },  icons = {    breadcrumb = "»", -- symbol used in the command line area that shows your active key combo    separator = "➜", -- symbol used between a key and it's label    group = "+", -- symbol prepended to a group  },  window = {    border = "single", -- none, single, double, shadow    position = "bottom", -- bottom, top    margin = { 1, 0, 1, 0 }, -- extra window margin [top, right, bottom, left]    padding = { 2, 2, 2, 2 }, -- extra window padding [top, right, bottom, left]  },  layout = {    height = { min = 4, max = 25 }, -- min and max height of the columns    width = { min = 20, max = 50 }, -- min and max width of the columns    spacing = 3, -- spacing between columns  },  hidden = { "<silent>", "<cmd>", "<Cmd>", "<CR>", "call", "lua", "^:", "^ " }, -- hide mapping boilerplate  show_help = true, -- show help message on the command line when the popup is visible}-- Set leaderif O.leader_key == " " or O.leader_key == "space" then  vim.api.nvim_set_keymap("n", "<Space>", "<NOP>", { noremap = true, silent = true })  vim.g.mapleader = " "else  vim.api.nvim_set_keymap("n", O.leader_key, "<NOP>", { noremap = true, silent = true })  vim.g.mapleader = O.leader_keyendlocal opts = {  mode = "n", -- NORMAL mode  prefix = "<leader>",  buffer = nil, -- Global mappings. Specify a buffer number for buffer local mappings  silent = true, -- use `silent` when creating keymaps  noremap = true, -- use `noremap` when creating keymaps  nowait = false, -- use `nowait` when creating keymaps}-- no hlvim.api.nvim_set_keymap("n", "<Leader>h", ':let @/=""<CR>', { noremap = true, silent = true })-- explorer-- TODO this introduces some bugs unfortunatelyvim.api.nvim_set_keymap(  "n",  "<Leader>e",  ":lua require'lv-nvimtree'.toggle_tree()<CR>",  { noremap = true, silent = true })-- vim.api.nvim_set_keymap('n', '<Leader>e',--                         ":NvimTreeToggle<CR>",--                         {noremap = true, silent = true})-- telescope or snapif O.plugin.snap.active then  vim.api.nvim_set_keymap("n", "<Leader>f", ":Snap find_files<CR>", { noremap = true, silent = true })else  vim.api.nvim_set_keymap("n", "<Leader>f", ":Telescope find_files<CR>", { noremap = true, silent = true })end-- dashboardvim.api.nvim_set_keymap("n", "<Leader>;", ":Dashboard<CR>", { noremap = true, silent = true })-- Commentsvim.api.nvim_set_keymap("n", "<leader>/", ":CommentToggle<CR>", { noremap = true, silent = true })vim.api.nvim_set_keymap("v", "<leader>/", ":CommentToggle<CR>", { noremap = true, silent = true })-- close buffervim.api.nvim_set_keymap("n", "<leader>c", ":bdelete<CR>", { noremap = true, silent = true })-- TODO create entire treesitter sectionlocal mappings = {  ["/"] = "Comment",  ["c"] = "Close Buffer",  ["e"] = "Explorer",  ["f"] = "Find File",  ["h"] = "No Highlight",  b = {    name = "Buffers",    j = { "<cmd>BufferPick<cr>", "jump to buffer" },    f = { O.plugin.snap.active and "<cmd>Snap buffers<cr>" or "<cmd>Telescope buffers<cr>", "Find buffer" },    w = { "<cmd>BufferWipeout<cr>", "wipeout buffer" },    e = {      "<cmd>BufferCloseAllButCurrent<cr>",      "close all but current buffer",    },    h = { "<cmd>BufferCloseBuffersLeft<cr>", "close all buffers to the left" },    l = {      "<cmd>BufferCloseBuffersRight<cr>",      "close all BufferLines to the right",    },    D = {      "<cmd>BufferOrderByDirectory<cr>",      "sort BufferLines automatically by directory",    },    L = {      "<cmd>BufferOrderByLanguage<cr>",      "sort BufferLines automatically by language",    },  },  -- diagnostics vanilla nvim  -- -- diagnostic  -- function lv_utils.get_all()  --     vim.lsp.diagnostic.get_all()  -- end  -- function lv_utils.get_next()  --     vim.lsp.diagnostic.get_next()  -- end  -- function lv_utils.get_prev()  --     vim.lsp.diagnostic.get_prev()  -- end  -- function lv_utils.goto_next()  --     vim.lsp.diagnostic.goto_next()  -- end  -- function lv_utils.goto_prev()  --     vim.lsp.diagnostic.goto_prev()  -- end  -- function lv_utils.show_line_diagnostics()  --     vim.lsp.diagnostic.show_line_diagnostics()  -- end  -- " Available Debug Adapters:  -- "   https://microsoft.github.io/debug-adapter-protocol/implementors/adapters/  -- " Adapter configuration and installation instructions:  -- "   https://github.com/mfussenegger/nvim-dap/wiki/Debug-Adapter-installation  -- " Debug Adapter protocol:  -- "   https://microsoft.github.io/debug-adapter-protocol/  -- " Debugging  -- command! DebugToggleBreakpoint lua require'dap'.toggle_breakpoint()  -- command! DebugStart lua require'dap'.continue()  -- command! DebugContinue lua require'dap'.continue()  -- command! DebugStepOver lua require'dap'.step_over()  -- command! DebugStepOut lua require'dap'.step_out()  -- command! DebugStepInto lua require'dap'.step_into()  -- command! DebugToggleRepl lua require'dap'.repl.toggle()  -- command! DebugGetSession lua require'dap'.session()  -- D = {  --     name = "Debug",  --     b = {"<cmd>DebugToggleBreakpoint<cr>", "Toggle Breakpoint"},  --     c = {"<cmd>DebugContinue<cr>", "Continue"},  --     i = {"<cmd>DebugStepInto<cr>", "Step Into"},  --     o = {"<cmd>DebugStepOver<cr>", "Step Over"},  --     r = {"<cmd>DebugToggleRepl<cr>", "Toggle Repl"},  --     s = {"<cmd>DebugStart<cr>", "Start"}  -- },  g = {    name = "Git",    j = { "<cmd>lua require 'gitsigns'.next_hunk()<cr>", "Next Hunk" },    k = { "<cmd>lua require 'gitsigns'.prev_hunk()<cr>", "Prev Hunk" },    l = { "<cmd>lua require 'gitsigns'.blame_line()<cr>", "Blame" },    p = { "<cmd>lua require 'gitsigns'.preview_hunk()<cr>", "Preview Hunk" },    r = { "<cmd>lua require 'gitsigns'.reset_hunk()<cr>", "Reset Hunk" },    R = { "<cmd>lua require 'gitsigns'.reset_buffer()<cr>", "Reset Buffer" },    s = { "<cmd>lua require 'gitsigns'.stage_hunk()<cr>", "Stage Hunk" },    u = {      "<cmd>lua require 'gitsigns'.undo_stage_hunk()<cr>",      "Undo Stage Hunk",    },    o = { "<cmd>Telescope git_status<cr>", "Open changed file" },    b = { "<cmd>Telescope git_branches<cr>", "Checkout branch" },    c = { "<cmd>Telescope git_commits<cr>", "Checkout commit" },    C = {      "<cmd>Telescope git_bcommits<cr>",      "Checkout commit(for current file)",    },  },  l = {    name = "LSP",    a = { "<cmd>Lspsaga code_action<cr>", "Code Action" },    A = { "<cmd>Lspsaga range_code_action<cr>", "Selected Action" },    d = {      "<cmd>Telescope lsp_document_diagnostics<cr>",      "Document Diagnostics",    },    D = {      "<cmd>Telescope lsp_workspace_diagnostics<cr>",      "Workspace Diagnostics",    },    f = { "<cmd>lua vim.lsp.buf.formatting()<cr>", "Format" },    h = { "<cmd>Lspsaga hover_doc<cr>", "Hover Doc" },    i = { "<cmd>LspInfo<cr>", "Info" },    j = { "<cmd>Lspsaga diagnostic_jump_prev<cr>", "Prev Diagnostic" },    k = { "<cmd>Lspsaga diagnostic_jump_next<cr>", "Next Diagnostic" },    l = { "<cmd>Lspsaga lsp_finder<cr>", "LSP Finder" },    L = { "<cmd>Lspsaga show_line_diagnostics<cr>", "Line Diagnostics" },    p = { "<cmd>Lspsaga preview_definition<cr>", "Preview Definition" },    q = { "<cmd>Telescope quickfix<cr>", "Quickfix" },    r = { "<cmd>Lspsaga rename<cr>", "Rename" },    t = { "<cmd>LspTypeDefinition<cr>", "Type Definition" },    x = { "<cmd>cclose<cr>", "Close Quickfix" },    s = {      O.plugin.symbol_outline.active and "<cmd>SymbolsOutline<cr>" or "<cmd> Telescope lsp_document_symbols<cr>",      "Document Symbols",    },    S = {      "<cmd>Telescope lsp_dynamic_workspace_symbols<cr>",      "Workspace Symbols",    },  },  s = {    name = "Search",    b = { "<cmd>Telescope git_branches<cr>", "Checkout branch" },    c = { "<cmd>Telescope colorscheme<cr>", "Colorscheme" },    -- d = {    --     "<cmd>Telescope lsp_document_diagnostics<cr>",    --     "Document Diagnostics"    -- },    -- D = {    --     "<cmd>Telescope lsp_workspace_diagnostics<cr>",    --     "Workspace Diagnostics"    -- },    f = { O.plugin.snap.active and "<cmd>Snap find_files<cr>" or "<cmd>Telescope find_files<cr>", "Find File" },    h = { "<cmd>Telescope help_tags<cr>", "Find Help" },    -- m = {"<cmd>Telescope marks<cr>", "Marks"},    M = { "<cmd>Telescope man_pages<cr>", "Man Pages" },    r = { O.plugin.snap.active and "<cmd>Snap oldfiles<cr>" or "<cmd>Telescope oldfiles<cr>", "Open Recent File" },    R = { "<cmd>Telescope registers<cr>", "Registers" },    t = { O.plugin.snap.active and "<cmd>Snap live_grep<cr>" or "<cmd>Telescope live_grep<cr>", "Text" },  },  S = {    name = "Session",    s = { "<cmd>SessionSave<cr>", "Save Session" },    l = { "<cmd>SessionLoad<cr>", "Load Session" },  },  T = {    name = "Treesitter",    i = { ":TSConfigInfo<cr>", "Info" },  },}if O.plugin.spectre.active then  mappings["r"] = {    name = "Replace",    f = {      "<cmd>lua require('spectre').open_file_search()<cr>",      "Current File",    },    p = { "<cmd>lua require('spectre').open()<cr>", "Project" },  }endif O.plugin.trouble.active then  mappings["d"] = {    name = "Diagnostics",    t = { "<cmd>TroubleToggle<cr>", "trouble" },    w = { "<cmd>TroubleToggle lsp_workspace_diagnostics<cr>", "workspace" },    d = { "<cmd>TroubleToggle lsp_document_diagnostics<cr>", "document" },    q = { "<cmd>TroubleToggle quickfix<cr>", "quickfix" },    l = { "<cmd>TroubleToggle loclist<cr>", "loclist" },    r = { "<cmd>TroubleToggle lsp_references<cr>", "references" },  }endif O.plugin.gitlinker.active then  mappings["gy"] = "Gitlink"endif O.plugin.ts_playground.active then  vim.api.nvim_set_keymap("n", "<leader>Th", ":TSHighlightCapturesUnderCursor<CR>", { noremap = true, silent = true })  mappings[""] = "Highlight Capture"endif O.plugin.zen.active then  vim.api.nvim_set_keymap("n", "<leader>z", ":ZenMode<CR>", { noremap = true, silent = true })  mappings["z"] = "Zen"endif O.plugin.lazygit.active then  vim.api.nvim_set_keymap("n", "<leader>gg", ":LazyGit<CR>", { noremap = true, silent = true })  mappings["gg"] = "LazyGit"endif O.plugin.telescope_project.active then  -- open projects  vim.api.nvim_set_keymap(    "n",    "<leader>p",    ":lua require'telescope'.extensions.project.project{}<CR>",    { noremap = true, silent = true }  )  mappings["p"] = "Projects"end-- [";"] = "Dashboard",if O.lang.latex.active then  mappings["L"] = {    name = "+Latex",    c = { "<cmd>VimtexCompile<cr>", "Toggle Compilation Mode" },    f = { "<cmd>call vimtex#fzf#run()<cr>", "Fzf Find" },    i = { "<cmd>VimtexInfo<cr>", "Project Information" },    s = { "<cmd>VimtexStop<cr>", "Stop Project Compilation" },    t = { "<cmd>VimtexTocToggle<cr>", "Toggle Table Of Content" },    v = { "<cmd>VimtexView<cr>", "View PDF" },  }endif O.lushmode then  mappings["L"] = {    name = "+Lush",    l = { ":Lushify<cr>", "Lushify" },    x = { ":lua require('lush').export_to_buffer(require('lush_theme.cool_name'))", "Lush Export" },    t = { ":LushRunTutorial<cr>", "Lush Tutorial" },    q = { ":LushRunQuickstart<cr>", "Lush Quickstart" },  }endlocal wk = require "which-key"wk.register(mappings, opts)
 |