Highlight changed text after any action which modifies the current buffer. This plugin was originaly written to support Undo / Redo highlighting, but is now expanded to support any other action.
Purely lua / nvim api implementation, no external dependencies needed.
Using Lazy:
{
'tzachar/highlight-undo.nvim',
opts = {
...
},
},
The easiest way to set up highlight-undo
as follows:
require('highlight-undo').setup({})
The code above will set up highlight-undo
to hijack u
, <C-r>
, p
and P
. To disable any of the defaults see here
You can also manually setup highlight-undo
with specific / additional keymaps as follows:
require('highlight-undo').setup({
duration = 300,
keymaps = {
Keymap_name = {
-- most fields here are the same as in vim.keymap.set
desc = "a description",
hlgroup = 'HighlightUndo',
mode = 'n',
lhs = 'lhs',
rhs = 'optional, can be nil',
opts = {
-- same as opts to vim.keymap.set. if rhs is nil, there should be a
-- callback key which points to a function
},
},
},
})
As this plugin hijacks kemaps, there might be issues with other plugin with
similar behavior. Make sure this plugin is loaded last. For example, using
lazy.nvim
, you can just specify the following:
{
'tzachar/highlight-undo.nvim',
keys = { { "u" }, { "<C-r>" } },
}
Specify which keymaps should trigger the beginning and end of tracking changes (see here). By default, the plugin starts tracking changes before and after the following keymaps:
u
-- for Undo<C-r>
-- for Redop
-- for pasteP
-- for Paste
To disable any of the defaults, add a disabled = true
entry to the appropriate
keymap. For example, to disable the default highlight for Paste:
require('highlight-undo').setup({
keymaps = {
Paste = {
disabled = true,
},
},
})
Keymaps are specified in the same format as vim.keymap.set
accepts: mode, lhs,
rhs, opts. Maps are passed verbatim to vim.keymap.set
. A different possibility
is when you just want to hijack an existing keymap, you can then just specify
the lhs
and highligh-undo
will remap lhs
and trigger the original action
afterwards.
For example, adding p
(which exists by default), is as easy as:
require('highlight-undo').setup({
keymaps = {
paste = {
desc = "paste",
hlgroup = 'HighlightUndo',
mode = 'n',
lhs = 'p',
rhs = 'p',
opts = {},
},
},
})
Note that lhs
and rhs
are identical.
Specify the highlighting group to use.
By default, highlight-undo
will use HighlightUndo
for the undo action and
HighlightRedo
for the redo action. Both of these groups, are defined when the
plugin is loaded. If the groups are already defined elsewhere in your config
then they will not be overwritten. You can also use others groups, if desired.
The duration (in milliseconds) to highlight changes. Default is 300.
highlight-undo
will remap the u
and <C-r>
keys (for undo and redo, by default) and
hijack the calls. By utilizing nvim_buf_attach
to get indications for changes in the
buffer, the plugin can achieve very low overhead.