dotfiles/.config/nvim/lua/which-key-nvim.lua
2021-07-11 16:50:22 +03:00

355 lines
14 KiB
Lua

require("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
}
local function map(mode, lhs, rhs, opts)
local options = {noremap = true, silent = true}
if opts then
options = vim.tbl_extend("force", options, opts)
end
vim.api.nvim_set_keymap(mode, lhs, rhs, options)
end
local opt = {}
-- Set leader
-- if O.leader_key == ' ' or O.leader_key == 'space' then
map('n', '<Space>', '<NOP>', opt)
-- 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_key
-- end
local 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
}
-- cycle tabs
map("n", "<leader>n", [[<Cmd>BufferLineCycleNext<CR>]], opt)
map("n", "<leader>p", [[<Cmd>BufferLineLineCyclePrev<CR>]], opt)
-- Truezen.nvim
map("n", "<leader>z", ":TZAtaraxis<CR>", opt)
map("n", "<leader>m", ":TZMinimalist<CR>", opt)
map("n", "<leader>j", ":TZFocus<CR>", opt)
-- no hl
vim.api.nvim_set_keymap('n', '<Leader>h', ':let @/=""<CR>',
{noremap = true, silent = true})
-- explorer
map("n", "<leader>e", ":NvimTreeToggle<CR>", opt)
-- TODO this introduces some bugs unfortunately
-- vim.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 snap
-- if 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
-- dashboard
vim.api.nvim_set_keymap('n', '<Leader>;', ':Dashboard<CR>',
{noremap = true, silent = true})
-- Comments
map("v", "<leader>/", ":CommentToggle<CR>", opt)
-- dashboard
map("n", "<Leader>;", [[<Cmd> Dashboard<CR>]], opt)
-- TODO create entire treesitter section
local mappings = {
["/"] = {":CommentToggle<CR>", "Comment"},
['<tab>'] = {'<C-^>', 'alternate file'},
-- ["e"] = "Explorer",
--
-- ["c"]= {":BufferClose<CR>", "Close Buffer"},
["f"] = "Find File",
["h"] = "No Highlight",
['\\'] = { ':vnew<CR>', 'vsplit'},
['-'] = { ':new<CR>', 'hsplit'},
b = {
name = "Buffers",
j = {"<cmd>BufferLinePick<cr>", "jump to buffer"},
-- f = {O.plugin.snap.active and "<cmd>Snap buffers<cr>" or "<cmd>Telescope buffers<cr>", "Find buffer"},
f = {"<cmd>Telescope buffers<cr>", "Find buffer"},
w = {"<cmd>BufferLineWipeout<cr>", "wipeout buffer"},
h = {"<cmd>BufferLineCloseBuffersLeft<cr>", "close all buffers to the left"},
l = {
"<cmd>BufferLineCloseBuffersRight<cr>",
"close all BufferLines to the right"
},
D = {
"<cmd>BufferLineOrderByDirectory<cr>",
"sort BufferLines automatically by directory"
},
L = {
"<cmd>BufferLineOrderByLanguage<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 = {"<cmd> Telescope lsp_document_symbols<cr>", "Document Symbols"},
-- 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 = {"<cmd>Telescope find_files<cr>", "Find File"},
-- 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 = {"<cmd>Telescope oldfiles<cr>", "Open Recent File"},
-- 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 = {"<cmd>Telescope live_grep<cr>", "Text"}
-- 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"}
-- }
-- end
--
-- if 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"}
-- }
-- end
--
-- if O.plugin.gitlinker.active then mappings["gy"] = "Gitlink" end
--
-- if O.plugin.ts_playground.active then
-- vim.api.nvim_set_keymap("n", "<leader>Th",
-- ":TSHighlightCapturesUnderCursor<CR>",
-- {noremap = true, silent = true})
-- mappings[""] = "Highlight Capture"
-- end
--
-- if O.plugin.zen.active then
-- vim.api.nvim_set_keymap("n", "<leader>z", ":ZenMode<CR>",
-- {noremap = true, silent = true})
-- mappings["z"] = "Zen"
-- end
-- if O.plugin.lazygit.active then
-- vim.api.nvim_set_keymap("n", "<leader>gg", ":LazyGit<CR>",
-- {noremap = true, silent = true})
-- mappings["gg"] = "LazyGit"
-- end
-- if 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"}
-- }
-- end
--
-- if 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"}
-- }
-- end
local wk = require("which-key")
wk.register(mappings, opts)