refactor(keymap): dont use which-key to setup lsp keymaps

This commit is contained in:
Folke Lemaitre 2023-01-01 10:53:43 +01:00
parent dc6b0b21f5
commit ddd014398c
No known key found for this signature in database
GPG key ID: 41F8B1FBACAE2040
2 changed files with 63 additions and 66 deletions

View file

@ -53,10 +53,15 @@ return {
key_labels = { ["<leader>"] = "SPC" }, key_labels = { ["<leader>"] = "SPC" },
}) })
wk.register({ wk.register({
f = { name = "+file" }, ["g"] = { name = "+goto" },
g = { name = "+git" }, ["]"] = { name = "+next" },
b = { name = "+buffer" }, ["["] = { name = "+prev" },
}, { prefix = "<leader>" }) ["<leader>b"] = { name = "+buffer" },
["<leader>c"] = { name = "+code" },
["<leader>f"] = { name = "+file" },
["<leader>g"] = { name = "+git" },
["<leader>x"] = { name = "+diagnostics" },
})
end, end,
}, },

View file

@ -1,70 +1,62 @@
local M = {} local M = {}
function M.diagnostic_goto(next, severity)
local go = next and vim.diagnostic.goto_next or vim.diagnostic.goto_prev
severity = severity and vim.diagnostic.severity[severity] or nil
return function()
go({ severity = severity })
end
end
function M.on_attach(client, buffer) function M.on_attach(client, buffer)
local cap = client.server_capabilities local cap = client.server_capabilities
require("which-key").register({ local function map(lhs, rhs, opts)
buffer = buffer, opts = opts or {}
["<leader>"] = { vim.keymap.set(opts.mode or "n", lhs, rhs, { silent = true, buffer = buffer, expr = opts.expr, desc = opts.desc })
c = { end
name = "+code",
{ map("<leader>ca", vim.lsp.buf.code_action, { desc = "Code Action", mode = { "n", "v" } })
cond = client.name == "tsserver", map("<leader>cd", vim.diagnostic.open_float, { desc = "Line Diagnostics" })
o = { "<cmd>:TypescriptOrganizeImports<CR>", "Organize Imports" }, map("<leader>cl", "<cmd>LspInfo<cr>", { desc = "Lsp Info" })
R = { "<cmd>:TypescriptRenameFile<CR>", "Rename File" }, map("<leader>xd", "<cmd>Telescope diagnostics<cr>", { desc = "Telescope Diagnostics" })
}, map("gd", "<cmd>Telescope lsp_definitions<cr>", { desc = "Goto Definition" })
r = { "<cmd>lua vim.lsp.buf.rename()<cr>", "Rename", cond = cap.renameProvider }, map("gr", "<cmd>Telescope lsp_references<cr>", { desc = "References" })
a = { map("gR", "<cmd>Trouble lsp_references<cr>", { desc = "Trouble References" })
{ vim.lsp.buf.code_action, "Code Action" }, map("gD", "<cmd>Telescope lsp_declarations<CR>", { desc = "Goto Declaration" })
{ "<cmd>lua vim.lsp.buf.code_action()<cr>", "Code Action", mode = "v" }, map("gI", "<cmd>Telescope lsp_implementations<CR>", { desc = "Goto Implementation" })
}, map("gt", "<cmd>Telescope lsp_type_definitions<cr>", { desc = "Goto Type Definition" })
f = { map("<C-k>", "<cmd>lua vim.lsp.buf.signature_help()<CR>", { desc = "Signature Help", mode = { "i", "n" } })
{ map("K", "<cmd>lua vim.lsp.buf.hover()<CR>", { desc = "Hover" })
require("plugins.lsp.format").format, map("[d", M.diagnostic_goto(true), { desc = "Next Diagnostic" })
"Format Document", map("]d", M.diagnostic_goto(false), { desc = "Prev Diagnostic" })
cond = cap.documentFormatting, map("]e", M.diagnostic_goto(true, "ERROR"), { desc = "Next Error" })
}, map("[e", M.diagnostic_goto(false, "ERROR"), { desc = "Prev Error" })
{ map("]w", M.diagnostic_goto(true, "WARNING"), { desc = "Next Warning" })
require("plugins.lsp.format").format, map("[w", M.diagnostic_goto(false, "WARNING"), { desc = "Prev Warning" })
"Format Range",
cond = cap.documentRangeFormatting, if cap.documentFormatting then
mode = "v", map("<leader>cf", require("plugins.lsp.format").format, { desc = "Format Document" })
}, end
},
d = { vim.diagnostic.open_float, "Line Diagnostics" }, if cap.documentRangeFormatting then
l = { map("<leader>cf", require("plugins.lsp.format").format, { desc = "Format Range", mode = "v" })
name = "+lsp", end
i = { "<cmd>LspInfo<cr>", "Lsp Info" },
}, if cap.renameProvider then
}, map("<leader>cr", function()
x = { if pcall(require, "inc_rename") then
d = { "<cmd>Telescope diagnostics<cr>", "Search Diagnostics" }, return ":IncRename " .. vim.fn.expand("<cword>")
}, else
}, vim.lsp.buf.rename()
g = { end
name = "+goto", end, { expr = true, desc = "Rename" })
d = { "<cmd>Telescope lsp_definitions<cr>", "Goto Definition" }, end
r = { "<cmd>Telescope lsp_references<cr>", "References" },
R = { "<cmd>Trouble lsp_references<cr>", "Trouble References" }, if client.name == "tsserver" and pcall(require, "typescript") then
D = { "<cmd>Telescope lsp_declarations<CR>", "Goto Declaration" }, map("<leader>co", "<cmd>TypescriptOrganizeImports<CR>", { desc = "Organize Imports" })
I = { "<cmd>Telescope lsp_implementations<CR>", "Goto Implementation" }, map("<leader>cR", "<cmd>TypescriptRenameFile<CR>", { desc = "Rename File" })
t = { "<cmd>Telescope lsp_type_definitions<cr>", "Goto Type Definition" }, end
},
["<C-k>"] = { "<cmd>lua vim.lsp.buf.signature_help()<CR>", "Signature Help", mode = { "n", "i" } },
["K"] = { "<cmd>lua vim.lsp.buf.hover()<CR>", "Hover" },
["[d"] = { "<cmd>lua vim.diagnostic.goto_prev()<CR>", "Next Diagnostic" },
["]d"] = { "<cmd>lua vim.diagnostic.goto_next()<CR>", "Prev Diagnostic" },
["[e"] = { "<cmd>lua vim.diagnostic.goto_prev({severity = vim.diagnostic.severity.ERROR})<CR>", "Next Error" },
["]e"] = { "<cmd>lua vim.diagnostic.goto_next({severity = vim.diagnostic.severity.ERROR})<CR>", "Prev Error" },
["[w"] = {
"<cmd>lua vim.diagnostic.goto_prev({severity = vim.diagnostic.severity.WARNING})<CR>",
"Next Warning",
},
["]w"] = {
"<cmd>lua vim.diagnostic.goto_next({severity = vim.diagnostic.severity.WARNING})<CR>",
"Prev Warning",
},
})
end end
return M return M