🏙 Tokyo Night
🏙 Tokyo Night
A dark and light Neovim theme written in Lua ported from the Visual Studio Code TokyoNight theme. Includes extra themes for Kitty, Alacritty, iTerm and Fish.
Moon | Storm |
---|---|
Night | Day |
✨ Features
- Supports the latest Neovim 0.9.0 features.
- Terminal colors.
- Supports all major plugins.
- Provides TokyoNight extras for numerous other applications.
🎨 Supported Plugins
| Plugin | Source | | --- | --- | | [aerial.nvim](https://github.com/stevearc/aerial.nvim) | [`aerial`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/aerial.lua) | | [ale](https://github.com/dense-analysis/ale) | [`ale`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/ale.lua) | | [alpha-nvim](https://github.com/goolord/alpha-nvim) | [`alpha`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/alpha.lua) | | [barbar.nvim](https://github.com/romgrk/barbar.nvim) | [`barbar`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/barbar.lua) | | [bufferline.nvim](https://github.com/akinsho/bufferline.nvim) | [`bufferline`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/bufferline.lua) | | [nvim-cmp](https://github.com/hrsh7th/nvim-cmp) | [`cmp`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/cmp.lua) | | [nvim-dap](https://github.com/mfussenegger/nvim-dap) | [`dap`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/dap.lua) | | [dashboard-nvim](https://github.com/nvimdev/dashboard-nvim) | [`dashboard`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/dashboard.lua) | | [flash.nvim](https://github.com/folke/flash.nvim) | [`flash`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/flash.lua) | | [fzf-lua](https://github.com/ibhagwan/fzf-lua) | [`fzf`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/fzf.lua) | | [vim-gitgutter](https://github.com/airblade/vim-gitgutter) | [`gitgutter`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/gitgutter.lua) | | [gitsigns.nvim](https://github.com/lewis6991/gitsigns.nvim) | [`gitsigns`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/gitsigns.lua) | | [glyph-palette.vim](https://github.com/lambdalisue/glyph-palette.vim) | [`glyph-palette`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/glyph-palette.lua) | | [grug-far.nvim](https://github.com/MagicDuck/grug-far.nvim) | [`grug-far`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/grug-far.lua) | | [headlines.nvim](https://github.com/lukas-reineke/headlines.nvim) | [`headlines`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/headlines.lua) | | [hop.nvim](https://github.com/phaazon/hop.nvim) | [`hop`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/hop.lua) | | [vim-illuminate](https://github.com/RRethy/vim-illuminate) | [`illuminate`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/illuminate.lua) | | [indent-blankline.nvim](https://github.com/lukas-reineke/indent-blankline.nvim) | [`indent-blankline`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/indent-blankline.lua) | | [indentmini.nvim](https://github.com/nvimdev/indentmini.nvim) | [`indentmini`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/indentmini.lua) | | [lazy.nvim](https://github.com/folke/lazy.nvim) | [`lazy`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/lazy.lua) | | [leap.nvim](https://github.com/ggandor/leap.nvim) | [`leap`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/leap.lua) | | [lspsaga.nvim](https://github.com/glepnir/lspsaga.nvim) | [`lspsaga`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/lspsaga.lua) | | [markdown.nvim](https://github.com/MeanderingProgrammer/markdown.nvim) | [`markdown`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/markdown.lua) | | [mini.animate](https://github.com/echasnovski/mini.animate) | [`mini_animate`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_animate.lua) | | [mini.clue](https://github.com/echasnovski/mini.clue) | [`mini_clue`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_clue.lua) | | [mini.completion](https://github.com/echasnovski/mini.completion) | [`mini_completion`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_completion.lua) | | [mini.cursorword](https://github.com/echasnovski/mini.cursorword) | [`mini_cursorword`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_cursorword.lua) | | [mini.deps](https://github.com/echasnovski/mini.deps) | [`mini_deps`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_deps.lua) | | [mini.diff](https://github.com/echasnovski/mini.diff) | [`mini_diff`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_diff.lua) | | [mini.files](https://github.com/echasnovski/mini.files) | [`mini_files`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_files.lua) | | [mini.hipatterns](https://github.com/echasnovski/mini.hipatterns) | [`mini_hipatterns`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_hipatterns.lua) | | [mini.icons](https://github.com/echasnovski/mini.icons) | [`mini_icons`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_icons.lua) | | [mini.indentscope](https://github.com/echasnovski/mini.indentscope) | [`mini_indentscope`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_indentscope.lua) | | [mini.jump](https://github.com/echasnovski/mini.jump) | [`mini_jump`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_jump.lua) | | [mini.map](https://github.com/echasnovski/mini.map) | [`mini_map`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_map.lua) | | [mini.notify](https://github.com/echasnovski/mini.notify) | [`mini_notify`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_notify.lua) | | [mini.operators](https://github.com/echasnovski/mini.operators) | [`mini_operators`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_operators.lua) | | [mini.pick](https://github.com/echasnovski/mini.pick) | [`mini_pick`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_pick.lua) | | [mini.starter](https://github.com/echasnovski/mini.starter) | [`mini_starter`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_starter.lua) | | [mini.statusline](https://github.com/echasnovski/mini.statusline) | [`mini_statusline`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_statusline.lua) | | [mini.surround](https://github.com/echasnovski/mini.surround) | [`mini_surround`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_surround.lua) | | [mini.tabline](https://github.com/echasnovski/mini.tabline) | [`mini_tabline`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_tabline.lua) | | [mini.test](https://github.com/echasnovski/mini.test) | [`mini_test`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_test.lua) | | [mini.trailspace](https://github.com/echasnovski/mini.trailspace) | [`mini_trailspace`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/mini_trailspace.lua) | | [nvim-navic](https://github.com/SmiteshP/nvim-navic) | [`navic`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/navic.lua) | | [neo-tree.nvim](https://github.com/nvim-neo-tree/neo-tree.nvim) | [`neo-tree`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/neo-tree.lua) | | [neogit](https://github.com/TimUntersberger/neogit) | [`neogit`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/neogit.lua) | | [neotest](https://github.com/nvim-neotest/neotest) | [`neotest`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/neotest.lua) | | [noice.nvim](https://github.com/folke/noice.nvim) | [`noice`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/noice.lua) | | [nvim-notify](https://github.com/rcarriga/nvim-notify) | [`notify`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/notify.lua) | | [nvim-tree.lua](https://github.com/kyazdani42/nvim-tree.lua) | [`nvim-tree`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/nvim-tree.lua) | | [octo.nvim](https://github.com/pwntester/octo.nvim) | [`octo`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/octo.lua) | | [rainbow-delimiters.nvim](https://github.com/HiPhish/rainbow-delimiters.nvim) | [`rainbow`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/rainbow.lua) | | [nvim-scrollbar](https://github.com/petertriho/nvim-scrollbar) | [`scrollbar`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/scrollbar.lua) | | [vim-sneak](https://github.com/justinmk/vim-sneak) | [`sneak`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/sneak.lua) | | [telescope.nvim](https://github.com/nvim-telescope/telescope.nvim) | [`telescope`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/telescope.lua) | | [nvim-treesitter-context](https://github.com/nvim-treesitter/nvim-treesitter-context) | [`treesitter-context`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/treesitter-context.lua) | | [trouble.nvim](https://github.com/folke/trouble.nvim) | [`trouble`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/trouble.lua) | | [vimwiki](https://github.com/vimwiki/vimwiki) | [`vimwiki`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/vimwiki.lua) | | [which-key.nvim](https://github.com/folke/which-key.nvim) | [`which-key`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/which-key.lua) | | [yanky.nvim](https://github.com/gbprod/yanky.nvim) | [`yanky`](/config/nvim/external/themes/tokyonight/lua/tokyonight/groups/yanky.lua) |🍭 Extras
| Tool | Extra | | --- | --- | | [Aerc](https://git.sr.ht/~rjarry/aerc/) | [extras/aerc](extras/aerc) | | [Alacritty](https://github.com/alacritty/alacritty) | [extras/alacritty](extras/alacritty) | | [Delta](https://github.com/dandavison/delta) | [extras/delta](extras/delta) | | [Dunst](https://dunst-project.org/) | [extras/dunst](extras/dunst) | | [Fish](https://fishshell.com/docs/current/index.html) | [extras/fish](extras/fish) | | [Fish Themes](https://fishshell.com/docs/current/interactive.html#syntax-highlighting) | [extras/fish_themes](extras/fish_themes) | | [Foot](https://codeberg.org/dnkl/foot) | [extras/foot](extras/foot) | | [Fuzzel](https://codeberg.org/dnkl/fuzzel) | [extras/fuzzel](extras/fuzzel) | | [Fzf](https://github.com/junegunn/fzf) | [extras/fzf](extras/fzf) | | [GitUI](https://github.com/extrawurst/gitui) | [extras/gitui](extras/gitui) | | [GNOME Terminal](https://gitlab.gnome.org/GNOME/gnome-terminal) | [extras/gnome_terminal](extras/gnome_terminal) | | [Helix](https://helix-editor.com/) | [extras/helix](extras/helix) | | [iTerm](https://iterm2.com/) | [extras/iterm](extras/iterm) | | [Kitty](https://sw.kovidgoyal.net/kitty/conf.html) | [extras/kitty](extras/kitty) | | [Lazygit](https://github.com/jesseduffield/lazygit) | [extras/lazygit](extras/lazygit) | | [Lua Table for testing](https://www.lua.org) | [extras/lua](extras/lua) | | [Prism](https://prismjs.com) | [extras/prism](extras/prism) | | [process-compose](https://f1bonacc1.github.io/process-compose/) | [extras/process_compose](extras/process_compose) | | [Slack](https://slack.com) | [extras/slack](extras/slack) | | [Spotify Player](https://github.com/aome510/spotify-player) | [extras/spotify_player](extras/spotify_player) | | [Sublime Text](https://www.sublimetext.com/docs/themes) | [extras/sublime](extras/sublime) | | [Terminator](https://gnome-terminator.readthedocs.io/en/latest/config.html) | [extras/terminator](extras/terminator) | | [Tilix](https://github.com/gnunn1/tilix) | [extras/tilix](extras/tilix) | | [Tmux](https://github.com/tmux/tmux/wiki) | [extras/tmux](extras/tmux) | | [Vim](https://vimhelp.org/) | [extras/vim](extras/vim) | | [Vimium](https://vimium.github.io/) | [extras/vimium](extras/vimium) | | [WezTerm](https://wezfurlong.org/wezterm/config/files.html) | [extras/wezterm](extras/wezterm) | | [Windows Terminal](https://aka.ms/terminal-documentation) | [extras/windows_terminal](extras/windows_terminal) | | [Xfce Terminal](https://docs.xfce.org/apps/terminal/advanced) | [extras/xfceterm](extras/xfceterm) | | [Xresources](https://wiki.archlinux.org/title/X_resources) | [extras/xresources](extras/xresources) | | [Yazi](https://github.com/sxyazi/yazi) | [extras/yazi](extras/yazi) | | [Zathura](https://pwmt.org/projects/zathura/) | [extras/zathura](extras/zathura) | | [Zellij](https://zellij.dev/) | [extras/zellij](extras/zellij) |⚡️ Requirements
📦 Installation
Install the theme with your preferred package manager, such as folke/lazy.nvim:
{
"folke/tokyonight.nvim",
lazy = false,
priority = 1000,
opts = {},
}
🚀 Usage
vim.cmd[[colorscheme tokyonight]]
colorscheme tokyonight
" There are also colorschemes for the different styles.
colorscheme tokyonight-night
colorscheme tokyonight-storm
colorscheme tokyonight-day
colorscheme tokyonight-moon
Some plugins need extra configuration to work with TokyoNight.
Click here for more details
### [Barbecue](https://github.com/utilyre/barbecue.nvim) ```lua -- Lua require('barbecue').setup { -- ... your barbecue config theme = 'tokyonight', -- ... your barbecue config } ``` ### [Lualine](https://github.com/nvim-lualine/lualine.nvim) ```lua -- Lua require('lualine').setup { options = { -- ... your lualine config theme = 'tokyonight' -- ... your lualine config } } ``` ### [Lightline](https://github.com/itchyny/lightline.vim) ```vim " Vim Script let g:lightline = {'colorscheme': 'tokyonight'} ```⚙️ Configuration
[!IMPORTANT] Set the configuration BEFORE loading the color scheme with
colorscheme tokyonight
.
The theme offers four styles: storm, moon, night, and day.
The day style is used when { style = "day" }
is passed to
setup(options)
or when vim.o.background = "light"
.
TokyoNight uses the default options,
unless setup
is explicitly called.
Default Options
```lua ---@class tokyonight.Config ---@field on_colors fun(colors: ColorScheme) ---@field on_highlights fun(highlights: tokyonight.Highlights, colors: ColorScheme) M.defaults = { style = "moon", -- The theme comes in three styles, `storm`, a darker variant `night` and `day` light_style = "day", -- The theme is used when the background is set to light transparent = false, -- Enable this to disable setting the background color terminal_colors = true, -- Configure the colors used when opening a `:terminal` in Neovim styles = { -- Style to be applied to different syntax groups -- Value is any valid attr-list value for `:help nvim_set_hl` comments = { italic = true }, keywords = { italic = true }, functions = {}, variables = {}, -- Background styles. Can be "dark", "transparent" or "normal" sidebars = "dark", -- style for sidebars, see below floats = "dark", -- style for floating windows }, day_brightness = 0.3, -- Adjusts the brightness of the colors of the **Day** style. Number between 0 and 1, from dull to vibrant colors dim_inactive = false, -- dims inactive windows lualine_bold = false, -- When `true`, section headers in the lualine theme will be bold --- You can override specific color groups to use other groups or a hex color --- function will be called with a ColorScheme table ---@param colors ColorScheme on_colors = function(colors) end, --- You can override specific highlights to use other groups or a hex color --- function will be called with a Highlights and ColorScheme table ---@param highlights tokyonight.Highlights ---@param colors ColorScheme on_highlights = function(highlights, colors) end, cache = true, -- When set to true, the theme will be cached for better performance ---@type table<string, boolean|{enabled:boolean}> plugins = { -- enable all plugins when not using lazy.nvim -- set to false to manually enable/disable plugins all = package.loaded.lazy == nil, -- uses your plugin manager to automatically enable needed plugins -- currently only lazy.nvim is supported auto = true, -- add any plugins here that you want to enable -- for all possible plugins, see: -- * https://github.com/folke/tokyonight.nvim/tree/main/lua/tokyonight/groups -- telescope = true, }, } ```🪓 Overriding Colors & Highlight Groups
How the highlight groups are calculated:
colors
are determined based on your configuration, with the ability to override them usingconfig.on_colors(colors)
.- These
colors
are utilized to generate the highlight groups. config.on_highlights(highlights, colors)
can be used to override highlight groups.
For default values of colors
and highlights
, please consult the
storm,
moon,
night, and
day themes.
Settings & Changing Colors
```lua require("tokyonight").setup({ -- use the night style style = "night", -- disable italic for functions styles = { functions = {} }, -- Change the "hint" color to the "orange" color, and make the "error" color bright red on_colors = function(colors) colors.hint = colors.orange colors.error = "#ff0000" end }) ```Borderless Telescope
```lua require("tokyonight").setup({ on_highlights = function(hl, c) local prompt = "#2d3149" hl.TelescopeNormal = { bg = c.bg_dark, fg = c.fg_dark, } hl.TelescopeBorder = { bg = c.bg_dark, fg = c.bg_dark, } hl.TelescopePromptNormal = { bg = prompt, } hl.TelescopePromptBorder = { bg = prompt, fg = prompt, } hl.TelescopePromptTitle = { bg = prompt, fg = prompt, } hl.TelescopePreviewTitle = { bg = c.bg_dark, fg = c.bg_dark, } hl.TelescopeResultsTitle = { bg = c.bg_dark, fg = c.bg_dark, } end, }) ```Fix undercurls
in Tmux
To have undercurls show up and in color, add the following to your
[Tmux](https://github.com/tmux/tmux) configuration file:
```sh
# Undercurl
set -g default-terminal "${TERM}"
set -as terminal-overrides ',*:Smulx=\E[4::%p1%dm' # undercurl support
set -as terminal-overrides ',*:Setulc=\E[58::2::%p1%{65536}%/%d::%p1%{256}%/%{255}%&%d::%p1%{255}%&%d%;m' # underscore colours - needs tmux-3.0
```
🍭 Extras
Extra color configs for Kitty, Alacritty, Fish, WezTerm, iTerm and foot can be found in extras. To use them, refer to their respective documentation.
You can easily use the color palette for other plugins inside your Neovim configuration:
local colors = require("tokyonight.colors").setup() -- pass in any of the config options as explained above
local util = require("tokyonight.util")
aplugin.background = colors.bg_dark
aplugin.my_error = util.lighten(colors.red1, 0.3) -- number between 0 and 1. 0 results in white, 1 results in red1
🔥 Contributing
Pull requests are welcome.
For the extras, we use a simple template system that can be used to generate themes for the different styles.
How to add a new extra template:
- Create a file like
lua/tokyonight/extra/cool-app.lua
. - Add the name and output file extension to the
extras
table inlua/tokyonight/extra/init.lua
. -
Run the following command to generate new extra themes from the tokyonight plugin directory:
./scripts/build
- Check the newly created themes in the
extra/
directory. Please DO NOT commit them, as they are already automatically built by the CI.