X-Git-Url: https://git.rmz.io/dotfiles.git/blobdiff_plain/ada728731a4a403ea48280185b699f45589f5d40..fdd63454b51a35418ec23d3489cf20ae66a2299d:/nvim/lua/config/keymaps.lua diff --git a/nvim/lua/config/keymaps.lua b/nvim/lua/config/keymaps.lua index e8b8287..fc3ba2f 100644 --- a/nvim/lua/config/keymaps.lua +++ b/nvim/lua/config/keymaps.lua @@ -1,93 +1,101 @@ -- Keymaps are automatically loaded on the VeryLazy event +-- NOTE: Default LazyVim keys are not loaded automatically, review upstream keymas occasionnaly. +-- ~/.local/share/nvim/lazy/LazyVim/lua/lazyvim/config/keymaps.lua local Util = require("lazyvim.util") -local function map(mode, lhs, rhs, opts) - local keys = require("lazy.core.handler").handlers.keys - ---@cast keys LazyKeysHandler - -- do not create the keymap if a lazy keys handler exists - if not keys.active[keys.parse({ lhs, mode = mode }).id] then - opts = opts or {} - opts.silent = opts.silent ~= false - vim.keymap.set(mode, lhs, rhs, opts) - end -end - -- Resize window using arrow keys -- TODO: this is cool, but should also support a number -map("n", "", "resize +2", { desc = "Increase window height" }) -map("n", "", "resize -2", { desc = "Decrease window height" }) -map("n", "", "vertical resize -2", { desc = "Decrease window width" }) -map("n", "", "vertical resize +2", { desc = "Increase window width" }) +vim.keymap.set("n", "", "resize +2", { desc = "Increase window height" }) +vim.keymap.set("n", "", "resize -2", { desc = "Decrease window height" }) +vim.keymap.set("n", "", "vertical resize -2", { desc = "Decrease window width" }) +vim.keymap.set("n", "", "vertical resize +2", { desc = "Increase window width" }) -- Move Lines -map("n", "", "m .+1==", { desc = "Move down" }) -map("n", "", "m .-2==", { desc = "Move up" }) -map("i", "", "m .+1==gi", { desc = "Move down" }) -map("i", "", "m .-2==gi", { desc = "Move up" }) -map("v", "", ":m '>+1gv=gv", { desc = "Move down" }) -map("v", "", ":m '<-2gv=gv", { desc = "Move up" }) +vim.keymap.set("n", "", "m .+1==", { desc = "Move down" }) +vim.keymap.set("n", "", "m .-2==", { desc = "Move up" }) +-- NOTE: this triggers with when I'm too quick at doing "go to normal mode then move line" +vim.keymap.set("i", "", "m .+1==gi", { desc = "Move down" }) +vim.keymap.set("i", "", "m .-2==gi", { desc = "Move up" }) +vim.keymap.set("v", "", ":m '>+1gv=gv", { desc = "Move down" }) +vim.keymap.set("v", "", ":m '<-2gv=gv", { desc = "Move up" }) -- buffers -if Util.has("bufferline.nvim") then - map("n", "", "BufferLineCyclePrev", { desc = "Prev buffer" }) - map("n", "", "BufferLineCycleNext", { desc = "Next buffer" }) - map("n", "[b", "BufferLineCyclePrev", { desc = "Prev buffer" }) - map("n", "]b", "BufferLineCycleNext", { desc = "Next buffer" }) -else - map("n", "", "bprevious", { desc = "Prev buffer" }) - map("n", "", "bnext", { desc = "Next buffer" }) - map("n", "[b", "bprevious", { desc = "Prev buffer" }) - map("n", "]b", "bnext", { desc = "Next buffer" }) -end -map("n", "bb", "e #", { desc = "Switch to Other Buffer" }) -map("n", "`", "e #", { desc = "Switch to Other Buffer" }) +vim.keymap.set("n", "", "BufferLineCyclePrev", { desc = "Prev buffer" }) +vim.keymap.set("n", "", "BufferLineCycleNext", { desc = "Next buffer" }) +vim.keymap.set("n", "[b", "BufferLineCyclePrev", { desc = "Prev buffer" }) +vim.keymap.set("n", "]b", "BufferLineCycleNext", { desc = "Next buffer" }) + +vim.keymap.set("n", "bb", "e #", { desc = "Switch to Other Buffer" }) -- Clear search with -map({ "i", "n" }, "", "noh", { desc = "Escape and clear hlsearch" }) +vim.keymap.set({ "i", "n" }, "", "noh", { desc = "Escape and clear hlsearch" }) -- Clear search, diff update and redraw -- taken from runtime/lua/_editor.lua -map( +vim.keymap.set( "n", "ur", "nohlsearchdiffupdatenormal! ", { desc = "Redraw / clear hlsearch / diff update" } ) -map({ "n", "x" }, "gw", "*N", { desc = "Search word under cursor" }) +vim.keymap.set({ "n", "x" }, "gw", "*N", { desc = "Search word under cursor" }) -- Add undo break-points -map("i", ",", ",u") -map("i", ".", ".u") -map("i", ";", ";u") +vim.keymap.set("i", ",", ",u") +vim.keymap.set("i", ".", ".u") +vim.keymap.set("i", ";", ";u") -- lazy -map("n", "l", ":Lazy", { desc = "Lazy" }) +vim.keymap.set("n", "l", ":Lazy", { desc = "Lazy" }) -- new file -map("n", "fn", "enew", { desc = "New File" }) +vim.keymap.set("n", "fn", "enew", { desc = "New File" }) + +vim.keymap.set("n", "[q", vim.cmd.cprev, { desc = "Previous quickfix" }) +vim.keymap.set("n", "]q", vim.cmd.cnext, { desc = "Next quickfix" }) -if not Util.has("trouble.nvim") then - map("n", "[q", vim.cmd.cprev, { desc = "Previous quickfix" }) - map("n", "]q", vim.cmd.cnext, { desc = "Next quickfix" }) +-- diagnostic +local diagnostic_goto = function(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 +vim.keymap.set("n", "cd", vim.diagnostic.open_float, { desc = "Line Diagnostics" }) +vim.keymap.set("n", "]d", diagnostic_goto(true), { desc = "Next Diagnostic" }) +vim.keymap.set("n", "[d", diagnostic_goto(false), { desc = "Prev Diagnostic" }) +vim.keymap.set("n", "]e", diagnostic_goto(true, "ERROR"), { desc = "Next Error" }) +vim.keymap.set("n", "[e", diagnostic_goto(false, "ERROR"), { desc = "Prev Error" }) +vim.keymap.set("n", "]w", diagnostic_goto(true, "WARN"), { desc = "Next Warning" }) +vim.keymap.set("n", "[w", diagnostic_goto(false, "WARN"), { desc = "Prev Warning" }) -- stylua: ignore start -- toggle options -map("n", "uf", Util.format.toggle, { desc = "Toggle format on Save" }) -map("n", "ud", Util.toggle.diagnostics, { desc = "Toggle Diagnostics" }) +vim.keymap.set("n", "uf", Util.format.toggle, { desc = "Toggle format on Save" }) +vim.keymap.set("n", "ud", Snacks.toggle.diagnostics, { desc = "Toggle Diagnostics" }) local conceallevel = vim.o.conceallevel > 0 and vim.o.conceallevel or 3 -map("n", "uc", function() Util.toggle("conceallevel", false, {0, conceallevel}) end, { desc = "Toggle Conceal" }) +vim.keymap.set("n", "uc", function() Snacks.toggle("conceallevel", false, {0, conceallevel}) end, { desc = "Toggle Conceal" }) -- highlights under cursor if vim.fn.has("nvim-0.9.0") == 1 then - map("n", "ui", vim.show_pos, { desc = "Inspect Pos" }) + vim.keymap.set("n", "ui", vim.show_pos, { desc = "Inspect Pos" }) end -- floating terminal -- TODO: I prefer a split buffer for terminal, need to review how to make this more vim-like -map("n", "ft", function() Util.float_term(nil, { cwd = Util.get_root() }) end, { desc = "Terminal (root dir)" }) -map("n", "fT", function() Util.float_term() end, { desc = "Terminal (cwd)" }) -map("t", "", "", {desc = "Enter Normal Mode"}) +local lazyterm = function() LazyVim.terminal(nil, { cwd = LazyVim.root() }) end +vim.keymap.set("n", "ft", lazyterm, { desc = "Terminal (Root Dir)" }) +vim.keymap.set("n", "fT", function() LazyVim.terminal() end, { desc = "Terminal (cwd)" }) + +-- Terminal Mappings +vim.keymap.set("t", "", "", { desc = "Enter Normal Mode" }) +vim.keymap.set("t", "", "wincmd h", { desc = "Go to Left Window" }) +vim.keymap.set("t", "", "wincmd j", { desc = "Go to Lower Window" }) +vim.keymap.set("t", "", "wincmd k", { desc = "Go to Upper Window" }) +vim.keymap.set("t", "", "wincmd l", { desc = "Go to Right Window" }) +vim.keymap.set("t", "", "close", { desc = "Hide Terminal" }) +vim.keymap.set("t", "", "close", { desc = "which_key_ignore" })