Compare commits
3 commits
b0a4ab2dc4
...
ed20661f72
Author | SHA1 | Date | |
---|---|---|---|
ed20661f72 | |||
ed1947965e | |||
afe7d344ea |
4 changed files with 645 additions and 4 deletions
|
@ -27,13 +27,18 @@
|
||||||
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||||
unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||||
|
|
||||||
|
snowfall-lib = {
|
||||||
|
url = "github:snowfallorg/lib";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
nixvim = {
|
nixvim = {
|
||||||
url = "github:nix-community/nixvim";
|
url = "github:nix-community/nixvim";
|
||||||
inputs.nixpkgs.follows = "unstable";
|
inputs.nixpkgs.follows = "unstable";
|
||||||
};
|
};
|
||||||
|
|
||||||
snowfall-lib = {
|
neovim-nightly = {
|
||||||
url = "github:snowfallorg/lib";
|
url = "github:nix-community/neovim-nightly-overlay";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
{ ... }:
|
_: {
|
||||||
{
|
|
||||||
viAlias = true;
|
viAlias = true;
|
||||||
vimAlias = true;
|
vimAlias = true;
|
||||||
|
|
||||||
|
|
430
modules/nixvim/keymaps/default.nix
Normal file
430
modules/nixvim/keymaps/default.nix
Normal file
|
@ -0,0 +1,430 @@
|
||||||
|
{ lib, ... }:
|
||||||
|
let
|
||||||
|
inherit (lib)
|
||||||
|
map
|
||||||
|
mapAttrsToList
|
||||||
|
toUpper
|
||||||
|
substring
|
||||||
|
mapCartesianProduct
|
||||||
|
toLower
|
||||||
|
;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
globals = {
|
||||||
|
mapleader = " ";
|
||||||
|
maplocalleader = "\\";
|
||||||
|
};
|
||||||
|
|
||||||
|
keymaps =
|
||||||
|
# Disable Arrow Key Movement - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
(map
|
||||||
|
(d: {
|
||||||
|
mode = [
|
||||||
|
"i"
|
||||||
|
"n"
|
||||||
|
];
|
||||||
|
key = d;
|
||||||
|
action = "<nop>";
|
||||||
|
})
|
||||||
|
[
|
||||||
|
"<Down>"
|
||||||
|
"<Up>"
|
||||||
|
"<Left>"
|
||||||
|
"<Right>"
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
# Better Up/Down - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (mapAttrsToList
|
||||||
|
(d: k: {
|
||||||
|
mode = [
|
||||||
|
"n"
|
||||||
|
"x"
|
||||||
|
];
|
||||||
|
key = k;
|
||||||
|
action = "v:count == 0 ? 'g${k}' : '${k}'";
|
||||||
|
options = {
|
||||||
|
desc = d;
|
||||||
|
expr = true;
|
||||||
|
silent = true;
|
||||||
|
};
|
||||||
|
})
|
||||||
|
{
|
||||||
|
Down = "j";
|
||||||
|
Up = "k";
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Resize Windows - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (mapAttrsToList
|
||||||
|
(
|
||||||
|
k: d:
|
||||||
|
let
|
||||||
|
s = if (d == "Increase") then "+" else "-";
|
||||||
|
in
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<C-${k}>";
|
||||||
|
action = "<cmd>resize ${s}4<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "${d} Window Height";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
{
|
||||||
|
Up = "Increase";
|
||||||
|
Down = "Decrease";
|
||||||
|
Left = "Decrease";
|
||||||
|
Right = "Increase";
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Buffers - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (mapAttrsToList
|
||||||
|
(
|
||||||
|
k: d:
|
||||||
|
let
|
||||||
|
# previous -> Prev
|
||||||
|
prettyDir = (toUpper (substring 0 1 d)) + (substring 1 3 d);
|
||||||
|
in
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = k;
|
||||||
|
action = "<cmd>b${d}<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "${prettyDir} Buffer";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
{
|
||||||
|
"<S-h>" = "previous";
|
||||||
|
"<S-l>" = "next";
|
||||||
|
"[b" = "previous";
|
||||||
|
"]b" = "next";
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>bD";
|
||||||
|
action = "<cmd>bd<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "Delete Buffer and Window";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# Clear Search/Diff Update/Redraw - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [
|
||||||
|
"i"
|
||||||
|
"n"
|
||||||
|
];
|
||||||
|
key = "<esc>";
|
||||||
|
action = "<cmd>noh<cr><esc>";
|
||||||
|
options = {
|
||||||
|
desc = "Escape and Clear hlsearch";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>ur";
|
||||||
|
action = "<cmd>nohlsearch<bar>diffupdate<bar>normal! <C-l><cr>";
|
||||||
|
options = {
|
||||||
|
desc = "Redraw / Clear hlsearch / Diff Update";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# Better n & N - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (mapCartesianProduct
|
||||||
|
(
|
||||||
|
{ m, d }:
|
||||||
|
let
|
||||||
|
nn = if (d == "Next") then "Nn" else "nN";
|
||||||
|
zv = if (m == "n") then ".'zv'" else "";
|
||||||
|
in
|
||||||
|
{
|
||||||
|
mode = [ m ];
|
||||||
|
key = if (d == "Next") then "n" else "N";
|
||||||
|
action = "'${nn}'[v:searchforward]${zv}";
|
||||||
|
options = {
|
||||||
|
desc = "${d} Search Result";
|
||||||
|
expr = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
{
|
||||||
|
m = [
|
||||||
|
"n"
|
||||||
|
"x"
|
||||||
|
"o"
|
||||||
|
];
|
||||||
|
d = [
|
||||||
|
"Next"
|
||||||
|
"Prev"
|
||||||
|
];
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Undo Break-Points - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (map
|
||||||
|
(c: {
|
||||||
|
mode = [ "i" ];
|
||||||
|
key = c;
|
||||||
|
action = "${c}<c-g>u";
|
||||||
|
})
|
||||||
|
[
|
||||||
|
","
|
||||||
|
"."
|
||||||
|
";"
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
# Search Docs (keywordprog) - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
# https://til.codeinthehole.com/posts/about-how-to-use-keywordprg-effectively/
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>K";
|
||||||
|
action = "<cmd>norm! K<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "Search <keywordprog> for word";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# Better Indenting - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (map
|
||||||
|
(c: {
|
||||||
|
mode = [ "v" ];
|
||||||
|
key = c;
|
||||||
|
action = "${c}gv";
|
||||||
|
})
|
||||||
|
[
|
||||||
|
"<"
|
||||||
|
">"
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
# Commenting - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (mapAttrsToList
|
||||||
|
(k: d: {
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "gc${k}";
|
||||||
|
action = "${k}<esc>Vcx<esc><cmd>normal gcc<cr>fxa<bs>";
|
||||||
|
options = {
|
||||||
|
desc = "Add Comment ${d}";
|
||||||
|
};
|
||||||
|
})
|
||||||
|
{
|
||||||
|
o = "Below";
|
||||||
|
O = "Above";
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# New File - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>fn";
|
||||||
|
action = "<cmd>enew<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "New File";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# Locations/Quickfixes - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>xl";
|
||||||
|
action = "<cmd>lopen<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "Location List";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>xq";
|
||||||
|
action = "<cmd>copen<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "Quickfix list";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
++ (mapAttrsToList
|
||||||
|
(
|
||||||
|
k: d:
|
||||||
|
let
|
||||||
|
cmd = substring 0 4 (toLower d);
|
||||||
|
in
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "${k}q";
|
||||||
|
action = "<cmd>c${cmd}<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "${d} Quickfix";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
{
|
||||||
|
"[" = "Previous";
|
||||||
|
"]" = "Next";
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Diagnostics - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>cd";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() vim.diagnostic.open_float() end";
|
||||||
|
options = {
|
||||||
|
desc = "Line Diagnostics";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
++ (mapCartesianProduct
|
||||||
|
(
|
||||||
|
{ dir, key }:
|
||||||
|
let
|
||||||
|
sevs = {
|
||||||
|
d = {
|
||||||
|
key = "nil";
|
||||||
|
desc = "Diagnostic";
|
||||||
|
};
|
||||||
|
e = {
|
||||||
|
key = "vim.diagnostic.severity.ERROR";
|
||||||
|
desc = "Error";
|
||||||
|
};
|
||||||
|
w = {
|
||||||
|
key = "vim.diagnostic.severity.WARN";
|
||||||
|
desc = "Warning";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
cmd = toLower dir;
|
||||||
|
sev = sevs."${key}".key;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "${if (dir == "Next") then "]" else "["}${key}";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() vim.diagnostic.goto_${cmd}({ severity = ${sev} }) end";
|
||||||
|
options = {
|
||||||
|
desc = "${dir} ${sevs."${key}".desc}";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)
|
||||||
|
{
|
||||||
|
dir = [
|
||||||
|
"Next"
|
||||||
|
"Prev"
|
||||||
|
];
|
||||||
|
key = [
|
||||||
|
"d"
|
||||||
|
"e"
|
||||||
|
"w"
|
||||||
|
];
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Quit - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>qq";
|
||||||
|
action = "<cmd>qa<cr>";
|
||||||
|
options = {
|
||||||
|
desc = "Quit All";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# Inspect - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>ui";
|
||||||
|
action.__raw = # lua
|
||||||
|
"vim.show_pos";
|
||||||
|
options = {
|
||||||
|
desc = "Inspect Position";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# Window Management - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>w";
|
||||||
|
action = "<C-w>";
|
||||||
|
options = {
|
||||||
|
desc = "Windows";
|
||||||
|
remap = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>-";
|
||||||
|
action = "<C-w>s";
|
||||||
|
options = {
|
||||||
|
desc = "Split Window Below";
|
||||||
|
remap = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>|";
|
||||||
|
action = "<C-w>v";
|
||||||
|
options = {
|
||||||
|
desc = "Split Window Right";
|
||||||
|
remap = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>wd";
|
||||||
|
action = "<C-w>c";
|
||||||
|
options = {
|
||||||
|
desc = "Delete Window";
|
||||||
|
remap = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
]
|
||||||
|
|
||||||
|
# Tab Management - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
++ (mapAttrsToList
|
||||||
|
(k: a: {
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader><tab>${k}";
|
||||||
|
action = "<cmd>tab${toLower a}<cr>";
|
||||||
|
options = {
|
||||||
|
desc = if (a == "Only") then "Close Other Tabs" else "${a} Tab";
|
||||||
|
};
|
||||||
|
})
|
||||||
|
{
|
||||||
|
l = "Last";
|
||||||
|
o = "Only";
|
||||||
|
f = "First";
|
||||||
|
"<Tab>" = "New";
|
||||||
|
"]" = "Next";
|
||||||
|
d = "Close";
|
||||||
|
"[" = "Previous";
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
207
modules/nixvim/plugins/base/snacks/default.nix
Normal file
207
modules/nixvim/plugins/base/snacks/default.nix
Normal file
|
@ -0,0 +1,207 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
extraPackages = [ pkgs.lazygit ];
|
||||||
|
|
||||||
|
plugins.snacks = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
bigfile.enabled = true;
|
||||||
|
notifier.enabled = true;
|
||||||
|
quickfile.enabled = true;
|
||||||
|
statuscolumn.enabled = true;
|
||||||
|
words.enabled = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
keymaps = [
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>un";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.notifier.hide() end";
|
||||||
|
options = {
|
||||||
|
desc = "Dismiss All Notifications";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>bd";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.bufdelete() end";
|
||||||
|
options = {
|
||||||
|
desc = "Delete Buffer";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>bo";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.bufdelete.other() end";
|
||||||
|
options = {
|
||||||
|
desc = "Delete Other Buffers";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
# LazyGit - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>gg";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.lazygit() end";
|
||||||
|
options = {
|
||||||
|
desc = "Lazygit";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>gf";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.lazygit.log_file() end";
|
||||||
|
options = {
|
||||||
|
desc = "Lazygit Current File History";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>gl";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.lazygit.log() end";
|
||||||
|
options = {
|
||||||
|
desc = "Lazygit Log";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
# Git - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
{
|
||||||
|
mode = [ "n" ];
|
||||||
|
key = "<leader>gb";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.git.blame_line() end";
|
||||||
|
options = {
|
||||||
|
desc = "Gib Blame Line";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mode = [
|
||||||
|
"n"
|
||||||
|
"x"
|
||||||
|
];
|
||||||
|
key = "<leader>gB";
|
||||||
|
action.__raw = # lua
|
||||||
|
"function() Snacks.gitbrowse() end";
|
||||||
|
options = {
|
||||||
|
desc = "Git Browse";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
# Toggles - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
extraConfigLua = # lua
|
||||||
|
''
|
||||||
|
---@param buf? number
|
||||||
|
function format_enabled(buf)
|
||||||
|
buf = (buf == nil or buf == 0) and vim.api.nvim_get_current_buf() or buf
|
||||||
|
local gaf = vim.g.autoformat
|
||||||
|
local baf = vim.b[buf].autoformat
|
||||||
|
|
||||||
|
-- If the buffer has a local value, use that
|
||||||
|
if baf ~= nil then
|
||||||
|
return baf
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Otherwise use the global value if set, or true by default
|
||||||
|
return gaf == nil or gaf
|
||||||
|
end
|
||||||
|
|
||||||
|
---@param enable? boolean
|
||||||
|
---@param buf? boolean
|
||||||
|
function format_enable(state, buf)
|
||||||
|
if enable == nil then
|
||||||
|
enable = true
|
||||||
|
end
|
||||||
|
|
||||||
|
if buf then
|
||||||
|
vim.b.autoformat = enable
|
||||||
|
else
|
||||||
|
vim.g.autoformat = enable
|
||||||
|
vim.b.autoformat = nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
---@param buf? boolean
|
||||||
|
function toggle_format(buf)
|
||||||
|
return Snacks.toggle({
|
||||||
|
name = "Auto Format (" .. (buf and "Buffer" or "Global") .. ")",
|
||||||
|
get = function()
|
||||||
|
if not buf then
|
||||||
|
return vim.g.autoformat == nil or vim.g.autoformat
|
||||||
|
end
|
||||||
|
return format_enabled()
|
||||||
|
end,
|
||||||
|
set = function(state)
|
||||||
|
format_enable(state, buf)
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
toggle_format():map("<leader>uf")
|
||||||
|
toggle_format(true):map("<leader>uF")
|
||||||
|
|
||||||
|
Snacks.toggle.option("spell", { name = "Spelling"}):map("<leader>us")
|
||||||
|
Snacks.toggle.option("wrap", {name = "Wrap"}):map("<leader>uw")
|
||||||
|
Snacks.toggle.option("relativenumber", { name = "Relative Number"}):map("<leader>uL")
|
||||||
|
Snacks.toggle.diagnostics():map("<leader>ud")
|
||||||
|
Snacks.toggle.line_number():map("<leader>ul")
|
||||||
|
Snacks.toggle.option("conceallevel", {off = 0, on = vim.o.conceallevel > 0 and vim.o.conceallevel or 2}):map("<leader>uc")
|
||||||
|
Snacks.toggle.treesitter():map("<leader>uT")
|
||||||
|
Snacks.toggle.option("background", { off = "light", on = "dark" , name = "Dark Background"}):map("<leader>ub")
|
||||||
|
if vim.lsp.inlay_hint then
|
||||||
|
Snacks.toggle.inlay_hints():map("<leader>uh")
|
||||||
|
end
|
||||||
|
|
||||||
|
function maximize_window()
|
||||||
|
---@type {k:string, v:any}[]?
|
||||||
|
local maximized = nil
|
||||||
|
return Snacks.toggle({
|
||||||
|
name = "Maximize",
|
||||||
|
get = function()
|
||||||
|
return maximized ~= nil
|
||||||
|
end,
|
||||||
|
set = function(state)
|
||||||
|
if state then
|
||||||
|
maximized = {}
|
||||||
|
local function set(k, v)
|
||||||
|
table.insert(maximized, 1, { k = v, v = vim.o[k] })
|
||||||
|
vim.o[k] = v
|
||||||
|
end
|
||||||
|
set("winwidth", 999)
|
||||||
|
set("winheight", 999)
|
||||||
|
set("winminwidth", 10)
|
||||||
|
set("winminheight", 4)
|
||||||
|
vim.cmd("wincmd =")
|
||||||
|
vim.api.nvim_create_autocmd("ExitPre", {
|
||||||
|
once = true,
|
||||||
|
group = vim.api.nvim_create_augroup("marleyvim_restore_max_exit_pre", { clear = true }),
|
||||||
|
desc = "Restore width/height when closing Neovim while maximized",
|
||||||
|
callback = function()
|
||||||
|
maximize_window.set(false)
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
else
|
||||||
|
for _, opt in ipairs(maximized) do
|
||||||
|
vim.o[opt.k] = opt.v
|
||||||
|
end
|
||||||
|
maximized = nil
|
||||||
|
vim.cmd("wincmd =")
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
maximize_window():map("<leader>wm")
|
||||||
|
'';
|
||||||
|
}
|
Loading…
Reference in a new issue