# snacks.nvim
**Repository Path**: pyy-huang-ting/snacks.nvim
## Basic Information
- **Project Name**: snacks.nvim
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: browse
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 1
- **Created**: 2025-06-12
- **Last Updated**: 2025-06-12
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# 🍿 `snacks.nvim`
A collection of small QoL plugins for Neovim.
## ✨ Features
| Snack | Description | Setup |
| ----- | ----------- | :---: |
| [animate](https://github.com/folke/snacks.nvim/blob/main/docs/animate.md) | Efficient animations including over 45 easing functions _(library)_ | |
| [bigfile](https://github.com/folke/snacks.nvim/blob/main/docs/bigfile.md) | Deal with big files | ‼️ |
| [bufdelete](https://github.com/folke/snacks.nvim/blob/main/docs/bufdelete.md) | Delete buffers without disrupting window layout | |
| [dashboard](https://github.com/folke/snacks.nvim/blob/main/docs/dashboard.md) | Beautiful declarative dashboards | ‼️ |
| [debug](https://github.com/folke/snacks.nvim/blob/main/docs/debug.md) | Pretty inspect & backtraces for debugging | |
| [dim](https://github.com/folke/snacks.nvim/blob/main/docs/dim.md) | Focus on the active scope by dimming the rest | |
| [git](https://github.com/folke/snacks.nvim/blob/main/docs/git.md) | Git utilities | |
| [gitbrowse](https://github.com/folke/snacks.nvim/blob/main/docs/gitbrowse.md) | Open the current file, branch, commit, or repo in a browser (e.g. GitHub, GitLab, Bitbucket) | |
| [indent](https://github.com/folke/snacks.nvim/blob/main/docs/indent.md) | Indent guides and scopes | |
| [input](https://github.com/folke/snacks.nvim/blob/main/docs/input.md) | Better `vim.ui.input` | ‼️ |
| [layout](https://github.com/folke/snacks.nvim/blob/main/docs/layout.md) | Window layouts | |
| [lazygit](https://github.com/folke/snacks.nvim/blob/main/docs/lazygit.md) | Open LazyGit in a float, auto-configure colorscheme and integration with Neovim | |
| [notifier](https://github.com/folke/snacks.nvim/blob/main/docs/notifier.md) | Pretty `vim.notify` | ‼️ |
| [notify](https://github.com/folke/snacks.nvim/blob/main/docs/notify.md) | Utility functions to work with Neovim's `vim.notify` | |
| [picker](https://github.com/folke/snacks.nvim/blob/main/docs/picker.md) | Picker for selecting items | ‼️ |
| [profiler](https://github.com/folke/snacks.nvim/blob/main/docs/profiler.md) | Neovim lua profiler | |
| [quickfile](https://github.com/folke/snacks.nvim/blob/main/docs/quickfile.md) | When doing `nvim somefile.txt`, it will render the file as quickly as possible, before loading your plugins. | ‼️ |
| [rename](https://github.com/folke/snacks.nvim/blob/main/docs/rename.md) | LSP-integrated file renaming with support for plugins like [neo-tree.nvim](https://github.com/nvim-neo-tree/neo-tree.nvim) and [mini.files](https://github.com/echasnovski/mini.files). | |
| [scope](https://github.com/folke/snacks.nvim/blob/main/docs/scope.md) | Scope detection, text objects and jumping based on treesitter or indent | ‼️ |
| [scratch](https://github.com/folke/snacks.nvim/blob/main/docs/scratch.md) | Scratch buffers with a persistent file | |
| [scroll](https://github.com/folke/snacks.nvim/blob/main/docs/scroll.md) | Smooth scrolling | ‼️ |
| [statuscolumn](https://github.com/folke/snacks.nvim/blob/main/docs/statuscolumn.md) | Pretty status column | ‼️ |
| [terminal](https://github.com/folke/snacks.nvim/blob/main/docs/terminal.md) | Create and toggle floating/split terminals | |
| [toggle](https://github.com/folke/snacks.nvim/blob/main/docs/toggle.md) | Toggle keymaps integrated with which-key icons / colors | |
| [util](https://github.com/folke/snacks.nvim/blob/main/docs/util.md) | Utility functions for Snacks _(library)_ | |
| [win](https://github.com/folke/snacks.nvim/blob/main/docs/win.md) | Create and manage floating windows or splits | |
| [words](https://github.com/folke/snacks.nvim/blob/main/docs/words.md) | Auto-show LSP references and quickly navigate between them | ‼️ |
| [zen](https://github.com/folke/snacks.nvim/blob/main/docs/zen.md) | Zen mode • distraction-free coding | |
## ⚡️ Requirements
- **Neovim** >= 0.9.4
- for proper icons support:
- [mini.icons](https://github.com/echasnovski/mini.icons) _(optional)_
- [nvim-web-devicons](https://github.com/nvim-tree/nvim-web-devicons) _(optional)_
- a [Nerd Font](https://www.nerdfonts.com/) **_(optional)_**
## 📦 Installation
Install the plugin with your package manager:
### [lazy.nvim](https://github.com/folke/lazy.nvim)
> [!important]
> A couple of plugins **require** `snacks.nvim` to be set-up early.
> Setup creates some autocmds and does not load any plugins.
> Check the [code](https://github.com/folke/snacks.nvim/blob/main/lua/snacks/init.lua) to see what it does.
> [!caution]
> You need to explicitly pass options for a plugin or set `enabled = true` to enable it.
> [!tip]
> It's a good idea to run `:checkhealth snacks` to see if everything is set up correctly.
```lua
{
"folke/snacks.nvim",
priority = 1000,
lazy = false,
---@type snacks.Config
opts = {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
bigfile = { enabled = true },
dashboard = { enabled = true },
indent = { enabled = true },
input = { enabled = true },
picker = { enabled = true },
notifier = { enabled = true },
quickfile = { enabled = true },
scroll = { enabled = true },
statuscolumn = { enabled = true },
words = { enabled = true },
},
}
```
For an in-depth setup of `snacks.nvim` with `lazy.nvim`, check the [example](https://github.com/folke/snacks.nvim?tab=readme-ov-file#-usage) below.
## ⚙️ Configuration
Please refer to the readme of each plugin for their specific configuration.
Default Options
```lua
---@class snacks.Config
---@field animate? snacks.animate.Config
---@field bigfile? snacks.bigfile.Config
---@field dashboard? snacks.dashboard.Config
---@field dim? snacks.dim.Config
---@field gitbrowse? snacks.gitbrowse.Config
---@field indent? snacks.indent.Config
---@field input? snacks.input.Config
---@field layout? snacks.layout.Config
---@field lazygit? snacks.lazygit.Config
---@field notifier? snacks.notifier.Config
---@field picker? snacks.picker.Config
---@field profiler? snacks.profiler.Config
---@field quickfile? snacks.quickfile.Config
---@field scope? snacks.scope.Config
---@field scratch? snacks.scratch.Config
---@field scroll? snacks.scroll.Config
---@field statuscolumn? snacks.statuscolumn.Config
---@field terminal? snacks.terminal.Config
---@field toggle? snacks.toggle.Config
---@field win? snacks.win.Config
---@field words? snacks.words.Config
---@field zen? snacks.zen.Config
---@field styles? table
{}
```
Some plugins have examples in their documentation. You can include them in your
config like this:
```lua
{
dashboard = { example = "github" }
}
```
If you want to customize options for a plugin after they have been resolved, you
can use the `config` function:
```lua
{
gitbrowse = {
config = function(opts, defaults)
table.insert(opts.remote_patterns, { "my", "custom pattern" })
end
},
}
```
## 🚀 Usage
See the example below for how to configure `snacks.nvim`.
```lua
{
"folke/snacks.nvim",
priority = 1000,
lazy = false,
---@type snacks.Config
opts = {
bigfile = { enabled = true },
dashboard = { enabled = true },
indent = { enabled = true },
input = { enabled = true },
notifier = {
enabled = true,
timeout = 3000,
},
picker = { enabled = true },
quickfile = { enabled = true },
scroll = { enabled = true },
statuscolumn = { enabled = true },
words = { enabled = true },
styles = {
notification = {
-- wo = { wrap = true } -- Wrap notifications
}
}
},
keys = {
{ "z", function() Snacks.zen() end, desc = "Toggle Zen Mode" },
{ "Z", function() Snacks.zen.zoom() end, desc = "Toggle Zoom" },
{ ".", function() Snacks.scratch() end, desc = "Toggle Scratch Buffer" },
{ "S", function() Snacks.scratch.select() end, desc = "Select Scratch Buffer" },
{ "n", function() Snacks.notifier.show_history() end, desc = "Notification History" },
{ "bd", function() Snacks.bufdelete() end, desc = "Delete Buffer" },
{ "cR", function() Snacks.rename.rename_file() end, desc = "Rename File" },
{ "gB", function() Snacks.gitbrowse() end, desc = "Git Browse", mode = { "n", "v" } },
{ "gb", function() Snacks.git.blame_line() end, desc = "Git Blame Line" },
{ "gf", function() Snacks.lazygit.log_file() end, desc = "Lazygit Current File History" },
{ "gg", function() Snacks.lazygit() end, desc = "Lazygit" },
{ "gl", function() Snacks.lazygit.log() end, desc = "Lazygit Log (cwd)" },
{ "un", function() Snacks.notifier.hide() end, desc = "Dismiss All Notifications" },
{ "", function() Snacks.terminal() end, desc = "Toggle Terminal" },
{ "", function() Snacks.terminal() end, desc = "which_key_ignore" },
{ "]]", function() Snacks.words.jump(vim.v.count1) end, desc = "Next Reference", mode = { "n", "t" } },
{ "[[", function() Snacks.words.jump(-vim.v.count1) end, desc = "Prev Reference", mode = { "n", "t" } },
{
"N",
desc = "Neovim News",
function()
Snacks.win({
file = vim.api.nvim_get_runtime_file("doc/news.txt", false)[1],
width = 0.6,
height = 0.6,
wo = {
spell = false,
wrap = false,
signcolumn = "yes",
statuscolumn = " ",
conceallevel = 3,
},
})
end,
}
},
init = function()
vim.api.nvim_create_autocmd("User", {
pattern = "VeryLazy",
callback = function()
-- Setup some globals for debugging (lazy-loaded)
_G.dd = function(...)
Snacks.debug.inspect(...)
end
_G.bt = function()
Snacks.debug.backtrace()
end
vim.print = _G.dd -- Override print to use snacks for `:=` command
-- Create some toggle mappings
Snacks.toggle.option("spell", { name = "Spelling" }):map("us")
Snacks.toggle.option("wrap", { name = "Wrap" }):map("uw")
Snacks.toggle.option("relativenumber", { name = "Relative Number" }):map("uL")
Snacks.toggle.diagnostics():map("ud")
Snacks.toggle.line_number():map("ul")
Snacks.toggle.option("conceallevel", { off = 0, on = vim.o.conceallevel > 0 and vim.o.conceallevel or 2 }):map("uc")
Snacks.toggle.treesitter():map("uT")
Snacks.toggle.option("background", { off = "light", on = "dark", name = "Dark Background" }):map("ub")
Snacks.toggle.inlay_hints():map("uh")
Snacks.toggle.indent():map("ug")
Snacks.toggle.dim():map("uD")
end,
})
end,
}
```
## 🌈 Highlight Groups
Click to see all highlight groups
| Highlight Group | Default Group | Description |
| ----------------------------- | ----------------------- | ------------------------------ |
| **SnacksNormal** | _NormalFloat_ | Normal for the float window |
| **SnacksWinBar** | _Title_ | Title of the window |
| **SnacksBackdrop** | _none_ | Backdrop |
| **SnacksNormalNC** | _NormalFloat_ | Normal for non-current windows |
| **SnacksWinBarNC** | _SnacksWinBar_ | Title for non-current windows |
| **SnacksScratchKey** | _DiagnosticVirtualText_ | Keymap help in the footer |
| **SnacksScratchDesc** | _DiagnosticInfo_ | Keymap help desc in the footer |
| **SnacksNotifierInfo** | _none_ | Notification window for Info |
| **SnacksNotifierWarn** | _none_ | Notification window for Warn |
| **SnacksNotifierDebug** | _none_ | Notification window for Debug |
| **SnacksNotifierError** | _none_ | Notification window for Error |
| **SnacksNotifierTrace** | _none_ | Notification window for Trace |
| **SnacksNotifierIconInfo** | _none_ | Icon for Info notification |
| **SnacksNotifierIconWarn** | _none_ | Icon for Warn notification |
| **SnacksNotifierIconDebug** | _none_ | Icon for Debug notification |
| **SnacksNotifierIconError** | _none_ | Icon for Error notification |
| **SnacksNotifierIconTrace** | _none_ | Icon for Trace notification |
| **SnacksNotifierTitleInfo** | _none_ | Title for Info notification |
| **SnacksNotifierTitleWarn** | _none_ | Title for Warn notification |
| **SnacksNotifierTitleDebug** | _none_ | Title for Debug notification |
| **SnacksNotifierTitleError** | _none_ | Title for Error notification |
| **SnacksNotifierTitleTrace** | _none_ | Title for Trace notification |
| **SnacksNotifierBorderInfo** | _none_ | Border for Info notification |
| **SnacksNotifierBorderWarn** | _none_ | Border for Warn notification |
| **SnacksNotifierBorderDebug** | _none_ | Border for Debug notification |
| **SnacksNotifierBorderError** | _none_ | Border for Error notification |
| **SnacksNotifierBorderTrace** | _none_ | Border for Trace notification |
| **SnacksNotifierFooterInfo** | _DiagnosticInfo_ | Footer for Info notification |
| **SnacksNotifierFooterWarn** | _DiagnosticWarn_ | Footer for Warn notification |
| **SnacksNotifierFooterDebug** | _DiagnosticHint_ | Footer for Debug notification |
| **SnacksNotifierFooterError** | _DiagnosticError_ | Footer for Error notification |
| **SnacksNotifierFooterTrace** | _DiagnosticHint_ | Footer for Trace notification |
| **SnacksDashboardNormal** | _Normal_ | Normal for the dashboard |
| **SnacksDashboardDesc** | _Special_ | Description text in dashboard |
| **SnacksDashboardFile** | _Special_ | Dashboard file items |
| **SnacksDashboardDir** | _NonText_ | Directory items |
| **SnacksDashboardFooter** | _Title_ | Dashboard footer text |
| **SnacksDashboardHeader** | _Title_ | Dashboard header text |
| **SnacksDashboardIcon** | _Special_ | Dashboard icons |
| **SnacksDashboardKey** | _Number_ | Keybind text |
| **SnacksDashboardTerminal** | _SnacksDashboardNormal_ | Terminal text |
| **SnacksDashboardSpecial** | _Special_ | Special elements |
| **SnacksDashboardTitle** | _Title_ | Title text |