This port of Catppuccin is special because it was the first one and the one that originated the project itself. Given this, it's important to acknowledge that it all didn't come to be what it is now out of nowhere. So, if you are interested in knowing more about the initial stages of the theme, you can find it under the v0.1 tag
# Flavours
# Features - Supports both vim and neovim (Requires [neovim](https://github.com/neovim/neovim/) >= 0.8 or [vim](https://github.com/vim/vim) >= 9 compiled with [lua](https://github.com/lua/lua) >= 5.1) - Highly configurable with 4 different flavours and [ability to create your own!](https://github.com/catppuccin/nvim/discussions/323) - [Compile](https://github.com/catppuccin/nvim#Compile) user config for [fastest startuptime](https://www.reddit.com/r/neovim/comments/xxfpt3/catppuccinnvim_now_startup_in_1ms/) - Integrations with lsp, treesitter and [a bunch of plugins](https://github.com/catppuccin/nvim#integrations) - Supports for [many other applications](https://github.com/catppuccin/catppuccin) # Installation [lazy.nvim](https://github.com/folke/lazy.nvim) ```lua { "catppuccin/nvim", name = "catppuccin", priority = 1000 } ``` [packer.nvim](https://github.com/wbthomason/packer.nvim) ```lua use { "catppuccin/nvim", as = "catppuccin" } ``` [vim-plug](https://github.com/junegunn/vim-plug) ```vim Plug 'catppuccin/nvim', { 'as': 'catppuccin' } ``` # Usage ```vim colorscheme catppuccin " catppuccin-latte, catppuccin-frappe, catppuccin-macchiato, catppuccin-mocha ``` ```lua vim.cmd.colorscheme "catppuccin" ``` # Configuration There is no need to call `setup` if you don't want to change the default options and settings. ```lua require("catppuccin").setup({ flavour = "auto", -- latte, frappe, macchiato, mocha background = { -- :h background light = "latte", dark = "mocha", }, transparent_background = false, -- disables setting the background color. show_end_of_buffer = false, -- shows the '~' characters after the end of buffers term_colors = false, -- sets terminal colors (e.g. `g:terminal_color_0`) dim_inactive = { enabled = false, -- dims the background color of inactive window shade = "dark", percentage = 0.15, -- percentage of the shade to apply to the inactive window }, no_italic = false, -- Force no italic no_bold = false, -- Force no bold no_underline = false, -- Force no underline styles = { -- Handles the styles of general hi groups (see `:h highlight-args`): comments = { "italic" }, -- Change the style of comments conditionals = { "italic" }, loops = {}, functions = {}, keywords = {}, strings = {}, variables = {}, numbers = {}, booleans = {}, properties = {}, types = {}, operators = {}, -- miscs = {}, -- Uncomment to turn off hard-coded styles }, color_overrides = {}, custom_highlights = {}, default_integrations = true, integrations = { cmp = true, gitsigns = true, nvimtree = true, treesitter = true, notify = false, mini = { enabled = true, indentscope_color = "", }, -- For more plugins integrations please scroll down (https://github.com/catppuccin/nvim#integrations) }, }) -- setup must be called before loading vim.cmd.colorscheme "catppuccin" ``` # Customize highlights ## Get catppuccin colors ```lua local latte = require("catppuccin.palettes").get_palette "latte" local frappe = require("catppuccin.palettes").get_palette "frappe" local macchiato = require("catppuccin.palettes").get_palette "macchiato" local mocha = require("catppuccin.palettes").get_palette "mocha" ``` Returns a table where the key is the name of the color and the value is its hex value corresponding to each flavour. ## Overwriting colors Colors can be overwritten using `color_overrides` in the setting, checkout https://github.com/catppuccin/nvim/discussions/323 for inspirations: ```lua require("catppuccin").setup { color_overrides = { all = { text = "#ffffff", }, latte = { base = "#ff0000", mantle = "#242424", crust = "#474747", }, frappe = {}, macchiato = {}, mocha = {}, } } ``` > [!Note] > For more information check out our [style-guide](https://github.com/catppuccin/catppuccin/blob/main/docs/style-guide.md) ## Overwriting highlight groups Global highlight groups can be overwritten in the setting, for example: ```lua require("catppuccin").setup { custom_highlights = function(colors) return { Comment = { fg = colors.flamingo }, TabLineSel = { bg = colors.pink }, CmpBorder = { fg = colors.surface2 }, Pmenu = { bg = colors.none }, } end } ``` Per flavour highlight groups can also be overwritten in the setting, for example: ```lua require("catppuccin").setup { highlight_overrides = { all = function(colors) return { NvimTreeNormal = { fg = colors.none }, CmpBorder = { fg = "#3e4145" }, } end, latte = function(latte) return { Normal = { fg = latte.base }, } end, frappe = function(frappe) return { ["@comment"] = { fg = frappe.surface2, style = { "italic" } }, } end, macchiato = function(macchiato) return { LineNr = { fg = macchiato.overlay1 }, } end, mocha = function(mocha) return { Comment = { fg = mocha.flamingo }, } end, }, } ``` # Integrations Catppuccin provides theme support for other plugins in the Neovim ecosystem and extended Neovim functionality through _integrations_. To enable/disable an integration you just need to set it to true/false, for example: ```lua require("catppuccin").setup({ integrations = { cmp = true, gitsigns = true, nvimtree = true, treesitter = true, notify = false, mini = { enabled = true, indentscope_color = "", }, } }) ``` Some integrations are enabled by default, you can control this behaviour with `default_integrations` option. ```lua require("catppuccin").setup({ default_integrations = false, }) ``` Below is a list of supported plugins and their corresponding integration module. > [!Important] > If you'd like to know which highlight groups are being affected by catppuccin, check out this directory: [`lua/catppuccin/groups/integrations/`](https://github.com/catppuccin/nvim/tree/main/lua/catppuccin/groups/integrations).
Plugin | Default |
aerial.nvim | ```lua aerial = false ``` |
alpha-nvim | ```lua alpha = true ``` |
barbar.nvim | ```lua barbar = false ``` |
barbecue.nvim |
```lua
barbecue = {
dim_dirname = true, -- directory name is dimmed by default
bold_basename = true,
dim_context = false,
alt_background = false,
},
```
SpecialUse this to set it up: ```lua require("barbecue").setup { theme = "catppuccin", -- catppuccin-latte, catppuccin-frappe, catppuccin-macchiato, catppuccin-mocha } ``` |
beacon.nvim | ```lua beacon = false ``` |
bufferline.nvim |
SpecialUpdate your bufferline config to use the Catppuccin components: > [!NOTE] > bufferline needs to be loaded after setting up catppuccin or it will highlight incorrectly ```lua use "akinsho/bufferline.nvim" { after = "catppuccin", config = function() require("bufferline").setup { highlights = require("catppuccin.groups.integrations.bufferline").get() } end } ``` Configurations are self-explanatory, see `:h bufferline-highlights` for detailed explanations: ```lua local mocha = require("catppuccin.palettes").get_palette "mocha" bufferline.setup { highlights = require("catppuccin.groups.integrations.bufferline").get { styles = { "italic", "bold" }, custom = { all = { fill = { bg = "#000000" }, }, mocha = { background = { fg = mocha.text }, }, latte = { background = { fg = "#000000" }, }, }, }, } ``` |
coc.nvim |
```lua
coc_nvim = false
```
SpecialSetting `enabled` to `true` enables this integration. ```lua coc_nvim = true, ``` > [!Note] > coc.nvim by default link to native lsp highlight groups so config from `native_lsp` will also apply to coc In the inners tables you can set the style for the diagnostics, both `virtual_text` (what you see on the side) and `underlines` (what points directly at the thing (e.g. an error)). ```lua native_lsp = { enabled = true, virtual_text = { errors = { "italic" }, hints = { "italic" }, warnings = { "italic" }, information = { "italic" }, ok = { "italic" }, }, underlines = { errors = { "underline" }, hints = { "underline" }, warnings = { "underline" }, information = { "underline" }, ok = { "underline" }, }, inlay_hints = { background = true, }, }, ``` |
colorful-winsep.nvim | ```lua colorful_winsep = { enabled = false, color = "red", } ``` |
dashboard-nvim | ```lua dashboard = true ``` |
diffview.nvim | ```lua diffview = false ``` |
dropbar.nvim | ```lua dropbar = { enabled = false, color_mode = false, -- enable color for kind's texts, not just kind's icons }, ``` |
feline.nvim |
SpecialUpdate your Feline config to use the Catppuccin components: ```lua local ctp_feline = require('catppuccin.groups.integrations.feline') ctp_feline.setup() require("feline").setup({ components = ctp_feline.get(), }) ``` Notice that calling `setup()` is optional. You may pass a lua table in order to change assets, settings and the colors per vim mode. Here are the defaults: ```lua local clrs = require("catppuccin.palettes").get_palette() local ctp_feline = require('catppuccin.groups.integrations.feline') local U = require "catppuccin.utils.colors" ctp_feline.setup({ assets = { left_separator = "", right_separator = "", mode_icon = "", dir = "", file = "", lsp = { server = "", error = "", warning = "", info = "", hint = "", }, git = { branch = "", added = "", changed = "", removed = "", }, }, sett = { text = U.vary_color({ latte = latte.base }, clrs.surface0), bkg = U.vary_color({ latte = latte.crust }, clrs.surface0), diffs = clrs.mauve, extras = clrs.overlay1, curr_file = clrs.maroon, curr_dir = clrs.flamingo, show_modified = false -- show if the file has been modified show_lazy_updates = false -- show the count of updatable plugins from lazy.nvim -- need to set checker.enabled = true in lazy.nvim first -- the icon is set in ui.icons.plugin in lazy.nvim }, mode_colors = { ["n"] = { "NORMAL", clrs.lavender }, ["no"] = { "N-PENDING", clrs.lavender }, ["i"] = { "INSERT", clrs.green }, ["ic"] = { "INSERT", clrs.green }, ["t"] = { "TERMINAL", clrs.green }, ["v"] = { "VISUAL", clrs.flamingo }, ["V"] = { "V-LINE", clrs.flamingo }, [""] = { "V-BLOCK", clrs.flamingo }, ["R"] = { "REPLACE", clrs.maroon }, ["Rv"] = { "V-REPLACE", clrs.maroon }, ["s"] = { "SELECT", clrs.maroon }, ["S"] = { "S-LINE", clrs.maroon }, [""] = { "S-BLOCK", clrs.maroon }, ["c"] = { "COMMAND", clrs.peach }, ["cv"] = { "COMMAND", clrs.peach }, ["ce"] = { "COMMAND", clrs.peach }, ["r"] = { "PROMPT", clrs.teal }, ["rm"] = { "MORE", clrs.teal }, ["r?"] = { "CONFIRM", clrs.mauve }, ["!"] = { "SHELL", clrs.green }, }, view = { lsp = { progress = true, -- if true the status bar will display an lsp progress indicator name = false, -- if true the status bar will display the lsp servers name, otherwise it will display the text "Lsp" exclude_lsp_names = {}, -- lsp server names that should not be displayed when name is set to true separator = "|", -- the separator used when there are multiple lsp servers }, } }) ``` > [!Warning] > Currently feline [doesn't officially support custom themes](https://github.com/feline-nvim/feline.nvim/issues/302). In order for `:colorscheme catppuccin- |
fern.vim | ```lua fern = false ``` |
fidget.nvim |
```lua
fidget = false
```
SpecialSet `notification.window.winblend` to `0`: ```lua require("fidget").setup { notification = { window = { winblend = 0, }, } -- ... the rest of your fidget config } ``` |
flash.nvim | ```lua flash = true ``` |
fzf-lua | ```lua fzf = true ``` |
gitsigns.nvim | ```lua gitsigns = true ``` |
grug-far.nvim | ```lua grug_far = false ``` |
harpoon | ```lua harpoon = false ``` |
headlines.nvim | ```lua headlines = false ``` |
hop.nvim | ```lua hop = false ``` |
indent-blankline.nvim |
```lua
indent_blankline = {
enabled = true,
scope_color = "", -- catppuccin color (eg. `lavender`) Default: text
colored_indent_levels = false,
},
```
Special`colored_indent_levels` enables char highlights per indent level. Follow the instructions [here](https://github.com/lukas-reineke/indent-blankline.nvim#multiple-indent-colors) to set the latter up. |
leap.nvim | ```lua leap = false ``` |
lightline.vim |
Special```vim let g:lightline = {'colorscheme': 'catppuccin'} ``` |
lightspeed.nvim | ```lua lightspeed = false ``` |
lir.nvim | ```lua lir = { enabled = false, git_status = false } ``` |
lspsaga.nvim |
```lua
lsp_saga = false
```
SpecialFor custom Lsp Kind Icon and Color ```lua require("lspsaga").setup { ui = { kind = require("catppuccin.groups.integrations.lsp_saga").custom_kind(), }, } ``` |
lualine.nvim |
Special```lua require('lualine').setup { options = { theme = "catppuccin" -- ... the rest of your lualine config } } ``` |
markdown | ```lua markdown = true ``` |
mason.nvim | ```lua mason = false ``` |
mini.nvim | ```lua mini = { enabled = true, indentscope_color = "", -- catppuccin color (eg. `lavender`) Default: text }, ``` |
neo-tree.nvim | ```lua neotree = false ``` |
neogit | ```lua neogit = true ``` |
neotest | ```lua neotest = false ``` |
noice.nvim | ```lua noice = false ``` |
NormalNvim | ```lua NormalNvim = false ``` |
notifier.nvim | ```lua notifier = false ``` |
nvim-cmp | ```lua cmp = true ``` |
nvim-dap |
```lua
dap = true
```
Special```lua local sign = vim.fn.sign_define sign("DapBreakpoint", { text = "●", texthl = "DapBreakpoint", linehl = "", numhl = ""}) sign("DapBreakpointCondition", { text = "●", texthl = "DapBreakpointCondition", linehl = "", numhl = ""}) sign("DapLogPoint", { text = "◆", texthl = "DapLogPoint", linehl = "", numhl = ""}) ``` |
nvim-dap-ui | ```lua dap_ui = true ``` |
nvim-lspconfig |
```lua
native_lsp = {
enabled = true,
virtual_text = {
errors = { "italic" },
hints = { "italic" },
warnings = { "italic" },
information = { "italic" },
ok = { "italic" },
},
underlines = {
errors = { "underline" },
hints = { "underline" },
warnings = { "underline" },
information = { "underline" },
ok = { "underline" },
},
inlay_hints = {
background = true,
},
},
```
SpecialIn the inners tables you can set the style for the diagnostics, both `virtual_text` (what you see on the side) and `underlines` (what points directly at the thing (e.g. an error)). |
navic |
```lua
navic = {
enabled = false,
custom_bg = "NONE", -- "lualine" will set background to mantle
},
```
Special```lua -- You NEED to enable highlight in nvim-navic setting or it won't work require("nvim-navic").setup { highlight = true } ``` |
nvim-notify | ```lua notify = false ``` |
nvim-semantic-tokens | ```lua semantic_tokens = true ``` |
nvim-surround | ```lua nvim_surround = false ``` |
nvim-tree.lua | ```lua nvimtree = true ``` |
nvim-treesitter-context | ```lua treesitter_context = true ``` |
nvim-treesitter | ```lua treesitter = true ``` |
nvim-ts-rainbow2 | ```lua ts_rainbow2 = false ``` |
nvim-ts-rainbow | ```lua ts_rainbow = false ``` |
nvim-ufo | ```lua ufo = true ``` |
nvim-window-picker | ```lua window_picker = false ``` |
octo.nvim | ```lua octo = false ``` |
overseer.nvim | ```lua overseer = false ``` |
pounce.nvim | ```lua pounce = false ``` |
rainbow-delimiters.nvim | ```lua rainbow_delimiters = true ``` |
reactive.nvim |
SpecialThere're 2 available presets (`cursor` and `cursorline`) for every flavour. Here is how you can use them. ```lua require('reactive').setup { load = { 'catppuccin-mocha-cursor', 'catppuccin-mocha-cursorline' } } ``` To use another flavour just replace `mocha` with the one you want to use. |
render-markdown.nvim | ```lua render_markdown = true ``` |
symbols-outline.nvim | > [!NOTE] > This plugin has been archived by the author, consider using [outline.nvim](https://github.com/hedyhli/outline.nvim) ```lua symbols_outline = false ``` |
telekasten.nvim | ```lua telekasten = false ``` |
telescope.nvim | ```lua telescope = { enabled = true, -- style = "nvchad" } ``` |
trouble.nvim | ```lua lsp_trouble = false ``` |
vim-airline |
Special```vim let g:airline_theme = 'catppuccin' ``` |
vim-clap |
SpecialUse this to set it up: ```vim let g:clap_theme = 'catppuccin' ``` |
vim-dadbod-ui | ```lua dadbod_ui = false ``` |
vim-gitgutter | ```lua gitgutter = false ``` |
vim-illuminate | ```lua illuminate = { enabled = true, lsp = false } ``` |
vim-sandwich | ```lua sandwich = false ``` |
vim-sneak | ```lua vim_sneak = false ``` |
vimwiki | ```lua vimwiki = false ``` |
which-key.nvim | ```lua which_key = false ``` |
Copyright © 2021-present Catppuccin Org