diff --git a/lua/lazyvim/config/keymaps.lua b/lua/lazyvim/config/keymaps.lua index 8333b1c7..896b6d42 100644 --- a/lua/lazyvim/config/keymaps.lua +++ b/lua/lazyvim/config/keymaps.lua @@ -1,6 +1,6 @@ -- This file is automatically loaded by lazyvim.plugins.config -local util = require("lazyvim.util") +local Util = require("lazyvim.util") -- better up/down vim.keymap.set("n", "j", "v:count == 0 ? 'gj' : 'j'", { expr = true, silent = true }) @@ -15,22 +15,26 @@ vim.keymap.set("n", "", "k", { desc = "Go to upper window" }) vim.keymap.set("n", "", "l", { desc = "Go to right window" }) -- Resize window using arrow keys -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" }) +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 -vim.keymap.set("n", "", ":m .+1==", { desc = "Move down" }) -vim.keymap.set("v", "", ":m '>+1gv=gv", { desc = "Move down" }) -vim.keymap.set("i", "", ":m .+1==gi", { desc = "Move down" }) -vim.keymap.set("n", "", ":m .-2==", { desc = "Move up" }) -vim.keymap.set("v", "", ":m '<-2gv=gv", { desc = "Move up" }) -vim.keymap.set("i", "", ":m .-2==gi", { desc = "Move up" }) +vim.keymap.set("n", "", ":m .+1==", { desc = "Move down" }) +vim.keymap.set("v", "", ":m '>+1gv=gv", { desc = "Move down" }) +vim.keymap.set("i", "", ":m .+1==gi", { desc = "Move down" }) +vim.keymap.set("n", "", ":m .-2==", { desc = "Move up" }) +vim.keymap.set("v", "", ":m '<-2gv=gv", { desc = "Move up" }) +vim.keymap.set("i", "", ":m .-2==gi", { desc = "Move up" }) --- Switch buffers with hl -vim.keymap.set("n", "", "bprevious", { desc = "Prev buffer" }) -vim.keymap.set("n", "", "bnext", { desc = "Next buffer" }) +-- buffers +if not Util.has("nvim-bufferline.lua") then + vim.keymap.set("n", "", "bprevious", { desc = "Prev buffer" }) + vim.keymap.set("n", "", "bnext", { desc = "Next buffer" }) +end +vim.keymap.set("n", "bb", "e #", { desc = "Switch to Other Buffer" }) +vim.keymap.set("n", "`", "e #", { desc = "Switch to Other Buffer" }) -- Clear search with vim.keymap.set({ "i", "n" }, "", "noh", { desc = "Escape and clear hlsearch" }) @@ -74,16 +78,16 @@ vim.keymap.set("n", "xq", "copen", { desc = "Open Quickfix List -- toggle options vim.keymap.set("n", "tf", require("lazyvim.plugins.lsp.format").toggle, { desc = "Toggle format on Save" }) -vim.keymap.set("n", "ts", function() util.toggle("spell") end, { desc = "Toggle Spelling" }) -vim.keymap.set("n", "tw", function() util.toggle("wrap") end, { desc = "Toggle Word Wrap" }) -vim.keymap.set("n", "tn", function() util.toggle("relativenumber", true) util.toggle("number") end, { desc = "Toggle Line Numbers" }) -vim.keymap.set("n", "td", util.toggle_diagnostics, { desc = "Toggle Diagnostics" }) +vim.keymap.set("n", "ts", function() Util.toggle("spell") end, { desc = "Toggle Spelling" }) +vim.keymap.set("n", "tw", function() Util.toggle("wrap") end, { desc = "Toggle Word Wrap" }) +vim.keymap.set("n", "tn", function() Util.toggle("relativenumber", true) Util.toggle("number") end, { desc = "Toggle Line Numbers" }) +vim.keymap.set("n", "td", Util.toggle_diagnostics, { desc = "Toggle Diagnostics" }) local conceallevel = vim.o.conceallevel > 0 and vim.o.conceallevel or 3 -vim.keymap.set("n", "tc", function() util.toggle("conceallevel", false, {0, conceallevel}) end, { desc = "Toggle Conceal" }) +vim.keymap.set("n", "tc", function() Util.toggle("conceallevel", false, {0, conceallevel}) end, { desc = "Toggle Conceal" }) -- lazygit vim.keymap.set("n", "gg", function() require("lazyvim.util").float_term({ "lazygit" }) end, { desc = "Lazygit (cwd)" }) -vim.keymap.set("n", "gG", function() util.float_term({ "lazygit" }, { cwd = util.get_root() }) end, { desc = "Lazygit (root dir)" }) +vim.keymap.set("n", "gG", function() Util.float_term({ "lazygit" }, { cwd = Util.get_root() }) end, { desc = "Lazygit (root dir)" }) -- quit vim.keymap.set("n", "qq", "qa", { desc = "Quit all" }) @@ -94,7 +98,7 @@ if vim.fn.has("nvim-0.9.0") == 1 then end -- floating terminal -vim.keymap.set("n", "ot", function() util.float_term(nil, { cwd = util.get_root() }) end, { desc = "Terminal (root dir)" }) +vim.keymap.set("n", "ot", function() Util.float_term(nil, { cwd = Util.get_root() }) end, { desc = "Terminal (root dir)" }) vim.keymap.set("n", "oT", function() require("lazyvim.util").float_term() end, { desc = "Terminal (cwd)" }) vim.keymap.set("t", "", "", {desc = "Enter Normal Mode"}) @@ -105,15 +109,9 @@ vim.keymap.set("n", "w-", "s", { desc = "split-window-below" }) vim.keymap.set("n", "w|", "v", { desc = "split-window-right" }) -- tabs -vim.keymap.set("n", "l", "tablast", { desc = "Last" }) -vim.keymap.set("n", "f", "tabfirst", { desc = "First" }) -vim.keymap.set("n", "", "tabnew", { desc = "New Tab" }) -vim.keymap.set("n", "]", "tabnext", { desc = "Next" }) -vim.keymap.set("n", "d", "tabclose", { desc = "Close" }) -vim.keymap.set("n", "[", "tabprevious", { desc = "Previous" }) - --- buffers -vim.keymap.set("n", "b]", ":BufferLineCycleNext", { desc = "Next Buffer" }) -vim.keymap.set("n", "bb", ":e #", { desc = "Switch to Other Buffer" }) -vim.keymap.set("n", "b[", ":BufferLineCyclePrev", { desc = "Previous Buffer" }) -vim.keymap.set("n", "`", ":e #", { desc = "Switch to Other Buffer" }) +vim.keymap.set("n", "l", "tablast", { desc = "Last" }) +vim.keymap.set("n", "f", "tabfirst", { desc = "First" }) +vim.keymap.set("n", "", "tabnew", { desc = "New Tab" }) +vim.keymap.set("n", "]", "tabnext", { desc = "Next" }) +vim.keymap.set("n", "d", "tabclose", { desc = "Close" }) +vim.keymap.set("n", "[", "tabprevious", { desc = "Previous" }) diff --git a/lua/lazyvim/plugins/ui.lua b/lua/lazyvim/plugins/ui.lua index 724a2757..75ace8eb 100644 --- a/lua/lazyvim/plugins/ui.lua +++ b/lua/lazyvim/plugins/ui.lua @@ -43,6 +43,10 @@ return { { "akinsho/nvim-bufferline.lua", event = "VeryLazy", + init = function() + vim.keymap.set("n", "", "BufferLineCyclePrev", { desc = "Prev Buffer" }) + vim.keymap.set("n", "", "BufferLineCycleNext", { desc = "Next Buffer" }) + end, opts = { options = { diagnostics = "nvim_lsp", diff --git a/lua/lazyvim/util/init.lua b/lua/lazyvim/util/init.lua index 57ef478e..8b5f135e 100644 --- a/lua/lazyvim/util/init.lua +++ b/lua/lazyvim/util/init.lua @@ -15,6 +15,11 @@ function M.on_attach(on_attach) }) end +---@param plugin string +function M.has(plugin) + return require("lazy.core.config").plugins[plugin] ~= nil +end + -- returns the root directory based on: -- * lsp workspace folders -- * lsp root_dir