Compare commits

..

96 commits

Author SHA1 Message Date
Antoine Bertin
72a04c4065
feat: add AvantePromptInput highlight support (#368)
* feat: add AvantePromptInput highlight support
2025-08-24 09:50:23 -05:00
HieuDao-code
0e70556c8c
feat(diffview.nvim): add support for sindrets/diffview.nvim (#369) 2025-08-24 09:47:05 -05:00
Dawid Karpiński
72befaffea
fix: do not clear blend prop from highlight (#351)
* add private built-in blend override

---------

Co-authored-by: mvllow <mvllow@icloud.com>
2025-07-18 15:25:55 -05:00
fdcote
f93360149e
feat: add ModesFormat (#367) 2025-06-26 16:32:32 -05:00
Adrian Schneider
83c66bcadb
feat(grug-far): add highlight groups for add/remove results (#366) 2025-06-26 12:31:24 -05:00
fdcote
6b9840790c feat: add QuickFixLine (#357) 2025-05-05 12:13:20 -05:00
Andrei Heidelbacher
d195ed8673 feat(blink.cmp): improve BlinkCmpDoc contrast between current line (#356) 2025-05-01 16:55:24 -05:00
Andrei Heidelbacher
a67f5ef34b fix(blink.cmp): remove dedicated BlinkCmpDoc highlight (#355)
The default `BlinkCmpDoc` highlight is linked to `NormalFloat`, which is
a sensible default. However, due to overriding the default link with
only `fg` provided, the `bg` is cleared and the documentation popup is
indistinguishable from regular text.

This change is technically a no-op in terms of intended palette, because
`NormalFloat` should already use `palette.text`, and only fixes the
cleared `bg` bug.
2025-04-30 20:53:00 -05:00
Andrei Heidelbacher
39ec539f83 feat(lualine): change background from base to surface (#354)
This change improves the contrast of the statusline while aligning with the theme's spec.
2025-04-30 20:02:53 -05:00
aileot
5ccc379822 fix: set background=light if variant is "dawn" (#349)
* fix: set `background=light` if variant is "dawn"

This change might fix https://github.com/rose-pine/neovim/issues/321

* Update lua/rose-pine.lua

* fix: restrict variants that override `&background`

The other variant params are considered as if "auto"
2025-03-31 10:27:19 -05:00
stelo
d7dc9cd3f2 feat: extends DapUIType fg to iris (#348) 2025-03-11 21:25:25 -05:00
mvllow
44739383b9 docs: add highlight group examples with blend and inherit options 2025-02-25 19:58:52 -06:00
Tiago
8b216f7252 feat: add support for vim-sneak (#342) 2025-02-23 15:19:21 -06:00
mvllow
0511701746 feat: use experimental darker text for dawn 2025-02-05 19:49:14 -06:00
mvllow
946de320f4 fix: strip non-standard blend properties 2025-02-05 19:36:24 -06:00
mvllow
340cf5ed5e feat(perf): cache colors for up to 3x speed improvements 2025-02-05 19:35:55 -06:00
mvllow
f01eac6eed fix: invalid palette format 2025-02-03 11:28:57 -06:00
mvllow
3d71ab02f2 feat: reduce background opacity for special comments 2025-02-03 11:06:21 -06:00
mvllow
0ca4bfbc6f feat: set attribute style 2025-02-03 11:05:57 -06:00
mvllow
8db1217704 feat: use consistent variable styles 2025-02-03 11:05:44 -06:00
mvllow
2b88dfb054 refactor: update documentation 2025-02-03 11:05:20 -06:00
aileot
ffd5b69948 refactor(gitsigns): avoid redundant links (#336)
The `SignAdd`, `SignChange`, and `SignDelete` are never referenced by
any other highlight definitions than the previous `GitSigns` ones before
this change.

The isolated definitions are only left for backward compatibility.
2025-02-02 15:09:20 -06:00
Patrick Haun
6b51153905 More obvious match highlight in snacks.picker (#335) 2025-01-15 14:28:37 -06:00
Federico Minaya
40f03c4df1 feat: add snacks indent highlights (#334) 2025-01-14 15:20:19 -06:00
mvllow
463742691b feat: add Notify*Body highlights
Fixes #331
2025-01-08 09:37:09 -06:00
mvllow
c306f13158 feat: use blended iris for visual
Fixes #277
2025-01-08 09:09:59 -06:00
mvllow
fc418a716f fix: lualine transparency
Fixes #333
2025-01-07 09:47:00 -06:00
YarLama
36526815ee Update readme.md (#328)
* Update readme.md

Extended description for Structured Setup lazy.nvim

* Update readme.md

---------

Co-authored-by: mvllow <mvllow@icloud.com>
2024-12-10 09:50:19 -06:00
Metin Yalcinkaya
a449bb2599 feat: added highlight support for Saghen/blink.cmp (#329)
Closes #326
2024-12-10 09:39:28 -06:00
Anupam Basu
5e7bf83782 feat: add highlight support for epwalsh/obsidian.nvim (#323)
---------

Co-authored-by: mvllow <mvllow@icloud.com>
2024-10-23 18:59:08 -04:00
mvllow
1ebe0a5171 feat: use gold for search
Closes #305
2024-10-08 10:22:29 -05:00
not
8869e546d4 feat(transparency): support trouble.nvim (#319) 2024-08-25 13:09:15 -05:00
not
2f44ef189f feat: use neutral colours for search (#318) 2024-08-25 12:41:35 -05:00
not
22f873c7db fix: palette typo (#317) 2024-08-25 12:37:07 -05:00
dav-cho
33a1ba3126 fix: wrong spelling for palette (#316) 2024-08-25 12:35:29 -05:00
Aaron Pham
fe9e661cda feat(plugins): add support for avante.nvim (#315) 2024-08-25 12:20:43 -05:00
jostaub
94ffdb7748 feat: palette overrides (#307)
* feat: palette overrides

* removed option all from palett override

* removed dead code forgotten in last commit

* fix typo in readme and simplified comment

Co-authored-by: not <mvllow@icloud.com>

---------

Co-authored-by: not <mvllow@icloud.com>
2024-08-14 13:40:33 -05:00
Allan Deutsch
d97cc7fcd7 fix: nvim-notify background (#308) 2024-08-12 15:59:44 -05:00
Vlad
7f0b8c4c7f chore: markdown.nvim renamed to render-markdown.nvim (#309)
Reference to change:
aeb5cec617
2024-08-05 15:59:59 -05:00
Shaun Clayton
c14da532fa feat: add support for grug-far.nvim (#304)
* feat: add support for grug-far.nvim

* fix: change link for results match to `CurSearch`

Co-authored-by: not <mvllow@icloud.com>

* fix: add highlights for line numbers

---------

Co-authored-by: not <mvllow@icloud.com>
2024-07-25 16:47:21 -05:00
Shaun Clayton
8b1a2e73d2 feat: add support for markdown.nvim (#303)
* feat: add support for markdown.nvim

* fix: tweaked some highlights to achieve better appearance

* fix: adjust heading highlights to use group linking
2024-07-24 16:29:39 -05:00
not
d6112a7c56 fix(transparency): lualine separator (#301)
Fixes #288
2024-07-23 21:51:43 -05:00
not
535240c846 feat: highlight neotree tabs (#300)
Fixes #263
2024-07-23 19:17:59 -05:00
Shaun Clayton
f7c01f07ee fix: fzf-lua invisible selection (#299)
* fix: invisible text in selection in fzf-lua

* fix: correct bg color for FzfLuaNormal

* fix: invisible text in selection in fzf-lua

* fix: correct bg color for FzfLuaNormal

* fix: change linking and add highlight for FzfLuaFilePart

* fix: linking to 'FloatTitle' for WhichKeyTitle

This works the same as the original fix, confirmed by testing
against nvim 0.10.0 and nightly.

Prefer linking over previous solution.
2024-07-23 16:56:40 -05:00
not
656f360ded feat: improve diff text (#297) 2024-07-22 16:07:45 -05:00
not
5929bc8683 feat: improve float transparency (#298) 2024-07-22 11:12:10 -05:00
Shaun Clayton
bf7ceb32fa chore: update mini-icons highlights to use appropriate colors (#295) 2024-07-22 10:17:13 -05:00
Shaun Clayton
3bbd8a865c fix: broken transparency for treesitter-context (#294) 2024-07-22 00:23:59 -05:00
Shaun Clayton
afb46f9b66 fix: add missing highlight (#293) 2024-07-21 23:06:14 -05:00
Shaun Clayton
f2bf6e8d49 feat: add support for rainbow-delimiters.nvim (#292) 2024-07-21 16:39:15 -05:00
Shaun Clayton
2f1733d36f feat: add support for icons in which-key.nvim (#291)
* feat: add icon support for which-key.nvim

* fix: incorrect color reference

* feat: set WhichKeyIcon hl group to 'pine' by default

Used when the colors option is set to false.
2024-07-21 16:12:11 -05:00
Shaun Clayton
c4b55e85fb feat(palette): add initial support for new color leaf (#290)
* feat(palette): add new color 'leaf'

* feat: add  highlight groups to defaults
2024-07-21 13:17:17 -05:00
Shaun Clayton
fe5f4e11f7 chore: update highlights for which-key.nvim (#287)
* chore: update highlights for which-key.nvim

* fix: revert placement of WhichKeyFloat hl group

* feat: add additional highlight groups for icons in which-key

* Revert "feat: add additional highlight groups for icons in which-key"

Need to come up with a different solution.

This reverts commit 18d70420a2.

* fix: use explicit fg and bg for WhichKeyTitle

* Revert "fix: use explicit fg and bg for WhichKeyTitle"

Breaks extend_background_behind_borders again... Oops

This reverts commit 1389556a19.
2024-07-15 10:21:08 -05:00
Ilya Kuporosov
69b3aa9500 fix: link @lsp.type.comment.c, @lsp.type.comment.cpp to @comment (#282)
It fixes branches of conditional directives like `#if` and `#ifdef` in C and C++
appearing as if they both are true, without breaking TODO comments.
2024-07-03 16:23:19 -05:00
not
71852123cc feat: set matching background on MiniFilesTitle (#280) 2024-06-27 12:55:27 -05:00
Evgeni Chasnovski
6d476a5c64 feat: add explicit full 'mini.nvim' support (#279) 2024-06-27 12:51:35 -05:00
not
958dce3da9 feat: support upcoming modes.nvim update (#274)
[modes.nvim](https://github.com/mvllow/modes.nvim) is about to
incorporate replace mode.
2024-06-09 10:48:51 -05:00
abvee
511e82e272 Added ["@float"] to default_highlights (#272) (#273) 2024-05-25 21:52:38 -05:00
not
f67828be44 Revert "feat: new themes for lualine (#267)" (#269)
This reverts commit cbc2064f4c.
2024-05-14 09:42:41 -05:00
PRIZ ;]
cbc2064f4c feat: new themes for lualine (#267) 2024-05-10 12:22:41 -05:00
Hayden Rouille
c8477ee978 For transparency, remove BG for buffers and gray out the text (#265) 2024-04-18 09:48:05 -05:00
not
8d9c83d145 format (#264) 2024-04-09 13:00:32 -05:00
Dhruvin Shah
465b7dc623 feat: adding vim-illuminate highlights (#262) 2024-04-09 12:57:04 -05:00
Adam K
e4c22a9163 fix(python): import semantic_tokens from basedpyright (#257)
* fix(python): import semantic_tokens from basedpyright

* fix: restores svelte string highlights
2024-04-09 12:56:29 -05:00
Dave Greene
01dc90af2f Fixed enum use vs magic string (#261) 2024-03-29 22:39:26 -05:00
Julius Rüberg
63f4613365 feat: add highlights for nvim-treesitter-context (#260) 2024-03-29 19:51:22 -05:00
not
1f22d4e97e feat: add mini.diff (#259) 2024-03-28 19:32:00 -05:00
Jaehwang Jung
a959c73910 fix: clear autocmd when changing colorscheme (#254) 2024-03-23 13:53:11 -05:00
not
3dbb8a99bd feat: highlight lsp variable constant (#246)
Closes #245
2024-03-19 18:51:46 -05:00
James Knight
e901a53e41 feat: add mini.statusline highlights (#250) 2024-03-15 12:08:52 -05:00
Andrew
c8e97915d1 feat: add highlight groups for folke/trouble.nvim (#248) 2024-03-05 08:47:17 -06:00
Fitrah
12ace889a0 fix(migrate): avoid ternary 'falls through' state (#242)
See: https://riptutorial.com/lua/example/26503/emulating-ternary-operator-with--and---or--logical-operators-#undefined
2024-02-14 09:58:18 -06:00
not
e28cda232b feat: prioritise semantic variable highlighting (#240) 2024-02-11 20:11:47 -06:00
not
ea3f15ca95 fix: markdown delimiter (#238) 2024-02-08 13:44:50 -06:00
not
4372c4eb49 feat: improve markdown syntax (#237)
* types: update highlight type

* feat: improve markdown highlighting
2024-02-08 13:42:03 -06:00
Maxim Kozhukh
95e9767165 feat: use treesitter highlights for @lsp.type.variable (#233) 2024-01-29 09:57:21 -06:00
Lin Tinusgrag
9d0e1b70d9 feat: make markdown headings distinguishable with treesitter (#232) 2024-01-29 09:54:19 -06:00
Maxim Kozhukh
75d145fa08 fix: unable to override linked groups (#230) 2024-01-29 09:48:02 -06:00
Eric Milford
4452ecd140 feat: Add support for Neotest (#225)
https://github.com/nvim-neotest/neotest/
2024-01-27 21:02:37 -06:00
not
0b77ef0e7b chore: update variable highlights (#226) 2024-01-27 20:34:00 -06:00
Wahyu Wiyoko
8514c638bc fix: misspelled highlight group name (#223) 2024-01-27 09:43:15 -06:00
not
e62a61166e fix: regression in options (#221)
* fix: headings not migrating to flat options

* fix: invalid key when using inherit
2024-01-26 21:43:53 -06:00
not
7ed74e3f24 feat: add new treesitter highlights (#217)
* feat: add WinBar and WinBarNC

* feat: add new treesitter highlight groups

* perf: parse necessary values upfront

This commit no longer parses each highlight group, but rather user
config values only.

* fix: titles are no longer dynamically coloured

Closes #216 #218 #219
2024-01-26 14:12:54 -06:00
not
f4d51d67ee feat: add mini.clue and mini.pick (#215) 2024-01-18 10:28:16 -06:00
not
aa74893a06 fix: unlink TabLine from StatusLine (#214) 2024-01-16 08:31:18 -06:00
atinylittleshell
1ffdf27819 feat(transparency): remove lualine background (#212) 2024-01-14 21:28:49 -06:00
not
e0674e5e5c feat: support folke/flash.nvim (#211) 2024-01-12 20:46:04 -06:00
Robin Gruyters
79e0d756b9 chore: update highlights for indent-blanklines (#210) 2024-01-12 20:39:12 -06:00
not
46044020c6 feat: improve neogit support (#209)
* feat: improve neogit support

* add change copied
2024-01-09 15:44:36 -06:00
not
1edcf47562 fix: mismatched WinSeparator background (#208)
* fix: mismatched WinSeparator background

* feat: use border group for bolded vert split

* fix: Pmenu fg typo
2024-01-08 09:43:57 -06:00
not
188190f285 revert: improve palette contrast (#207)
This commit restores the official palette colours. A future update will
address contrast.
2024-01-08 09:27:46 -06:00
not
bfa2d2b2fb feat(transparency): remove more backgrounds (#205)
* feat(transparency): remove border background

* chore(transparency): remove telescope selection caret background
2024-01-07 23:41:02 -06:00
not
2c892088f9 fix: transparency not affecting Normal background (#204) 2024-01-07 19:27:50 -06:00
not
76b6d830f6 feat!: enable extend_background_behind_borders by default (#201) 2024-01-07 17:55:48 -06:00
not
82285ba9f1 fix: none palette value (#200) 2024-01-07 17:35:36 -06:00
not
86fa83761e feat: re-add inherit option for custom highlight groups (#198) 2024-01-07 15:39:30 -06:00
12 changed files with 974 additions and 309 deletions

View file

@ -1,4 +1,10 @@
local p = require("rose-pine.palette")
local config = require("rose-pine.config")
local bg_base = p.base
if config.options.styles.transparency then
bg_base = "NONE"
end
return {
normal = {
@ -19,8 +25,8 @@ return {
a = { bg = p.surface, fg = p.love, gui = "bold" },
},
inactive = {
a = { bg = p.base, fg = p.subtle, gui = "bold" },
b = { bg = p.base, fg = p.subtle },
c = { bg = p.base, fg = p.subtle, gui = "italic" },
a = { bg = bg_base, fg = p.subtle, gui = "bold" },
b = { bg = bg_base, fg = p.subtle },
c = { bg = bg_base, fg = p.subtle, gui = "italic" },
},
}

View file

@ -1,34 +1,40 @@
local p = require("rose-pine.palette")
local config = require("rose-pine.config")
local bg_base = p.surface
if config.options.styles.transparency then
bg_base = "NONE"
end
return {
normal = {
a = { bg = p.rose, fg = p.base, gui = "bold" },
b = { bg = p.overlay, fg = p.rose },
c = { bg = p.base, fg = p.text },
c = { bg = bg_base, fg = p.text },
},
insert = {
a = { bg = p.foam, fg = p.base, gui = "bold" },
b = { bg = p.overlay, fg = p.foam },
c = { bg = p.base, fg = p.text },
c = { bg = bg_base, fg = p.text },
},
visual = {
a = { bg = p.iris, fg = p.base, gui = "bold" },
b = { bg = p.overlay, fg = p.iris },
c = { bg = p.base, fg = p.text },
c = { bg = bg_base, fg = p.text },
},
replace = {
a = { bg = p.pine, fg = p.base, gui = "bold" },
b = { bg = p.overlay, fg = p.pine },
c = { bg = p.base, fg = p.text },
c = { bg = bg_base, fg = p.text },
},
command = {
a = { bg = p.love, fg = p.base, gui = "bold" },
b = { bg = p.overlay, fg = p.love },
c = { bg = p.base, fg = p.text },
c = { bg = bg_base, fg = p.text },
},
inactive = {
a = { bg = p.base, fg = p.muted, gui = "bold" },
b = { bg = p.base, fg = p.muted },
c = { bg = p.base, fg = p.muted },
a = { bg = bg_base, fg = p.muted, gui = "bold" },
b = { bg = bg_base, fg = p.muted },
c = { bg = bg_base, fg = p.muted },
},
}

File diff suppressed because it is too large Load diff

View file

@ -1,7 +1,7 @@
---@alias Variant "main" | "moon" | "dawn"
---@alias Palette { base: string, surface: string, overlay: string, muted: string, subtle: string, text: string, love: string, gold: string, rose: string, pine: string, foam: string, iris: string }
---@alias PaletteColor "base" | "surface" | "overlay" | "muted" | "subtle" | "text" | "love" | "gold" | "rose" | "pine" | "foam" | "iris" | "highlight_low" | "highlight_med" | "highlight_high"
---@alias Highlight { fg: string, bg: string, sp: string, bold: boolean, italic: boolean, undercurl: boolean, underline: boolean, underdouble: boolean, underdotted: boolean, underdashed: boolean, strikethrough: boolean }
---@alias Highlight { link: string, inherit: boolean } | { fg: string, bg: string, sp: string, bold: boolean, italic: boolean, undercurl: boolean, underline: boolean, underdouble: boolean, underdotted: boolean, underdashed: boolean, strikethrough: boolean, inherit: boolean }
local config = {}
@ -21,11 +21,12 @@ config.options = {
---Extend background behind borders. Appearance differs based on which
---border characters you are using.
extend_background_behind_borders = false,
extend_background_behind_borders = true,
enable = {
terminal = true,
legacy_highlights = true,
migrations = true,
terminal = true,
},
styles = {
@ -34,6 +35,9 @@ config.options = {
transparency = false,
},
---@type table<string, table<string, string>>
palette = {},
---@type table<string, string | PaletteColor>
groups = {
border = "muted",
@ -43,7 +47,10 @@ config.options = {
error = "love",
hint = "iris",
info = "foam",
ok = "leaf",
warn = "gold",
note = "pine",
todo = "rose",
git_add = "foam",
git_change = "rose",
@ -56,15 +63,13 @@ config.options = {
git_text = "rose",
git_untracked = "subtle",
---@type string | PaletteColor | table<string, string | PaletteColor>
headings = {
h1 = "iris",
h2 = "foam",
h3 = "rose",
h4 = "gold",
h5 = "pine",
h6 = "foam",
},
---@type string | PaletteColor
h1 = "iris",
h2 = "foam",
h3 = "rose",
h4 = "gold",
h5 = "pine",
h6 = "leaf",
---@deprecated Replaced by `options.highlight_groups["Normal"]`
-- background = "base",
@ -72,6 +77,8 @@ config.options = {
-- comment = "subtle",
---@deprecated Replaced by `options.highlight_groups["@punctuation"]`
-- punctuation = "muted",
---@deprecated Expects a table with values h1...h6
-- headings = "text",
},
---@type table<string, Highlight>
@ -98,7 +105,13 @@ config.options = {
local function migrate(options)
if options.bold_vert_split then
options.highlight_groups["VertSplit"] = { fg = "muted", bg = "muted" }
local border = options.groups.border or "muted"
options.highlight_groups["VertSplit"] = { fg = border, bg = border }
options.highlight_groups["WinSeparator"] = { fg = border, bg = border }
end
if options.disable_background then
options.highlight_groups["Normal"] = { bg = "NONE" }
end
if options.disable_float_background then
@ -119,27 +132,34 @@ local function migrate(options)
options.highlight_groups["@punctuation"] = { fg = options.groups.punctuation }
end
options.styles.transparency = options.disable_background or options.styles.transparency
options.styles.transparency = (options.disable_background and options.disable_float_background)
or options.styles.transparency
-- These never actually existed, but may be set intuitively by the user
-- because of `disable_italics` existing.
options.styles.bold = (options.disable_bold or options.disable_bolds) and false or options.styles.bold
options.styles.bold = not (options.disable_bold or options.disable_bolds) and options.styles.bold or false
-- Similar to bold options, `disable_italic` never existed but could be a
-- common typo of the actual `disable_italics`.
options.styles.italic = (options.disable_italic or options.disable_italics) and false or options.styles.italic
options.styles.italic = not (options.disable_italic or options.disable_italics) and options.styles.italic or false
-- Set h1 through h6 to the same color if only one is specified
if type(options.groups.headings) == "string" then
options.groups.headings = {
h1 = options.groups.headings,
h2 = options.groups.headings,
h3 = options.groups.headings,
h4 = options.groups.headings,
h5 = options.groups.headings,
h6 = options.groups.headings,
}
options.groups.h1 = options.groups.headings
options.groups.h2 = options.groups.headings
options.groups.h3 = options.groups.headings
options.groups.h4 = options.groups.headings
options.groups.h5 = options.groups.headings
options.groups.h6 = options.groups.headings
elseif options.groups.headings == "table" then
options.groups.h1 = options.groups.headings.h1 or options.groups.h1
options.groups.h2 = options.groups.headings.h2 or options.groups.h2
options.groups.h3 = options.groups.headings.h3 or options.groups.h3
options.groups.h4 = options.groups.headings.h4 or options.groups.h4
options.groups.h5 = options.groups.headings.h5 or options.groups.h5
options.groups.h6 = options.groups.headings.h6 or options.groups.h6
end
options.groups.headings = nil
return options
end

View file

@ -11,12 +11,14 @@ local variants = {
love = "#eb6f92",
gold = "#f6c177",
rose = "#ebbcba",
pine = "#3e8fb0",
pine = "#31748f",
foam = "#9ccfd8",
iris = "#c4a7e7",
leaf = "#95b1ac",
highlight_low = "#21202e",
highlight_med = "#403d52",
highlight_high = "#524f67",
none = "NONE",
},
moon = {
_nc = "#1f1d30",
@ -32,9 +34,11 @@ local variants = {
pine = "#3e8fb0",
foam = "#9ccfd8",
iris = "#c4a7e7",
leaf = "#95b1ac",
highlight_low = "#2a283e",
highlight_med = "#44415a",
highlight_high = "#56526e",
none = "NONE",
},
dawn = {
_nc = "#f8f0e7",
@ -50,12 +54,23 @@ local variants = {
pine = "#286983",
foam = "#56949f",
iris = "#907aa9",
leaf = "#6d8f89",
highlight_low = "#f4ede8",
highlight_med = "#dfdad9",
highlight_high = "#cecacd",
none = "NONE",
},
}
if options.palette ~= nil and next(options.palette) then
-- handle variant specific overrides
for variant_name, override_palette in pairs(options.palette) do
if variants[variant_name] then
variants[variant_name] = vim.tbl_extend("force", variants[variant_name], override_palette or {})
end
end
end
if variants[options.variant] ~= nil then
return variants[options.variant]
end

View file

@ -2,43 +2,43 @@
--- https://github.com/akinsho/bufferline.nvim
---
--- @usage
--- local highlights = require('rose-pine.plugins.bufferline')
--- require('bufferline').setup({ highlights = highlights })
--- local highlights = require("rose-pine.plugins.bufferline")
--- require("bufferline").setup({ highlights = highlights })
local p = require("rose-pine.palette")
return {
-- fill = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- background = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- tab = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
tab_selected = {
fg = p.text,
bg = p.overlay,
},
-- tab_close = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- close_button = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- close_button_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- close_button_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
buffer_visible = {
fg = p.subtle,
@ -51,172 +51,172 @@ return {
italic = true,
},
-- diagnostic = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- diagnostic_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- diagnostic_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- },
-- info = {
-- fg = '<color-value-here>',
-- sp = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- sp = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- info_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- info_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- sp = '<color-value-here>',
-- sp = "<color-value-here>",
-- },
-- info_diagnostic = {
-- fg = '<color-value-here>',
-- sp = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- sp = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- info_diagnostic_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- info_diagnostic_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- sp = '<color-value-here>',
-- sp = "<color-value-here>",
-- },
-- warning = {
-- fg = '<color-value-here>',
-- sp = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- sp = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- warning_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- warning_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- sp = '<color-value-here>',
-- sp = "<color-value-here>",
-- },
-- warning_diagnostic = {
-- fg = '<color-value-here>',
-- sp = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- sp = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- warning_diagnostic_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- warning_diagnostic_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- sp = warning_diagnostic_fg,
-- },
-- error = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- sp = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- sp = "<color-value-here>",
-- },
-- error_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- error_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- sp = '<color-value-here>',
-- sp = "<color-value-here>",
-- },
-- error_diagnostic = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- sp = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- sp = "<color-value-here>",
-- },
-- error_diagnostic_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- error_diagnostic_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- sp = '<color-value-here>',
-- sp = "<color-value-here>",
-- },
-- modified = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- modified_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- modified_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- duplicate_selected = {
-- fg = '<color-value-here>',
-- fg = "<color-value-here>",
-- italic = true,
-- bg = '<color-value-here>',
-- bg = "<color-value-here>",
-- },
-- duplicate_visible = {
-- fg = '<color-value-here>',
-- fg = "<color-value-here>",
-- italic = true,
-- bg = '<color-value-here>',
-- bg = "<color-value-here>",
-- },
-- duplicate = {
-- fg = '<color-value-here>',
-- fg = "<color-value-here>",
-- italic = true,
-- bg = '<color-value-here>',
-- bg = "<color-value-here>",
-- },
-- separator_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- separator_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- separator = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- indicator_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- },
-- pick_selected = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- italic = true,
-- },
-- pick_visible = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- },
-- pick = {
-- fg = '<color-value-here>',
-- bg = '<color-value-here>',
-- fg = "<color-value-here>",
-- bg = "<color-value-here>",
-- bold = true,
-- italic = true,
-- },

View file

@ -2,7 +2,7 @@
--- https://github.com/NTBBloodbath/galaxyline.nvim
---
--- @usage
--- local highlights = require('rose-pine.plugins.galaxyline')
--- local highlights = require("rose-pine.plugins.galaxyline")
local p = require("rose-pine.palette")

View file

@ -2,7 +2,7 @@
--- https://github.com/David-Kunz/markid
---
--- @usage
--- local highlights = require('rose-pine.plugins.markid')
--- local highlights = require("rose-pine.plugins.markid")
--- require("nvim-treesitter.configs").setup({ markid = { enable = true, colors = highlights } })
local p = require("rose-pine.palette")

View file

@ -0,0 +1,14 @@
--- Rosé Pine for Obsidian(epwalsh)
--- https://github.com/epwalsh/obsidian.nvim
---
--- @usage
--- local highlights = require("rose-pine.plugins.obsidian")
--- require("obsidian").setup({ ui = {hl_groups = highlights} })
local p = require("rose-pine.palette")
return {
ObsidianBullet = { fg = p.muted },
ObsidianRefText = { underline = true, fg = p.iris },
ObsidianDone = { bold = true, fg = p.foam }
}

View file

@ -2,8 +2,8 @@
--- https://github.com/akinsho/toggleterm.nvim
---
--- @usage
--- local highlights = require('rose-pine.plugins.toggleterm')
--- require('toggleterm').setup({ highlights = highlights })
--- local highlights = require("rose-pine.plugins.toggleterm")
--- require("toggleterm").setup({ highlights = highlights })
return {
Normal = { link = "Normal" },

View file

@ -14,10 +14,17 @@ local function color_to_rgb(color)
return { byte(new_color, 16), byte(new_color, 8), byte(new_color, 0) }
end
local color_cache = {}
---@param color string Palette key or hex value
local function parse_color(color)
function utilities.parse_color(color)
if color_cache[color] then
return color_cache[color]
end
if color == nil then
return print("Invalid color")
print("Invalid color: " .. color)
return nil
end
color = color:lower()
@ -26,13 +33,21 @@ local function parse_color(color)
color = require("rose-pine.palette")[color] or vim.api.nvim_get_color_by_name(color)
end
color_cache[color] = color
return color
end
local blend_cache = {}
---@param fg string Foreground color
---@param bg string Background color
---@param alpha number Between 0 (background) and 1 (foreground)
local function blend(fg, bg, alpha)
function utilities.blend(fg, bg, alpha)
local cache_key = fg .. bg .. alpha
if blend_cache[cache_key] then
return blend_cache[cache_key]
end
local fg_rgb = color_to_rgb(fg)
local bg_rgb = color_to_rgb(bg)
@ -41,26 +56,10 @@ local function blend(fg, bg, alpha)
return math.floor(math.min(math.max(0, ret), 255) + 0.5)
end
return string.format("#%02X%02X%02X", blend_channel(1), blend_channel(2), blend_channel(3))
end
local result = string.format("#%02X%02X%02X", blend_channel(1), blend_channel(2), blend_channel(3))
---@param group string
---@param highlight table<string, any>
function utilities.highlight(group, highlight, blend_on)
local fg = highlight.fg and parse_color(highlight.fg) or "NONE"
local bg = highlight.bg and parse_color(highlight.bg) or "NONE"
local sp = highlight.sp and parse_color(highlight.sp) or "NONE"
if highlight.blend ~= nil and (highlight.blend >= 0 and highlight.blend <= 100) and bg ~= nil then
bg = blend(bg, blend_on or require("rose-pine.palette").base, highlight.blend / 100)
end
highlight.fg = fg
highlight.bg = bg
highlight.sp = sp
-- highlight = vim.tbl_extend("force", highlight, { fg = fg, bg = bg, sp = sp })
vim.api.nvim_set_hl(0, group, highlight)
blend_cache[cache_key] = result
return result
end
return utilities

View file

@ -13,18 +13,33 @@
## Getting started
Install `rose-pine/neovim` using your favourite plugin manager:
Install `rose-pine/neovim` using your favourite package manager:
**paq-nvim**
### [pam.nvim](https://github.com/mvllow/pam.nvim)
```lua
{ 'rose-pine/neovim', as = 'rose-pine' }
{ source = "rose-pine/neovim", as = "rose-pine" }
```
**lazy.nvim**
### [lazy.nvim](https://lazy.folke.io/installation)
**Structured Setup**
```lua
{ 'rose-pine/neovim', name = 'rose-pine' }
-- lua/plugins/rose-pine.lua
return {
"rose-pine/neovim",
name = "rose-pine",
config = function()
vim.cmd("colorscheme rose-pine")
end
}
```
**Single file**
```lua
{ "rose-pine/neovim", name = "rose-pine" }
```
## Gallery
@ -51,11 +66,17 @@ Rosé Pine has three variants: main, moon, and dawn. By default, `vim.o.backgrou
Colour values accept named colours from the [Rosé Pine palette](https://rosepinetheme.com/palette/ingredients/), e.g. "foam", or valid hex, e.g. "#fa8072".
```lua
require('rose-pine').setup({
require("rose-pine").setup({
variant = "auto", -- auto, main, moon, or dawn
dark_variant = "main", -- main, moon, or dawn
dim_inactive_windows = false,
extend_background_behind_borders = false,
extend_background_behind_borders = true,
enable = {
terminal = true,
legacy_highlights = true, -- Improve compatibility for previous versions of Neovim
migrations = true, -- Handle deprecated options automatically
},
styles = {
bold = true,
@ -71,6 +92,8 @@ require('rose-pine').setup({
error = "love",
hint = "iris",
info = "foam",
note = "pine",
todo = "rose",
warn = "gold",
git_add = "foam",
@ -84,21 +107,29 @@ require('rose-pine').setup({
git_text = "rose",
git_untracked = "subtle",
headings = {
h1 = "iris",
h2 = "foam",
h3 = "rose",
h4 = "gold",
h5 = "pine",
h6 = "foam",
},
-- Alternatively, set all headings at once.
-- headings = "subtle",
h1 = "iris",
h2 = "foam",
h3 = "rose",
h4 = "gold",
h5 = "pine",
h6 = "foam",
},
palette = {
-- Override the builtin palette per variant
-- moon = {
-- base = '#18191a',
-- overlay = '#363738',
-- },
},
-- NOTE: Highlight groups are extended (merged) by default. Disable this
-- per group via `inherit = false`
highlight_groups = {
-- Comment = { fg = "foam" },
-- StatusLine = { fg = "love", bg = "love", blend = 15 },
-- VertSplit = { fg = "muted", bg = "muted" },
-- Visual = { fg = "base", bg = "text", inherit = false },
},
before_highlight = function(group, highlight, palette)
@ -114,10 +145,10 @@ require('rose-pine').setup({
end,
})
vim.cmd('colorscheme rose-pine')
-- vim.cmd('colorscheme rose-pine-main')
-- vim.cmd('colorscheme rose-pine-moon')
-- vim.cmd('colorscheme rose-pine-dawn')
vim.cmd("colorscheme rose-pine")
-- vim.cmd("colorscheme rose-pine-main")
-- vim.cmd("colorscheme rose-pine-moon")
-- vim.cmd("colorscheme rose-pine-dawn")
```
> [!NOTE]
@ -125,6 +156,6 @@ vim.cmd('colorscheme rose-pine')
## Contributing
We welcome and appreciate contributions of any kind. Create an issue or start a discussion for any proposed changes. Pull requests are encouraged for supporting additional plugins.
We welcome and appreciate contributions of any kind. Create an issue or start a discussion for any proposed changes. Pull requests are encouraged for supporting additional plugins or [treesitter improvements](https://github.com/nvim-treesitter/nvim-treesitter/blob/master/CONTRIBUTING.md#highlights).
Feel free to update the [wiki](https://github.com/rose-pine/neovim/wiki/) with any [recipes](https://github.com/rose-pine/neovim/wiki/Recipes).