/vimade

An eye friendly plugin that fades your inactive buffers and preserves your syntax highlighting!

Primary LanguagePythonMIT LicenseMIT

vimade

An eye catching plugin that fades your inactive buffers and preserves syntax highlighting!!!!
Screenshots

Fade inactive windows

Fade using custom tints

Change the fadelevel

Fade signs (example below does 4000 signs)

Fade/Unfade diffs together

Fade/Unfade using word wrap

Fade using NormalNC (NVIM only)

Features
  • Fade inactive buffers
  • Fade/Unfade diffs together
  • Automatically adjust to colorscheme changes
  • Automatically adjust to basebg changes
  • Automatically adjust to fadelevel changes
  • Automatically adjust to &syntax changes
  • React to window resize + scroll changes
  • Apply custom tints (not necessarily your background color to text)
  • Vim8+
  • Neovim + also plays well with NormalNC
  • Python3
  • Python2
  • GUI Neovim + GUI Vim
  • 256 color terminal support (Xterm)
  • Toggle vimade on/off (VimadeEnable, VimadeDisable, VimadeToggle)
  • Supports terminal backgrounds for Vim8(not nvim yet) and iTerm, Tilix, Kitty, Gnome, rxvt
  • Wrapped Text
  • Folded Text (detects folded rows and fades above/below -- see VimadeOverrideFolded for highlight recommendations on hi Folded)
  • :ownsyntax support
  • Sign column support
  • Vim Documentation/Help
  • Secondary buffer window highlighting
Whats coming?
  • Helpers to fade Vim global highlights (e.g VertSplit, Folded, NonText, etc -- will alleviate issues with high contrast in some colorschemes)
  • Configurable FadeLevel per buffer
  • Conditional interface to determine which windows/buffers get faded/unfaded.
  • Performance Improvements
  • Limelight with syntax highlighting
  • Improve terminal color rounding for grays
  • Code cleanup
  • Tests
What/Why?
  • Vimade fades inactive/unfocused buffer text and removes the fade from focused buffers.
  • Vimade diffs and multiple windows linked to the same buffer are treated as a group that highlights/unhighlights together.
  • Vimade reacts to scrolling, tab changes, colorscheme changes, diff, and much more!
Install

Add TaDaa/vimade to your vimrc -- you can use any plugin manager e.g:

Plug 'TaDaa/vimade'
Config

Vimade is initialized with the following configuration. Vimade will react to configuration changes on the fly:

let g:vimade = {
  \ "normalid": '',
  \ "normalncid": '',
  \ "basefg": '',
  \ "basebg": '',
  \ "fadelevel": 0.4,
  \ "colbufsize": 15, "15 is the default for gui vim, 5 is the default for terminals and gvim
  \ "rowbufsize": 15, "15 is the default for gui vim, 0 is the default for terminals and gvim
  \ "checkinterval": 100, "100 is the default for gui vim, 500 is the default for terminals and neovim
  \ "usecursorhold": 0, "0 is default, but will automatically set to 1 for Windows GVIM
  \ "detecttermcolors": 0,
  \ 'enablescroll': 1, "1 is the default for gui vim, but will automatically set to 0 for terminals and Windows GVIM.
  \ 'enablesigns': g:vimade_features.has_signs_priority, "enabled for vim/nvim versions that support sign priority.  Older vim/nvim versions may suffer performance issues
  \ 'signsid': 13100,
  \ 'signsretentionperiod': 4000,
  \ 'fademinimap': 1,
  \ 'fadepriority': 10,
  \ 'groupdiff': 1,
  \ 'groupscrollbind': 0,
  \ 'enablefocusfading': 0,
  \ 'enablebasegroups': 1,
  \ 'enabletreesitter' : 0, "EXPERIMENTAL FEATURE - 0 is the default, enables support for treesitter highlights"
  \ 'basegroups': ['Folded', 'Search', 'SignColumn', 'LineNr', 'CursorLine', 'CursorLineNr', 'DiffAdd', 'DiffChange', 'DiffDelete', 'DiffText', 'FoldColumn', 'Whitespace']
}
  • vimade.normalid - if not specified, the normalid is determined when vimade is first loaded. normalid provides the id of the "Normal" highlight which is used to calculate fading. You can override this config with another highlight group.

  • vimade.normalncid - if not specified, the normalncid is determined when vimade is first loaded. normalncid provides the id of the "NormalNC" highlight which is used to calculate fading for inactive buffers in NVIM. You can override this config with another highlight group.

  • vimade.basefg - basefg can either be six digit hexidecimal color, rgb array [0-255,0-255,0-255], or cterm code (in terminal). Basefg is only used to calculate the default fading that should be applied to Normal text. By default basefg is calculated as the "Normal" highlight guifg or ctermfg.

  • vimade.basebg - basebg can be either be six digit hexidecimal color, rgb array [0-255,0-255,0-255], or cterm code (in terminal). basebg is used as the color that text is faded against. You can override this config with another hexidecimal color. A cool feature of basebg is to use it to change the tint of faded text even if its not your background!

  • vimade.fadelevel - amount of fading applied between text and basebg. 0 will make the text the same color as the background and 1 applies no fading. The default value is 0.4. If you are using terminal, you may need to tweak this value to get better results.

  • vimade.rowbufsize - the number of rows above and below of the determined scroll area that should be precalculated. Reduce this value to improve performance. Default is 15 for gui vim and 0 for terminals/gvim.

  • vimade.colbufsize - the number of cols left and right of the determined scroll area that should be precalculated. Reduce this value to improve performance. Default is 15 for gui vim and 1 for terminals/gvim.

  • vimade.checkinterval - the amount of time in milliseconds that vimade should check the screen for changes. This config is mainly used to detect resize and scroll changes that occur on inactive windows. Checkinterval does nothing on gvim, if you want to control the refresh time, see 'h updatetime'. Default is 100.

  • vimade.usecursorhold - disables the timer running in the background and instead relies OnCursorHold and updatetime (see h:updatetime). The default value is 0 except on Windows GVIM, which defaults to 1 due to the timer breaking movements. If you find that the timer is causing performance problems or other issues you can disable it by setting this option to 1.

  • vimade.detecttermcolors - detect the terminal background and foreground colors. This will work for Vim8 + iTerm, Tilix, Kitty, Gnome, Rxvt, and other editors that support the following query (\033]11;?\007 or \033]11;?\033\\). Default is 0. Enable this at your own risk as it can cause unwanted side effects.

  • vimade.enablesigns - Enabled by default for vim/nvim versions that support sign priority and causes signs to be faded when switching buffers. Only visible signs are faded. This feature can cause performance issues on older vim/nvim versions that don't support sign priority. Use signsretentionperiod to control the duration that vimade checks for sign updates after switching buffers.

  • vimade.enablescroll - Enables fading while scrolling inactive windows. This is only useful in gui vim and does have a performance cost. By default this setting is enabled in gui vim and disabled for terminals.

  • vimade.signsid - The starting id that Vimade should use when creating new signs. By default Vim requires numeric values to create signs and its possible that collisions may occur between plugins. If you need to override this value for compatibility, please open an issue as well. Default is 13100.

  • vimade.signspriority - Controls the signs fade priority. You may need to change this value if you find that not all signs are fading properly. Please also open a defect if you need to tweak this value as Vimade strives to minimize manual configuration where possible. Default is 31.

  • vimade.signsretentionperiod - The amount of time in milliseconds that faded buffers should be tracked for sign changes. Default value is 4000.

  • vimade.fademinimap - Enables a special fade effect for severin-lemaignan/vim-minimap. Setting vimade.fademinimap to 0 disables the special fade. Default is 1.

  • vimade.fadepriority - Controls the highlighting priority. You may want to tweak this value to make Vimade play nicely with other highlighting plugins and behaviors. For example, if you want hlsearch to show results on all buffers, you may want to lower this value to 0. Default is 10.

  • vimade.groupdiff - Controls whether or not diffs will fade/unfade together. If you want diffs to be treated separately, set this value to 0. Default is 1.

  • vimade.groupscrollbind - Controls whether or not scrollbound windows will fade/unfade together. If you want scrollbound windows to unfade together, set this to 1. Default is 0.

  • vimade.enablebasegroups - Neovim only setting. Enabled by default and allows basegroups/built-in highlight fading using winhl. This allows fading of built-in highlights such as Folded, Search, etc.

  • vimade.basegroups - Neovim only setting that specifies the basegroups/built-in highlight groups that will be faded using winhl when switching windows

  • vimade.enablefocusfading - Fades the current active window on focus blur and unfades when focus gained. This can be desirable when switching applications or TMUX splits. Default value is 0.
    Requires additional setup for terminal and tmux:

    1. Install tmux-plugins/vim-tmux-focus-events
    2. Add set -g focus-events on to your tmux.conf
    3. Neovim should just work at this point. If you are using Vim, you may need to add the following snippet to the very end of your vimrc.
      if has('gui_running') == 0 && has('nvim') == 0
         call feedkeys(":silent execute '!' | redraw!\<CR>")
      endif
      
  • vimade.enabletreesitter - This is an EXPERIMENTAL feature. Combines treesitter with syntax highlights if needed to fade buffer. Default value is 0.

Config Example(s)

*Always remember to first set the global vimade object (let g:vimade={}) this example reduces the amount of fading applied to text

let g:vimade = {}
let g:vimade.fadelevel = 0.7
let g:vimade.enablesigns = 1
Commands
  • VimadeEnable - Turns vimade on (Vimade is on by default)
  • VimadeDisable - Turns vimade off and unfades all buffers
  • VimadeToggle - Toggles between on/off states
  • VimadeRedraw - Forces vimade to redraw fading for every window.
  • VimadeFadeLevel [0.0-1.0] - Sets the FadeLevel config and forces an immediate redraw.
  • VimadeFadePriority [0+] - Sets the FadePriority config and forces an immediate redraw.
  • VimadeInfo - Provides debug information for Vimade. Please include this info in bug reports
  • VimadeWinDisable - Disables fading for the current window
  • VimadeWinEnable - Enables fading for the current window
  • VimadeBufDisable - Disables fading for the current buffer
  • VimadeBufEnable - Enables fading for the current buffer
  • VimadeFadeActive - Fades the current active window
  • VimadeUnfadeActive - Unfades the current active window
  • VimadeOverrideFolded - Overrides the Folded highlight by creating a link to the Vimade base fade. This should produce acceptable results for colorschemes that include Folded highlights that are distracting in faded windows.
  • VimadeOverrideSignColumn - Overrides the SignColumn highlight by creating a link to the Vimade base fade. This should produce acceptable results for colorschemes that include SignColumn highlights that are distracting in faded windows.
  • VimadeOverrideLineNr - Overrides the LineNr highlight by creating a link to the Vimade base fade. This should produce acceptable results for colorschemes that include LineNr highlights that are distracting in faded windows.
  • VimadeOverrideSplits - Overrides the VertSplit highlight by creating a link to the Vimade base fade. This should produce acceptable results for colorschemes that include VertSplit highlights that are distracting in faded windows.
  • VimadeOverrideNonText - Overrides the NonText highlight by creating a link to the Vimade base fade. This should produce acceptable results for colorschemes that include NonText highlights that are distracting in faded windows.
  • VimadeOverrideEndOfBuffer - Overrides the EndOfBuffer highlight by creating a link to the Vimade base fade. This should produce acceptable results for colorschemes that include EndOfBuffer highlights that are distracting in faded windows.
  • VimadeOverrideAll - Combines all VimadeOverride commands.
FAQ/Help

I am using GVIM and my mappings are not working

  • Add let g:vimade.usecursorhold=1 to your vimrc

What about Vim < 8?

  • Vim 7.4 is currently untested/experimental, but should work if you add let g:vimade.usecursorhold=1 to your vimrc

My colors look off in terminal mode!

  • Make sure that you either use a supported terminal or colorscheme or manually define the fg and bg for 'Normal'. You can also manually define the tint in your vimade config (g:vimade.basebg and g:vimade.basefg)

Tmux is not working!

  • Vimade only works in a 256 or higher color mode and by default TMUX may set t_Co to 8. it is recommended that you set export TERM=xterm-256color before starting vim. You can also set set termguicolors inside vim if your term supports it for an even more accurate level of fading.

Vim becomes slow when completions ar visible/changing (typically noticeable when a large number of buffers are open and autocomplete is running). Neovim does not seem to suffer from the same performance degradation.

  • This issue seems to be due to redraws that occur as the pum content changes. The best way to lessen the effect is to add au! CompleteChanged * redraw to your vimrc. The user redraw can force Vim to be more responsive in this scenario