Skip to content

Antony-AXS/indicator.nvim

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Indicator.nvim

What is Indicator.nvim ?

Indicator.nvim is a lightweight plugin that displays window numbers on the screen, making it easy to navigate through windows in a tab. It also highlights the window you jump into, enhancing your navigation experience.

Preview

indicator

Required

  • neovim >= 0.10
  • plenary.nvim

Optional

  • lualine.nvim - (for window and tab stats indication on status bar)

⇁ Installation

  • Neovim 0.10 + required
  • Ensure that a Nerd Font is installed and configured in your terminal emulator.
  • Install using your preferred plugin manager (e.g., lazy.nvim and packer.nvim).
  • Keymap examples are also provided. Feel free to modify them to suit your preferences.
{
   "Antony-AXS/indicator.nvim",
   event = "VeryLazy",
   dependencies = { "nvim-lua/plenary.nvim" },
   config = function()
     local Indicator = require("indicator")
     
     Indicator.setup({
       indicator_event = true, -- turns ON the Indicator feature by default
       window_highlight_event = false,
     })
   end
}
use {
  "Antony-AXS/indicator.nvim",
  event = "VimEnter",
  requires = { "nvim-lua/plenary.nvim" },
  config = function()
    local Indicator = require("indicator")
    
    Indicator.setup({
      indicator_event = true, -- turns ON the Indicator feature by default
      window_highlight_event = false,
    })
  end
}

Indicator API

Functions Description
indicateAll To Indicate All the Opened Windows in a tab once with their perspective number.
indicateCurrent To Indicate the Current Window number in which the cursor is at that moment Located.
triggerWindowManager Mimics inbuilt neovim window management system, only 'jump' and 'close' feature is avaliable.
indicator_event_activate Triggers an event listener to inidcate the window number of the window you jump into.
indicator_event_deactivate Disables the event listener to inidcate the window number of the window you jump into.
window_highlight_event_activate Triggers an event to Highlight the window you jump into everytime.
window_highlight_event_deactivate Disables the event to Highlight the window you jump into everytime.

Keymaps for Indicator API

  vim.keymap.set("n", "<leader>bx", function()
  	Indicator.indicateCurrent() -- takes in an integer arugment to extend the indicator display time
  end, { silent = true })

  vim.keymap.set("n", "<leader>bv", function()
  	Indicator.indicateAll()
  end, { silent = true })
  
  vim.keymap.set("n", "<leader>im", Indicator.triggerWindowManager, {})
  vim.keymap.set("n", "<leader>it", Indicator.indicator_event_activate, {})
  vim.keymap.set("n", "<leader>ir", Indicator.indicator_event_deactivate, {})

Window Management with Visual Indication

Neovim's in-built window management system is replicated here with added visual indicators, focusing on only the window 'jumping', 'shifting', 'rotating' and 'closing' features.
Set a keymap to trigger the function triggerWindowManager, and then use key commands to perform the following actions:

Action Keys Description
Shift number + H to shift the window to the left.
number + J to shift the window to the bottom.
number + K to shift the window to the top.
number + L to shift the window to the right.
Close number + c to close the desired window only.
number + o to keep the desired window and close the rest.
number + q to quit the desired window only.
Rotate number + r To continuously rotate all windows in the current tab 'clockwise'
until the rotation instance expires.
(expiration only happens only after the indicators disappear)
number + R To continuously rotate all windows in the current tab 'anticlockwise'
until the rotation instance expires.
Jump number + w to jump to the desired window.

Here, "number" in the table refers to the window number displayed on the screen.

Note: If a window number is not provided before pressing the valid keys, the following actions will be executed in the current window where the cursor is located.

Preview

window_management

About Window Highlight Feature

  • Setting 'window_highlight_event = true' in setup function sets the hightlight feature ON by default.
  • You can use 'Indicator.window_highlight_event_deactivate' to turn it OFF.
  • You can use 'Indicator.window_highlight_event_activate' to turn it ON.

Preview

window_highlight

Setup

 config = function()
   local Indicator = require("indicator")
   Indicator.setup({
    window_highlight_event = true, -- turns ON the window highlight feature by default
   })
 end

Keymaps

 vim.keymap.set("n", "<leader>iq", Indicator.window_highlight_event_activate, {})
 vim.keymap.set("n", "<leader>iw", Indicator.window_highlight_event_deactivate, {})

Status Line Indication

If you have lualine.nvim installed, window and tab count stats can be displayed on the status bar.

Tab count has two variables:

  • 1st one indicates the current tab you are in.
  • 2nd indicates the total number of tabs open in the neovim instance.

Window count has three variables:

  • 1st is the window number you cursor is in.
  • 2nd is the total number of windows that are open in the current tab.
  • 3rd is the total window count across all the open tabs in the neovim instance.

Preview

status_bar_1 status_bar_2

If only one tab is open, the tab stats won't appear, and the 3rd parameter for window stats will also be hidden.
They will only be displayed if more than one tab is open.

Setup

 Indicator.setup({
  window_count_status = {
   tab = {
     activate = true, -- Displays the tab stats on the status bar.
     position = { section = "x", index = 1 }, -- To configure the position of the tab stats.
     color = "" -- Sets the color of tab stats. If not set, the default color will be yellow.
   },
   window = {
     activate = true, -- Displays the window stats on the status bar.
     position = { section = "x", index = 1 }, -- To configure the position of the window stats.
     color = "" -- Sets the color of window stats. If not set, the default color will be yellow.
   },
  },
 })

Help Doc

The indicator.nvim help doc explains the features and functionality of the plugin in detail.
Use the commands below to jump to each specific sections of the document.

Doc Commands Description
:help indicator.nvim to jump to the start of the document
:help indicator_commands to jump to the commands section of the document
:help indicator_functions to jump to the functions section of the document
:help indicator_configuration to jump to the configuration section of the document

Welcome Your Ideas

If you have any ideas or suggestions to improve this plugin, I’d love to hear from you! Your feedback is always welcome.

About

A Neovim plugin for seamless window navigation.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published