Awesome
<p align="center"> <h2 align="center">heirline.nvim</h2> </p> <p align="center"> <img src="heirline.png" width="600" > </p> <p align="center">The ultimate Neovim Statusline for tinkerers</p>About
Heirline.nvim is a no-nonsense Neovim plugin made for rendering statusline/winbar/tabline/statuscolumn format strings. It is designed around recursive inheritance to be exceptionally fast and versatile.
Heirline does not provide any defaults, in fact, heirline can be thought of as an API to generate Vim status format strings.
Why another statusline plugin?
Heirline picks up from other popular customizable statusline plugins like galaxyline and feline but removes all the hard-coded guides and offers you thousands times more freedom. But freedom has a price: responsibility. I don't get to tell you what your statusline should do. You're in charge! With Heirline, you have a framework to easily implement whatever you can imagine, from simple to complex rules!
<p align="center"> <img width="1578" alt="heirline_prev" src="https://user-images.githubusercontent.com/36300441/187208978-3054fea6-0e3a-432c-a1fc-b4a29da36a7c.png"> </p>Features:
- Conditionals: Build custom active/inactive and buftype/filetype/bufname statuslines or single components.
- Highlight propagation: Seamlessly surround components within separators and/or set the (dynamic) coloring of a bunch of components at once.
- Modularity: Statusline components can be reutilized/rearranged and will behave according to their position in the genealogical tree.
- Update triggers: Re-evaluate components only when some condition is met or specific autocommand events are fired.
- Clickable: Write pure lua callbacks to be executed when clicking a component.
- Dynamic resizing: Specify how components should resize depending on available space.
- Full control: You have hooks to fully control the statusline evaluation cycle.
Heirline is not for everyone, heirline is for people who like tailoring their own tools (and also like lua):
- No default statusline is provided
- You must write your own statusline
But don't you worry! Along with the inheritance comes THE FEATUREFUL COOKBOOK 📖 of a distant relative. Your dream 🪄 statusline is a copypaste away!
Installation
Use your favorite plugin manager
Packer
use({
"rebelot/heirline.nvim",
-- You can optionally lazy-load heirline on UiEnter
-- to make sure all required plugins and colorschemes are loaded before setup
-- event = "UiEnter",
config = function()
require("heirline").setup({...})
end
})
Setup
require("heirline").setup({
statusline = {...},
winbar = {...},
tabline = {...},
statuscolumn = {...},
})
Calling setup
will load your statusline(s). To learn how to write a StatusLine, see the docs.
Donate
Buy me coffee and support my work ;)