Smooth scrolling for ANY command π€―. A highly customizable Neovim plugin written in Lua!
- Can add smooth cursor and window scroll animation to any normal mode movement, command, or Lua function
- Horizontal, vertical, and diagonal scrolling
- Adjusts scroll speed based on movement distance
- Non-blocking delays using luv
- Two scrolling modes:
cursor: animate cursor and window scrolling for any movementwindow: animate window scrolling ONLY when the cursor moves out of view
- Neovim >= 0.8.0
demo.mp4
Just install with your favorite package manager and run the setup function.
{
"declancm/cinnamon.nvim",
version = "*", -- use latest release
opts = {
-- change default options here
},
}A settings table can be passed into the setup function for custom options.
---@class CinnamonOptions
return {
-- Disable the plugin
disabled = false,
keymaps = {
-- Enable the provided 'basic' keymaps
basic = false,
-- Enable the provided 'extra' keymaps
extra = false,
},
---@class ScrollOptions
options = {
-- The scrolling mode
-- `cursor`: animate cursor and window scrolling for any movement
-- `window`: animate window scrolling ONLY when the cursor moves out of view
mode = "cursor",
-- Only animate scrolling if a count is provided
count_only = false,
-- Delay between each movement step (in ms)
delay = 5,
max_delta = {
-- Maximum distance for line movements before scroll
-- animation is skipped. Set to `false` to disable
line = false,
-- Maximum distance for column movements before scroll
-- animation is skipped. Set to `false` to disable
column = false,
-- Maximum duration for a movement (in ms). Automatically scales the
-- delay and step size
time = 1000,
},
step_size = {
-- Number of cursor/window lines moved per step
vertical = 1,
-- Number of cursor/window columns moved per step
horizontal = 2,
},
-- Optional post-movement callback. Not called if the movement is interrupted
callback = function() end,
},
}require("cinnamon").setup {
-- Enable all provided keymaps
keymaps = {
basic = true,
extra = true,
},
-- Only scroll the window
options = { mode = "window" },
}Scroll animation for ...
| Category | Keys |
|---|---|
| Half-window movements | <C-U> and <C-D> |
| Page movements | <C-B>, <C-F>, <PageUp> and <PageDown> |
| Paragraph movements | { and } |
| Prev/next search result | n, N, *, #, g* and g# |
| Prev/next cursor location | <C-O> and <C-I> |
Scroll animation for ...
| Category | Keys |
|---|---|
| Start/end of file | gg and G |
| Line number | [count]gg and [count]G |
| Start/end of line | 0, ^ and $ |
| Screen scrolling | zz, zt, zb, z., z<CR>, z-, z^, z+, <C-Y> and <C-E> |
| Horizontal scrolling | zH, zL, zs, ze, zh and zl |
| Up/down movements | [count]j, [count]k, [count]<Up>, [count]<Down>, [count]gj, [count]gk, [count]g<Up> and [count]g<Down> |
| Left/right movements | [count]h, [count]l, [count]<Left> and [count]<Right> |
require("cinnamon").scroll({command}, {options})
Executes the given command with cursor and window scroll animation.
-
{command}(string|function) Can be any of the following:-
Normal mode movement command
require("cinnamon").scroll("<C-]>")
-
Command-line (Ex) command when prefixed with a semicolon
require("cinnamon").scroll(":keepjumps normal! <C-]>")
-
A Lua function
require("cinnamon").scroll(function() vim.lsp.buf.definition({ loclist = true }) end)
-
-
{options}(ScrollOptions?) Override the default scroll options. See the Default Options for more information.require("cinnamon").scroll("<C-]>", { mode = "window" })
local cinnamon = require("cinnamon")
cinnamon.setup()
-- Centered scrolling:
vim.keymap.set("n", "<C-U>", function() cinnamon.scroll("<C-U>zz") end)
vim.keymap.set("n", "<C-D>", function() cinnamon.scroll("<C-D>zz") end)
-- LSP:
vim.keymap.set("n", "gd", function() cinnamon.scroll(vim.lsp.buf.definition) end)
vim.keymap.set("n", "gD", function() cinnamon.scroll(vim.lsp.buf.declaration) end)
-- Flash.nvim integration:
local flash = require("flash")
local jump = require("flash.jump")
flash.setup({
action = function(match, state)
cinnamon.scroll(function()
jump.jump(match, state)
jump.on_jump(state)
end)
end,
})CinnamonCmdPre- Triggered before the given command is executedCinnamonCmdPost- Triggered after the given command is executedCinnamonScrollPre- Triggered before the scroll animationCinnamonScrollPost- Triggered after the scroll animation
vim.b.cinnamon_disable(boolean) Disable scroll animation for the current buffervim.g.cinnamon_disable(boolean) Disable scroll animation globally
Example Usage:
-- Disable scrolling for help buffers
vim.api.nvim_create_autocmd("FileType", {
pattern = "help",
callback = function() vim.b.cinnamon_disable = true end,
})