neovim-rose-pine/readme.md
2022-01-28 18:32:46 -06:00

146 lines
6.1 KiB
Markdown

<p align="center">
<img src="https://github.com/rose-pine/rose-pine-theme/raw/main/assets/icon.png" width="80" />
<h2 align="center">Rosé Pine for Neovim</h2>
</p>
<p align="center">All natural pine, faux fur and a bit of soho vibes for the classy minimalist</p>
<p align="center">
<a href="https://github.com/rose-pine/rose-pine-theme">
<img src="https://img.shields.io/badge/community-rosé%20pine-26233a?labelColor=191724&logo=&style=for-the-badge" />
</a>
</p>
## Usage
```lua
use({
'rose-pine/neovim',
as = 'rose-pine',
tag = 'v0.1.0', -- Optional tag release
config = function()
vim.cmd('colorscheme rose-pine')
end
})
```
## Plugins
> PR's are more than welcome if your favourite plugin is missing
- [Treesitter](https://github.com/nvim-treesitter/nvim-treesitter)
- [Diagnostics](https://neovim.io/doc/user/lsp.html)
- [Barbar](https://github.com/romgrk/barbar.nvim)
- [Gitsigns](https://github.com/lewis6991/gitsigns.nvim)
- [Modes](https://github.com/mvllow/modes.nvim)
- [NvimTree](https://github.com/kyazdani42/nvim-tree.lua)
- [WhichKey](https://github.com/folke/which-key.nvim)
- [Indent-Blankline.nvim](https://github.com/lukas-reineke/indent-blankline.nvim)
- [Neogit](https://github.com/TimUntersberger/neogit)
- [Neorg](https://github.com/nvim-neorg/neorg)
- [Lspsaga](https://github.com/tami5/lspsaga.nvim)
- [Pounce](https://github.com/rlane/pounce.nvim)
- [Telescope](https://github.com/nvim-telescope/telescope.nvim)
- [Lualine](https://github.com/hoob3rt/lualine.nvim)
```lua
require('lualine').setup({
options = { theme = 'rose-pine' }
})
```
- [Galaxyline fork](https://github.com/NTBBloodbath/galaxyline.nvim)
```lua
local colors = require("galaxyline.themes.colors")["rose-pine"]
```
## Gallery
**Rosé Pine**
![Rosé Pine with Neovim](assets/rose-pine.png)
**Rosé Pine Moon**
![Rosé Pine Moon with Neovim](assets/rose-pine-moon.png)
**Rosé Pine Dawn**
![Rosé Pine Dawn with Neovim](assets/rose-pine-dawn.png)
## Options
> Options should be set **before** colorscheme
```lua
-- Set theme variant
-- Matches terminal theme if unset
-- @usage 'main' | 'moon' | 'dawn'
vim.g.rose_pine_variant = ''
vim.g.rose_pine_bold_vertical_split_line = false
vim.g.rose_pine_inactive_background = false
vim.g.rose_pine_disable_background = false
vim.g.rose_pine_disable_float_background = false
vim.g.rose_pine_disable_italics = false
local p = require('rose-pine.palette')
vim.g.rose_pine_colors = {
punctuation = p.subtle,
comment = p.subtle,
border = p.highlight_med,
hint = p.iris,
info = p.foam,
warn = p.gold,
error = p.love,
-- Or set all headings to one colour: `headings = p.text`
headings = {
h1 = p.iris,
h2 = p.foam,
h3 = p.rose,
h4 = p.gold,
h5 = p.pine,
h6 = p.foam,
},
}
-- Set colorscheme after options
vim.cmd('colorscheme rose-pine')
```
## Functions
```lua
-- Toggle between all variants
require('rose-pine').toggle()
-- Toggle between some variants
require('rose-pine').toggle({'main', 'dawn'})
-- Set specific variant
require('rose-pine').set('moon')
```
## Keymaps
> These are only suggestions; no keymaps are set by the theme
```lua
-- Toggle variants
vim.api.nvim_set_keymap('n', '<c-m>', [[<cmd>lua require('rose-pine').toggle()<cr>]], { noremap = true, silent = true })
-- Set variant
vim.api.nvim_set_keymap('n', '<c-0>', [[<cmd>lua require('rose-pine').set('main')<cr>]], { noremap = true, silent = true })
vim.api.nvim_set_keymap('n', '<c-9>', [[<cmd>lua require('rose-pine').set('moon')<cr>]], { noremap = true, silent = true })
vim.api.nvim_set_keymap('n', '<c-8>', [[<cmd>lua require('rose-pine').set('dawn')<cr>]], { noremap = true, silent = true })
```
## Contributing
We welcome and appreciate any help in creating a lovely experience for all.
- [Get highlight groups under cursor](https://github.com/nvim-treesitter/playground#show-treesitter-and-syntax-highlight-groups-under-the-cursor)
- [Adding new highlight groups](https://github.com/rose-pine/neovim/issues/6#issuecomment-962466323)