# 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 |