2020-12-30 17:31:38 +01:00
|
|
|
# lualine.nvim
|
2021-09-13 21:33:18 -06:00
|
|
|
|
|
|
|
<!-- panvimdoc-ignore-start -->
|
|
|
|
|
2021-01-06 14:18:18 +01:00
|
|
|
![code size](https://img.shields.io/github/languages/code-size/hoob3rt/lualine.nvim?style=flat-square)
|
|
|
|
![license](https://img.shields.io/github/license/hoob3rt/lualine.nvim?style=flat-square)
|
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
<!-- panvimdoc-ignore-end -->
|
|
|
|
|
2021-08-22 15:25:31 +06:00
|
|
|
A fast and easy to configure statusline plugin for neovim
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
`lualine.nvim` requires neovim 0.5
|
2021-01-03 00:14:48 +01:00
|
|
|
|
2021-09-17 08:44:43 +06:00
|
|
|
<!-- panvimdoc-ignore-start -->
|
|
|
|
|
|
|
|
This is a fork of [hoob3rt/lualine.nvim](https://github.com/hoob3rt/lualine.nvim).
|
|
|
|
If you're switching from there please checkout [BREAKING_CHANGES.md](./BREAKING_CHANGES.md)
|
|
|
|
to see what you may have to change in your config.
|
|
|
|
|
|
|
|
<!-- panvimdoc-ignore-end -->
|
|
|
|
|
2021-01-03 00:14:48 +01:00
|
|
|
## Contributing
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-01-08 00:22:01 +01:00
|
|
|
Feel free to create an issue/pr if you want to see anything else implemented.
|
2021-08-22 15:25:31 +06:00
|
|
|
If you have some question or need help with configuration start a [discussion](https://github.com/shadmansaleh/lualine.nvim/discussions).
|
2021-01-08 00:22:01 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
Please read [CONTRIBUTING.md](./CONTRIBUTING.md) before opening a pr.
|
2021-08-22 15:25:31 +06:00
|
|
|
You can also help with documentation in [wiki](https://github.com/shadmansaleh/lualine.nvim/wiki)
|
2021-05-13 21:01:37 +02:00
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
<!-- panvimdoc-ignore-start -->
|
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
## Screenshots
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:41:05 +01:00
|
|
|
Here is a preview of how lualine can look like.
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-19 13:44:38 +02:00
|
|
|
<p>
|
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/41551030/108650373-bb025580-74bf-11eb-8682-2c09321dd18e.png'/>
|
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/41551030/108650377-bd64af80-74bf-11eb-9c55-fbfc51b39fe8.png'/>
|
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/41551030/108650378-be95dc80-74bf-11eb-9718-82b242ecdd54.png'/>
|
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/41551030/108650381-bfc70980-74bf-11eb-9245-85c48f0f154a.png'/>
|
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/41551030/103467925-32372b00-4d54-11eb-88d6-6d39c46854d8.png'/>
|
|
|
|
</p>
|
2021-01-03 00:14:48 +01:00
|
|
|
|
|
|
|
Screenshots of all available themes are listed in [THEMES.md](./THEMES.md)
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
For those who want to break the norms. You can create custom looks in lualine.
|
2021-04-07 19:38:08 +06:00
|
|
|
|
|
|
|
**Example** :
|
|
|
|
|
2021-08-14 01:34:33 +06:00
|
|
|
- [evil_lualine](examples/evil_lualine.lua)
|
2021-05-19 13:44:38 +02:00
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/13149513/113875129-4453ba00-97d8-11eb-8f21-94a9ef565db3.png'/>
|
2021-04-07 19:38:08 +06:00
|
|
|
|
2021-08-30 21:30:48 +05:30
|
|
|
- [bubbles](examples/bubbles.lua)
|
|
|
|
<img width='700' src='https://user-images.githubusercontent.com/20235646/131350468-fc556196-5f46-4bfe-a72e-960f6a58db2c.png'/>
|
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
<!-- panvimdoc-ignore-end -->
|
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
## Performance compared to other plugins
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
Unlike other statusline plugins lualine loads only defined components, nothing else.
|
|
|
|
|
|
|
|
Startup time performance measured with an amazing plugin [tweekmonster/startuptime.vim](https://github.com/tweekmonster/startuptime.vim)
|
|
|
|
|
2021-01-06 18:23:23 +01:00
|
|
|
All times are measured with only `startuptime.vim` and given statusline plugin installed
|
|
|
|
|
2021-01-07 16:37:32 +01:00
|
|
|
| clean vimrc | lualine | lightline | airline |
|
|
|
|
| :------------: | :----------: | :----------: | :----------: |
|
|
|
|
| 8.943 ms | 9.034 ms | 11.463 ms | 13.425 ms |
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
|
|
|
|
## Installation
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
### [vim-plug](https://github.com/junegunn/vim-plug)
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
```vim
|
|
|
|
Plug 'hoob3rt/lualine.nvim'
|
|
|
|
" If you want to have icons in your statusline choose one of these
|
|
|
|
Plug 'kyazdani42/nvim-web-devicons'
|
|
|
|
Plug 'ryanoasis/vim-devicons'
|
|
|
|
```
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
### [packer.nvim](https://github.com/wbthomason/packer.nvim)
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
```lua
|
|
|
|
use {
|
|
|
|
'hoob3rt/lualine.nvim',
|
|
|
|
requires = {'kyazdani42/nvim-web-devicons', opt = true}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Usage and customization
|
2021-03-02 18:58:34 +06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
Lualine has sections as shown below.
|
|
|
|
|
|
|
|
```
|
|
|
|
+-------------------------------------------------+
|
2021-03-11 00:37:39 +01:00
|
|
|
| A | B | C X | Y | Z |
|
2020-12-30 17:31:38 +01:00
|
|
|
+-------------------------------------------------+
|
|
|
|
```
|
|
|
|
|
|
|
|
Each sections holds it's components e.g. current vim's mode.
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
<details><summary>Default config</summary>
|
|
|
|
|
|
|
|
```lua
|
|
|
|
require'lualine'.setup {
|
|
|
|
options = {
|
|
|
|
icons_enabled = true,
|
2021-08-14 14:39:10 +06:00
|
|
|
theme = 'auto',
|
2021-09-14 21:14:23 +06:00
|
|
|
component_separators = { left = '', right = ''},
|
|
|
|
section_separators = { left = '', right = ''},
|
2021-05-13 21:01:37 +02:00
|
|
|
disabled_filetypes = {}
|
|
|
|
},
|
|
|
|
sections = {
|
|
|
|
lualine_a = {'mode'},
|
2021-08-17 00:30:33 +06:00
|
|
|
lualine_b = {'branch', 'diff',
|
2021-08-27 00:15:18 +06:00
|
|
|
{'diagnostics', sources={'nvim_lsp', 'coc'}}},
|
2021-05-13 21:01:37 +02:00
|
|
|
lualine_c = {'filename'},
|
|
|
|
lualine_x = {'encoding', 'fileformat', 'filetype'},
|
|
|
|
lualine_y = {'progress'},
|
|
|
|
lualine_z = {'location'}
|
|
|
|
},
|
|
|
|
inactive_sections = {
|
|
|
|
lualine_a = {},
|
|
|
|
lualine_b = {},
|
|
|
|
lualine_c = {'filename'},
|
|
|
|
lualine_x = {'location'},
|
|
|
|
lualine_y = {},
|
|
|
|
lualine_z = {}
|
|
|
|
},
|
|
|
|
tabline = {},
|
|
|
|
extensions = {}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-08-04 07:13:37 +06:00
|
|
|
If you want to get your current lualine config. you can
|
2021-09-14 21:14:23 +06:00
|
|
|
do so with
|
2021-08-04 07:13:37 +06:00
|
|
|
```lua
|
|
|
|
require'lualine'.get_config()
|
|
|
|
|
|
|
|
```
|
|
|
|
|
2021-05-13 23:19:11 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 23:19:11 +02:00
|
|
|
### Starting lualine
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 23:19:11 +02:00
|
|
|
```lua
|
|
|
|
require('lualine').setup()
|
|
|
|
```
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
### Setting a theme
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2020-12-30 17:31:38 +01:00
|
|
|
```lua
|
2021-03-17 01:22:00 +01:00
|
|
|
options = {theme = 'gruvbox'}
|
2020-12-30 17:31:38 +01:00
|
|
|
```
|
|
|
|
|
2021-01-03 00:14:48 +01:00
|
|
|
All available themes are listed in [THEMES.md](./THEMES.md)
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-01-03 00:14:48 +01:00
|
|
|
Please create a pr if you managed to port a popular theme before me, [here is how to do it](./CONTRIBUTING.md).
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-04-12 12:25:21 +06:00
|
|
|
<details>
|
2021-05-13 21:01:37 +02:00
|
|
|
<summary>Customizing themes</summary>
|
2021-04-12 12:25:21 +06:00
|
|
|
|
|
|
|
```lua
|
|
|
|
local custom_gruvbox = require'lualine.themes.gruvbox'
|
2021-05-27 19:53:27 +02:00
|
|
|
-- Change the background of lualine_c section for normal mode
|
2021-04-12 12:25:21 +06:00
|
|
|
custom_gruvbox.normal.c.bg = '#112233' -- rgb colors are supported
|
|
|
|
require'lualine'.setup{
|
|
|
|
options = { theme = custom_gruvbox },
|
|
|
|
...
|
|
|
|
}
|
|
|
|
```
|
2021-05-13 21:01:37 +02:00
|
|
|
Theme structure is available [here](https://github.com/hoob3rt/lualine.nvim/blob/master/CONTRIBUTING.md#adding-a-theme)
|
2021-04-12 12:25:21 +06:00
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
### Separators
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-09-13 21:41:19 -06:00
|
|
|
Lualine defines two kinds of separators:
|
|
|
|
|
|
|
|
* `section_separators` - separators between sections
|
|
|
|
* `components_separators` - separators between components in sections
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
```lua
|
2021-03-17 01:22:00 +01:00
|
|
|
options = {
|
2021-09-14 21:14:23 +06:00
|
|
|
section_separators = { left = '', right = ''},
|
|
|
|
component_separators = { left = '', right = ''}
|
2021-03-17 01:22:00 +01:00
|
|
|
}
|
2020-12-30 17:31:38 +01:00
|
|
|
```
|
|
|
|
|
2021-09-14 21:14:23 +06:00
|
|
|
Here left means it'll be used for left sections (a, b, c) and right means
|
|
|
|
it'll be used for right sections (x, y, z).
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
<details><summary>Disabling separators</summary>
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
```lua
|
2021-03-19 03:52:13 +01:00
|
|
|
options = {section_separators = '', component_separators = ''}
|
2020-12-30 17:31:38 +01:00
|
|
|
```
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
</details>
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
### Changing components in lualine sections
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
sections = {lualine_a = {'mode'}}
|
2020-12-30 17:31:38 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
<details>
|
|
|
|
<summary><b>Available components</b></summary>
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
* `branch` (git branch)
|
|
|
|
* `diagnostics` (diagnostics count from your prefered source)
|
|
|
|
* `encoding` (file encoding)
|
|
|
|
* `fileformat` (file format)
|
|
|
|
* `filename`
|
2021-09-03 16:16:10 +06:00
|
|
|
* `filesize`
|
2021-05-13 21:01:37 +02:00
|
|
|
* `filetype`
|
|
|
|
* `hostname`
|
|
|
|
* `location` (location in file in line:column format)
|
|
|
|
* `mode` (vim mode)
|
|
|
|
* `progress` (%progress in file)
|
|
|
|
* `diff` (git diff status)
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
#### Custom components
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
##### Lua functions as lualine component
|
2020-12-30 17:31:38 +01:00
|
|
|
|
|
|
|
```lua
|
|
|
|
local function hello()
|
|
|
|
return [[hello world]]
|
|
|
|
end
|
2021-03-22 15:13:51 +01:00
|
|
|
sections = {lualine_a = {hello}}
|
2020-12-30 17:31:38 +01:00
|
|
|
```
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
##### Vim functions as lualine component
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
```lua
|
|
|
|
sections = {lualine_a = {'FugitiveHead'}}
|
|
|
|
```
|
2021-02-16 00:09:12 +06:00
|
|
|
|
2021-08-20 08:15:57 +06:00
|
|
|
#### Vim's statusline items as lualine component
|
|
|
|
|
|
|
|
```lua
|
|
|
|
sections = {lualine_c = {'%=', '%t%m', '%3p'}}
|
|
|
|
```
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
##### Vim variables as lualine component
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
Variables from `g:`, `v:`, `t:`, `w:`, `b:`, `o`, `go:`, `vo:`, `to:`, `wo:`, `bo:` scopes can be used.
|
2021-02-10 16:40:29 +06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
See `:h lua-vim-variables` and `:h lua-vim-options` if you are not sure what to use.
|
2021-02-10 16:40:29 +06:00
|
|
|
|
2021-03-03 00:34:45 +01:00
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
sections = {lualine_a = {'g:coc_status', 'bo:filetype'}}
|
2021-02-10 16:40:29 +06:00
|
|
|
```
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
##### Lua expressions as lualine component
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
You can use any valid lua expression as a component including
|
|
|
|
* oneliners
|
|
|
|
* global variables
|
|
|
|
* require statements
|
|
|
|
```lua
|
2021-09-03 18:49:05 +06:00
|
|
|
sections = {lualine_c = {"os.date('%a')", 'data', "require'lsp-status'.status()"}}
|
2021-05-13 21:01:37 +02:00
|
|
|
```
|
|
|
|
`data` is a global variable in this example.
|
|
|
|
|
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
### Component options
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
Component options can change the way a component behave.
|
|
|
|
There are two kinds of options:
|
2021-05-13 21:08:36 +02:00
|
|
|
* global options affecting all components
|
|
|
|
* local options affecting specific
|
2021-05-13 21:01:37 +02:00
|
|
|
|
|
|
|
Global options can be used as local options (can be applied to specific components)
|
|
|
|
but you cannot use local options as global.
|
|
|
|
Global option used locally overwrites the global, for example:
|
|
|
|
```lua
|
|
|
|
require'lualine'.setup {
|
2021-09-14 21:14:23 +06:00
|
|
|
options = {fmt = string.lower},
|
|
|
|
sections = {lualine_a = {
|
|
|
|
{'mode', fmt = function(str) return str:sub(1,1) end}},
|
|
|
|
lualine_b = {'branch'}}
|
2021-05-13 21:01:37 +02:00
|
|
|
}
|
|
|
|
```
|
2021-02-10 16:40:29 +06:00
|
|
|
|
2021-09-14 21:14:23 +06:00
|
|
|
`mode` will be formatted with the passed fa=unction so only first char will be
|
|
|
|
shown . On the other hand branch will be formatted with global formatter
|
|
|
|
`string.lower` so it will be showed in lower case.
|
2021-02-10 16:40:29 +06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
#### Available options
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
<details>
|
|
|
|
<summary><b>Global options</b></summary>
|
2021-02-10 16:40:29 +06:00
|
|
|
|
2021-03-03 00:34:45 +01:00
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
options = {
|
2021-09-03 18:49:05 +06:00
|
|
|
icons_enabled = true, -- displays icons in alongside component
|
2021-05-13 21:01:37 +02:00
|
|
|
padding = 1, -- adds padding to the left and right of components
|
2021-09-14 21:14:23 +06:00
|
|
|
-- padding can be specified to left or right separately like
|
|
|
|
-- padding = { left = left_padding, right = right_padding }
|
|
|
|
fmt = nil -- fmt function, formats component's output
|
2021-05-13 21:01:37 +02:00
|
|
|
}
|
2021-02-10 16:40:29 +06:00
|
|
|
```
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-04-12 12:14:43 +06:00
|
|
|
<details>
|
2021-05-13 21:01:37 +02:00
|
|
|
<summary><b>Local options</b></summary>
|
2021-04-12 12:14:43 +06:00
|
|
|
|
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
sections = {
|
|
|
|
lualine_a = {
|
|
|
|
{
|
|
|
|
'mode',
|
2021-09-03 18:49:05 +06:00
|
|
|
icon = nil, -- displays icon in front of the component
|
2021-05-07 23:24:42 +06:00
|
|
|
separator = nil, -- Determines what separator to use for the component.
|
2021-08-26 18:09:59 +06:00
|
|
|
-- when a string is given it's treated as component_separator.
|
|
|
|
-- When a table is given it's treated as section_separator.
|
|
|
|
-- This options can be used to set colored separators
|
2021-09-14 21:14:23 +06:00
|
|
|
-- arround component. Option need to be set like
|
|
|
|
-- `separator = { left = '', right = ''}`.
|
|
|
|
-- Where left will be placed in left side of component
|
|
|
|
-- and right will be placed in right side of component
|
2021-08-26 18:09:59 +06:00
|
|
|
-- Passing empty string disables that separator
|
2021-09-14 21:14:23 +06:00
|
|
|
cond = nil, -- condition function, component is loaded when function returns true
|
2021-05-13 21:01:37 +02:00
|
|
|
-- custom color for component in format
|
|
|
|
-- color = {fg = '#rrggbb', bg= '#rrggbb', gui='style'}
|
|
|
|
-- or highlight group
|
|
|
|
-- color = "WarningMsg"
|
2021-08-20 18:32:56 +06:00
|
|
|
color = nil,
|
|
|
|
-- Type option specifies what type a component is.
|
|
|
|
-- When type is omitted lualine will guess it.
|
|
|
|
-- Available types [format: type_name(example)]
|
|
|
|
-- mod(branch/filename), stl(%f/%m), var(g:coc_status/bo:modifiable),
|
|
|
|
-- luae(lua expressions), vimf(viml function name)
|
|
|
|
-- luae is short for lua-expression and vimf is short fror vim-function
|
|
|
|
type = nil,
|
2021-05-13 21:01:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-04-12 12:14:43 +06:00
|
|
|
```
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-02-16 00:09:12 +06:00
|
|
|
<details>
|
2021-05-13 21:01:37 +02:00
|
|
|
<summary><b>Component specific local options</b></summary>
|
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
#### diagnostics component options
|
2021-04-06 20:03:41 +06:00
|
|
|
|
2021-02-20 05:02:17 +01:00
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
sections = {
|
|
|
|
lualine_a = {
|
|
|
|
{
|
|
|
|
'diagnostics',
|
|
|
|
-- table of diagnostic sources, available sources:
|
2021-09-17 18:50:32 +06:00
|
|
|
-- 'nvim_lsp', 'nvim', 'coc', 'ale', 'vim_lsp'
|
2021-08-27 00:15:18 +06:00
|
|
|
-- Or a function that returns a table like
|
2021-09-17 14:40:10 +06:00
|
|
|
-- {error=error_cnt, warn=warn_cnt, info=info_cnt, hint=hint_cnt}
|
2021-08-17 00:17:56 +06:00
|
|
|
sources = {},
|
2021-05-13 21:01:37 +02:00
|
|
|
-- displays diagnostics from defined severity
|
2021-05-25 15:13:43 -05:00
|
|
|
sections = {'error', 'warn', 'info', 'hint'},
|
2021-05-13 21:01:37 +02:00
|
|
|
-- all colors are in format #rrggbb
|
2021-09-14 21:14:23 +06:00
|
|
|
diagnostics_color = {
|
|
|
|
error = nil, -- changes diagnostic's error foreground color
|
|
|
|
warn = nil, -- changes diagnostic's warn foreground color
|
|
|
|
info = nil, -- Changes diagnostic's info foreground color
|
|
|
|
hint = nil, -- Changes diagnostic's hint foreground color
|
|
|
|
}
|
2021-05-25 15:13:43 -05:00
|
|
|
symbols = {error = 'E', warn = 'W', info = 'I', hint = 'H'}
|
2021-07-25 13:48:50 +06:00
|
|
|
update_in_insert = false, -- Update diagnostics in insert mode
|
2021-05-13 21:01:37 +02:00
|
|
|
}
|
2021-04-06 20:03:41 +06:00
|
|
|
}
|
|
|
|
}
|
2021-02-20 05:02:17 +01:00
|
|
|
```
|
2021-05-13 21:01:37 +02:00
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
#### filename component options
|
2021-02-16 00:09:12 +06:00
|
|
|
|
2021-04-06 20:03:41 +06:00
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
sections = {
|
|
|
|
lualine_a = {
|
|
|
|
{
|
|
|
|
'filename',
|
2021-09-03 18:49:05 +06:00
|
|
|
file_status = true, -- displays file status (readonly status, modified status)
|
|
|
|
path = 0, -- 0 = just filename, 1 = relative path, 2 = absolute path
|
2021-05-28 15:49:44 -04:00
|
|
|
shorting_target = 40 -- Shortens path to leave 40 space in the window
|
|
|
|
-- for other components. Terrible name any suggestions?
|
2021-05-13 21:01:37 +02:00
|
|
|
}
|
|
|
|
}
|
2021-04-06 20:03:41 +06:00
|
|
|
}
|
|
|
|
```
|
2021-02-20 05:02:17 +01:00
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
#### filetype component options
|
2021-02-20 05:02:17 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
```lua
|
|
|
|
sections = {
|
|
|
|
lualine_a = {
|
|
|
|
{
|
|
|
|
'filetype',
|
2021-05-12 15:17:51 +06:00
|
|
|
colored = true, -- displays filetype icon in color if set to `true
|
2021-09-14 21:14:23 +06:00
|
|
|
icon_only = false -- Display only icon for filetype
|
2021-05-13 21:01:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
2021-02-16 00:09:12 +06:00
|
|
|
|
2021-09-13 21:33:18 -06:00
|
|
|
#### diff component options
|
2021-04-06 20:03:41 +06:00
|
|
|
|
2021-02-16 00:09:12 +06:00
|
|
|
```lua
|
2021-03-17 01:22:00 +01:00
|
|
|
sections = {
|
2021-05-13 21:01:37 +02:00
|
|
|
lualine_a = {
|
|
|
|
{
|
|
|
|
'diff',
|
|
|
|
colored = true, -- displays diff status in color if set to true
|
|
|
|
-- all colors are in format #rrggbb
|
2021-09-14 21:14:23 +06:00
|
|
|
diff_color = {
|
|
|
|
added = nil, -- changes diff's added foreground color
|
|
|
|
modified = nil, -- changes diff's modified foreground color
|
|
|
|
removed = nil, -- changes diff's removed foreground color
|
|
|
|
}
|
2021-05-13 21:01:37 +02:00
|
|
|
symbols = {added = '+', modified = '~', removed = '-'} -- changes diff symbols
|
2021-08-03 17:41:37 +06:00
|
|
|
source = nil, -- A function that works as a data source for diff.
|
|
|
|
-- it must return a table like
|
2021-09-03 18:49:05 +06:00
|
|
|
-- {added = add_count, modified = modified_count, removed = removed_count }
|
2021-08-03 17:41:37 +06:00
|
|
|
-- Or nil on failure. Count <= 0 won't be displayed.
|
2021-03-17 01:22:00 +01:00
|
|
|
}
|
2021-02-16 00:09:12 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
### Tabline
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-03-11 00:35:08 +01:00
|
|
|
You can use lualine to display components in tabline.
|
2021-05-13 21:01:37 +02:00
|
|
|
The configuration for tabline sections is exactly the same as for statusline.
|
2021-03-11 00:37:39 +01:00
|
|
|
```lua
|
2021-03-17 01:22:00 +01:00
|
|
|
tabline = {
|
|
|
|
lualine_a = {},
|
|
|
|
lualine_b = {'branch'},
|
|
|
|
lualine_c = {'filename'},
|
|
|
|
lualine_x = {},
|
|
|
|
lualine_y = {},
|
|
|
|
lualine_z = {}
|
2021-03-06 21:03:00 +06:00
|
|
|
}
|
|
|
|
```
|
|
|
|
This will show branch and filename component in top of neovim inside tabline .
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
You can also completely move your statuline to tabline by configuring
|
|
|
|
`lualine.tabline` and disabling `lualine.sections` and `lualine.inactive_sections`.
|
2021-03-06 21:03:00 +06:00
|
|
|
|
2021-03-11 00:37:39 +01:00
|
|
|
```lua
|
2021-03-17 01:22:00 +01:00
|
|
|
tabline = {
|
2021-03-06 21:03:00 +06:00
|
|
|
......
|
2021-03-17 01:22:00 +01:00
|
|
|
},
|
|
|
|
sections = {},
|
|
|
|
inactive_sections = {},
|
2021-03-06 21:03:00 +06:00
|
|
|
```
|
|
|
|
|
2021-08-09 16:36:52 +06:00
|
|
|
If you're looking for bufferline or want to show tabs in tabline . There are
|
|
|
|
manny awesome plugins that can do that. For example:
|
|
|
|
|
|
|
|
- [nvim-bufferline](https://github.com/akinsho/nvim-bufferline.lua)
|
|
|
|
- [tabline.nvim](https://github.com/kdheepak/tabline.nvim)
|
|
|
|
|
|
|
|
tabline.nvim even uses lualines theme by default 🙌
|
|
|
|
You can find a bigger list [here](https://github.com/rockerBOO/awesome-neovim#tabline)
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
### Extensions
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
Lualine extensions change statusline appearance for a window/buffer with
|
|
|
|
specified filetypes.
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
By default no extension are loaded to improve performance.
|
|
|
|
You can load extensions with:
|
2020-12-30 17:31:38 +01:00
|
|
|
```lua
|
2021-05-13 21:01:37 +02:00
|
|
|
extensions = {'quickfix'}
|
2020-12-30 17:31:38 +01:00
|
|
|
```
|
|
|
|
|
2021-03-16 00:00:45 +01:00
|
|
|
<details>
|
2021-03-16 00:02:22 +01:00
|
|
|
<summary><b>Available extensions</b></summary>
|
2021-03-16 00:00:45 +01:00
|
|
|
|
2021-05-11 21:22:58 +02:00
|
|
|
* chadtree
|
2021-03-16 00:00:45 +01:00
|
|
|
* fugitive
|
|
|
|
* fzf
|
|
|
|
* nerdtree
|
2021-04-12 05:03:25 -07:00
|
|
|
* nvim-tree
|
2021-05-11 21:22:58 +02:00
|
|
|
* quickfix
|
2021-09-19 18:13:02 +08:00
|
|
|
* toggleterm
|
2021-03-16 00:00:45 +01:00
|
|
|
|
|
|
|
</details>
|
2020-12-30 17:31:38 +01:00
|
|
|
|
2021-05-14 20:24:54 +02:00
|
|
|
<details>
|
|
|
|
<summary><b>Custom extensions</b></summary>
|
|
|
|
|
|
|
|
You can define your own extensions. If you think an extension might be useful for others then please submit a pr.
|
|
|
|
```lua
|
|
|
|
local my_extension = {sections = {lualine_a = 'mode'}, filetypes = {'lua'}}
|
|
|
|
require'lualine'.setup {extensions = {my_extension}}
|
|
|
|
```
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
---
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
### Disabling lualine
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
You can disable lualine for specific filetypes
|
2021-09-13 21:33:18 -06:00
|
|
|
|
2021-05-13 21:01:37 +02:00
|
|
|
```lua
|
|
|
|
options = {disabled_filetypes = {'lua'}}
|
|
|
|
```
|