implemented better colemak rebinds
This commit is contained in:
parent
9b586c91d5
commit
81f7051197
4 changed files with 305 additions and 30 deletions
|
@ -3,53 +3,49 @@
|
|||
-- Add any additional keymaps here
|
||||
local map = vim.keymap.set
|
||||
local wk = require("which-key")
|
||||
local cmdh = require("colemak-dh")
|
||||
|
||||
vim.keymap.set({ "i", "n" }, "<C-t>", "<Nop>")
|
||||
|
||||
local dirmap = {
|
||||
up = "w0",
|
||||
down = "w$",
|
||||
}
|
||||
|
||||
-- Bind arrows to hjkl to my colemak-dh motions work as expected
|
||||
map({ "n", "x" }, "<Up>", "k", { desc = "Up", remap = true })
|
||||
map({ "n", "x" }, "<Down>", "j", { desc = "Down", remap = true })
|
||||
map({ "n", "x" }, "<Left>", "h", { desc = "Left", remap = true })
|
||||
map({ "n", "x" }, "<Right>", "l", { desc = "Right", remap = true })
|
||||
-- map({ "n", "x" }, "<Up>", "k", { desc = "Up", remap = true })
|
||||
-- map({ "n", "x" }, "<Down>", "j", { desc = "Down", remap = true })
|
||||
-- map({ "n", "x" }, "<Left>", "h", { desc = "Left", remap = true })
|
||||
-- map({ "n", "x" }, "<Right>", "l", { desc = "Right", remap = true })
|
||||
|
||||
map({ "n", "t", "i" }, "<C-Left>", "<cmd> TmuxNavigateLeft<CR>", { desc = "Switch Window Left", remap = true })
|
||||
map({ "n", "t", "i" }, "<C-Right>", "<cmd> TmuxNavigateRight<CR>", { desc = "Switch Window Right", remap = true })
|
||||
map({ "n", "t", "i" }, "<C-Up>", "<cmd> TmuxNavigateUp<CR>", { remap = true })
|
||||
map({ "n", "t", "i" }, "<C-Down>", "<cmd> TmuxNavigateDown<CR>", { desc = "Switch Window Down", remap = true })
|
||||
-- map({ "n", "t", "i" }, "<C-Left>", "<cmd> TmuxNavigateLeft<CR>", { desc = "Switch Window Left", remap = true })
|
||||
-- map({ "n", "t", "i" }, "<C-Right>", "<cmd> TmuxNavigateRight<CR>", { desc = "Switch Window Right", remap = true })
|
||||
-- map({ "n", "t", "i" }, "<C-Up>", "<cmd> TmuxNavigateUp<CR>", { remap = true })
|
||||
-- map({ "n", "t", "i" }, "<C-Down>", "<cmd> TmuxNavigateDown<CR>", { desc = "Switch Window Down", remap = true })
|
||||
|
||||
map({ "x" }, "<M-Left>", "<M-h>", { remap = true })
|
||||
map({ "x" }, "<M-Right>", "<M-l>", { remap = true })
|
||||
map({ "n", "x", "v" }, "<M-Up>", "<M-k>", { remap = true })
|
||||
map({ "n", "x", "v" }, "<M-Down>", "<M-j>", { remap = true })
|
||||
map({ "n" }, "<S-Left>", "[b", { desc = "Previous Buffer", remap = true })
|
||||
map({ "n" }, "<S-Right>", "]b", { desc = "Next Buffer", remap = true })
|
||||
-- map({ "n" }, "<S-Left>", "[b", { desc = "Previous Buffer", remap = true })
|
||||
-- map({ "n" }, "<S-Right>", "]b", { desc = "Next Buffer", remap = true })
|
||||
map({ "n" }, "<S-Down>", "5j", { remap = true })
|
||||
map({ "n" }, "<S-Up>", "5k", { remap = true })
|
||||
map({ "i" }, "<M-e>", "<Esc>", { desc = "Escape insert mode", remap = true })
|
||||
-- map({ "i" }, "<M-e>", "<Esc>", { desc = "Escape insert mode", remap = true })
|
||||
|
||||
-- better navigation
|
||||
map({ "n" }, "<C-u>", "<C-u>zz", { remap = false })
|
||||
map({ "n" }, "<C-d>", "<C-d>zz", { remap = false })
|
||||
map({ "n" }, "n", "nzz", { remap = false })
|
||||
map({ "n" }, "N", "Nzz", { remap = false })
|
||||
map({ "n" }, "<PageDown>", "<Down>zz", { remap = false })
|
||||
map({ "n" }, "<PageUp>", "<Up>zz", { remap = false })
|
||||
map({ "n", "x" }, "<M-i>", "$", { remap = false })
|
||||
map({ "n", "x" }, "<M-m>", "0", { remap = false })
|
||||
-- map({ "n" }, "n", "nzz", { remap = false })
|
||||
-- map({ "n" }, "N", "Nzz", { remap = false })
|
||||
-- map({ "n" }, "<PageDown>", "<Down>zz", { remap = false })
|
||||
-- map({ "n" }, "<PageUp>", "<Up>zz", { remap = false })
|
||||
-- map({ "n", "x" }, "<M-i>", "$", { remap = false })
|
||||
-- map({ "n", "x" }, "<M-m>", "0", { remap = false })
|
||||
|
||||
-- easily access null register
|
||||
map({ "n", "x" }, "<leader>n", '"_', { remap = false, silent = true, desc = "Null Register" })
|
||||
|
||||
-- remove the default lazyvim, and also swap H and L (for move cursor) to make more sense on colemak
|
||||
vim.keymap.del({ "n" }, "<S-h>")
|
||||
vim.keymap.del({ "n" }, "<S-l>")
|
||||
map({ "n" }, "<S-h>", "L", { remap = false })
|
||||
map({ "n" }, "<S-l>", "H", { remap = false })
|
||||
-- vim.keymap.del({ "n" }, "<S-h>")
|
||||
-- vim.keymap.del({ "n" }, "<S-l>")
|
||||
-- map({ "n" }, "<S-h>", "L", { remap = false })
|
||||
-- map({ "n" }, "<S-l>", "H", { remap = false })
|
||||
-- better delete and put
|
||||
|
||||
-- better quit
|
||||
|
@ -73,7 +69,7 @@ map({ "n", "x" }, "<leader>y", ":w<CR>", { desc = "Save" })
|
|||
map({ "n", "x" }, "<leader>Y", ":wa<CR>", { desc = "Save All" })
|
||||
|
||||
-- Zen Mode
|
||||
map("n", "<leader>uz", "<CMD>ZenMode<CR>", { desc = "Toggle Zen Mode" })
|
||||
-- map("n", "<leader>uz", "<CMD>ZenMode<CR>", { desc = "Toggle Zen Mode" })
|
||||
|
||||
-- Source Current File
|
||||
map("n", "<leader><leader>x", "<CMD>source %<CR>", { desc = "Source current file" })
|
||||
|
@ -115,3 +111,5 @@ map("n", "<leader>or", function()
|
|||
end, { desc = "Obsidian Rename" })
|
||||
map("n", "<leader>oc", "<CMD>ObsidianTOC<CR>", { desc = "Obsidian Table Of Contents" })
|
||||
-- TODO: Add binds for templates
|
||||
-- cmdh.fix_hjkl()
|
||||
cmdh.fix_all()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue