Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yorickpeterse/nvim-window
Easily jump between NeoVim windows.
https://github.com/yorickpeterse/nvim-window
neovim nvim plugin
Last synced: 6 days ago
JSON representation
Easily jump between NeoVim windows.
- Host: GitHub
- URL: https://github.com/yorickpeterse/nvim-window
- Owner: yorickpeterse
- License: mpl-2.0
- Created: 2023-03-16T00:38:20.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-11-04T15:26:23.000Z (2 months ago)
- Last Synced: 2024-12-29T11:09:30.956Z (13 days ago)
- Topics: neovim, nvim, plugin
- Language: Lua
- Homepage:
- Size: 51.8 KB
- Stars: 132
- Watchers: 4
- Forks: 12
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-neovim - yorickpeterse/nvim-window - Easily jump between Neovim windows. (Split and Window / Indent)
README
# nvim-window
A simple and opinionated NeoVim plugin for switching between windows in the
current tab page.**NOTE:** this plugin is considered feature complete, and as such no new
features will be added _unless_ I have a need for it myself.## Rationale
In (Neo)Vim you can navigate between windows using `Control+W`, followed by a
motion. For example, to move to the window on the right of the current one you'd
press `Control+W l`. This works for simple scenarios, but gets annoying fast.
Consider the following window layout:```
+---+---+---+---+
| | | | |
| A | B | C | D |
| | | | |
+---+---+---+---+
```Assuming window A is the current window your cursor is in, and you want to move
to window C, you might press `Control+W 2l`. This is doable, but having to count
the number of steps every time gets tedious.It gets more annoying when you want to move to a window above your current one,
but the window is on the right:```
+---+---+---+
| | | |
| A | B | C |
| | | |
+---+---+---+
| D |
+-----------+
```Assuming window D is active and you want to move to window B, you'd have to take
two steps:- `Control+W k` to move to window A
- `Control+W l` to move to window BWhile there may be other ways of doing this, the use of `Control+W` is probably
the easiest approach to remember; and it's still annoying.This is where nvim-window comes in: it makes it trivial to jump between windows
(in the current tab page), without the need for knowing how far away they are or
relying on a fuzzy finder (and having to type out the window paths).Using nvim-window, press your binding of choice to activate nvim-window, press
one letter (or two, if there are many windows), and the given window becomes
active. This makes it _much_ easier to quickly jump between windows.You can see this in action here:
[![nvim-window using floating windows](https://asciinema.org/a/659545.svg)](https://asciinema.org/a/659545)
You can also render the hints to the `statusline`:
[![nvim-window using the statusline](https://asciinema.org/a/659546.svg)](https://asciinema.org/a/659546)
## Requirements
NeoVim 0.5 or newer
## Limitations
- Limited styling options to keep the code simple
- "Only" handles up to 52 windows in a single tab page
- No hinting of characters as you type (like hop.nvim), to keep the code simple## Installation
First add this plugin using your plugin manager of choice.
### lazy.nvim
```lua
{
"yorickpeterse/nvim-window",
keys = {
{ "wj", "lua require('nvim-window').pick()", desc = "nvim-window: Jump to window" },
},
config = true,
}
```### vim-plug
```vim
Plug 'https://gitlab.com/yorickpeterse/nvim-window.git'
```For the exact steps necessary, please refer to your plugin manager's
documentation.Once installed you need to add a key binding, as nvim-window doesn't define any
key bindings for you. You can set up a binding like so:```vim
map w :lua require('nvim-window').pick()
```I personally use comma (`,`), as this allows me to switch between windows using
(most of the time) only two keys:```vim
map , :lua require('nvim-window').pick()
```## Configuration
The default settings should be good enough for most. In case you want to change
them (e.g. by changing the background of the floating window), you can do so as
follows:```lua
require('nvim-window').setup({
-- The characters available for hinting windows.
chars = {
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o',
'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'
},-- A group to use for overwriting the Normal highlight group in the floating
-- window. This can be used to change the background color.
normal_hl = 'Normal',-- The highlight group to apply to the line that contains the hint characters.
-- This is used to make them stand out more.
hint_hl = 'Bold',-- The border style to use for the floating window.
border = 'single',-- How the hints should be rendered. The possible values are:
--
-- - "float" (default): renders the hints using floating windows
-- - "status": renders the hints to a string and calls `redrawstatus`,
-- allowing you to show the hints in a status or winbar line
render = 'float',
})
```You can place this in your `init.lua` before or after defining the mapping. You
can also dump it in a different Lua file; just make sure to actually load that
file :)## License
All source code in this repository is licensed under the Mozilla Public License
version 2.0, unless stated otherwise. A copy of this license can be found in the
file "LICENSE".