mirror of
https://github.com/sahinakkaya/dotfiles.git
synced 2024-12-23 23:59:36 +01:00
355 lines
14 KiB
Lua
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)
|