Compare commits

...

82 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
12 changed files with 649 additions and 179 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,7 +1,7 @@
local p = require("rose-pine.palette")
local config = require("rose-pine.config")
local bg_base = p.base
local bg_base = p.surface
if config.options.styles.transparency then
bg_base = "NONE"
end

View file

@ -91,7 +91,7 @@ local function set_highlights()
DiffAdd = { bg = groups.git_add, blend = 20 },
DiffChange = { bg = groups.git_change, blend = 20 },
DiffDelete = { bg = groups.git_delete, blend = 20 },
DiffText = { bg = groups.git_text, blend = 20 },
DiffText = { bg = groups.git_text, blend = 40 },
diffAdded = { link = "DiffAdd" },
diffChanged = { link = "DiffChange" },
diffRemoved = { link = "DiffDelete" },
@ -99,7 +99,7 @@ local function set_highlights()
-- EndOfBuffer = {},
ErrorMsg = { fg = groups.error, bold = styles.bold },
FloatBorder = make_border(),
FloatTitle = { link = "Directory" },
FloatTitle = { fg = palette.foam, bg = groups.panel, bold = styles.bold },
FoldColumn = { fg = palette.muted },
Folded = { fg = palette.text, bg = groups.panel },
IncSearch = { link = "CurSearch" },
@ -121,12 +121,12 @@ local function set_highlights()
PmenuSel = { fg = palette.text, bg = palette.overlay },
PmenuThumb = { bg = palette.muted },
Question = { fg = palette.gold },
-- QuickFixLink = {},
QuickFixLine = { fg = palette.foam },
-- RedrawDebugNormal = {},
RedrawDebugClear = { fg = palette.base, bg = palette.gold },
RedrawDebugComposed = { fg = palette.base, bg = palette.pine },
RedrawDebugRecompose = { fg = palette.base, bg = palette.love },
Search = { fg = palette.base, bg = palette.text },
Search = { fg = palette.text, bg = palette.gold, blend = 20 },
SignColumn = { fg = palette.text, bg = "NONE" },
SpecialKey = { fg = palette.foam },
SpellBad = { sp = palette.subtle, undercurl = true },
@ -143,7 +143,7 @@ local function set_highlights()
TabLineSel = { fg = palette.text, bg = palette.overlay, bold = styles.bold },
Title = { fg = palette.foam, bold = styles.bold },
VertSplit = { fg = groups.border },
Visual = { bg = palette.highlight_med },
Visual = { bg = palette.iris, blend = 15 },
-- VisualNOS = {},
WarningMsg = { fg = groups.warn, bold = styles.bold },
-- Whitespace = {},
@ -155,26 +155,32 @@ local function set_highlights()
DiagnosticError = { fg = groups.error },
DiagnosticHint = { fg = groups.hint },
DiagnosticInfo = { fg = groups.info },
DiagnosticOk = { fg = groups.ok },
DiagnosticWarn = { fg = groups.warn },
DiagnosticDefaultError = { link = "DiagnosticError" },
DiagnosticDefaultHint = { link = "DiagnosticHint" },
DiagnosticDefaultInfo = { link = "DiagnosticInfo" },
DiagnosticDefaultOk = { link = "DiagnosticOk" },
DiagnosticDefaultWarn = { link = "DiagnosticWarn" },
DiagnosticFloatingError = { link = "DiagnosticError" },
DiagnosticFloatingHint = { link = "DiagnosticHint" },
DiagnosticFloatingInfo = { link = "DiagnosticInfo" },
DiagnosticFloatingOk = { link = "DiagnosticOk" },
DiagnosticFloatingWarn = { link = "DiagnosticWarn" },
DiagnosticSignError = { link = "DiagnosticError" },
DiagnosticSignHint = { link = "DiagnosticHint" },
DiagnosticSignInfo = { link = "DiagnosticInfo" },
DiagnosticSignOk = { link = "DiagnosticOk" },
DiagnosticSignWarn = { link = "DiagnosticWarn" },
DiagnosticUnderlineError = { sp = groups.error, undercurl = true },
DiagnosticUnderlineHint = { sp = groups.hint, undercurl = true },
DiagnosticUnderlineInfo = { sp = groups.info, undercurl = true },
DiagnosticUnderlineOk = { sp = groups.ok, undercurl = true },
DiagnosticUnderlineWarn = { sp = groups.warn, undercurl = true },
DiagnosticVirtualTextError = { fg = groups.error, bg = groups.error, blend = 10 },
DiagnosticVirtualTextHint = { fg = groups.hint, bg = groups.hint, blend = 10 },
DiagnosticVirtualTextInfo = { fg = groups.info, bg = groups.info, blend = 10 },
DiagnosticVirtualTextOk = { fg = groups.ok, bg = groups.ok, blend = 10 },
DiagnosticVirtualTextWarn = { fg = groups.warn, bg = groups.warn, blend = 10 },
Boolean = { fg = palette.rose },
@ -202,8 +208,8 @@ local function set_highlights()
Macro = { fg = palette.iris },
Number = { fg = palette.gold },
Operator = { fg = palette.subtle },
PreConduit = { fg = palette.iris },
PreProc = { link = "PreConduit" },
PreCondit = { fg = palette.iris },
PreProc = { link = "PreCondit" },
Repeat = { fg = palette.pine },
Special = { fg = palette.foam },
SpecialChar = { link = "Special" },
@ -265,10 +271,12 @@ local function set_highlights()
mkdRule = { fg = palette.subtle },
mkdURL = { link = "markdownUrl" },
--- Identifiers
--- Treesitter
--- |:help treesitter-highlight-groups|
["@variable"] = { fg = palette.text, italic = styles.italic },
["@variable.builtin"] = { fg = palette.text, bold = styles.bold },
["@variable.builtin"] = { fg = palette.love, italic = styles.italic, bold = styles.bold },
["@variable.parameter"] = { fg = palette.iris, italic = styles.italic },
["@variable.parameter.builtin"] = { fg = palette.iris, italic = styles.italic, bold = styles.bold },
["@variable.member"] = { fg = palette.foam },
["@constant"] = { fg = palette.gold },
@ -279,7 +287,6 @@ local function set_highlights()
["@module.builtin"] = { fg = palette.text, bold = styles.bold },
["@label"] = { link = "Label" },
--- Literals
["@string"] = { link = "String" },
-- ["@string.documentation"] = {},
["@string.regexp"] = { fg = palette.iris },
@ -295,28 +302,27 @@ local function set_highlights()
["@boolean"] = { link = "Boolean" },
["@number"] = { link = "Number" },
["@number.float"] = { link = "Number" },
["@float"] = { link = "Number" },
--- Types
["@type"] = { fg = palette.foam },
["@type.builtin"] = { fg = palette.foam, bold = styles.bold },
-- ["@type.definition"] = {},
-- ["@type.qualifier"] = {},
-- ["@attribute"] = {},
["@attribute"] = { fg = palette.iris },
["@attribute.builtin"] = { fg = palette.iris, bold = styles.bold },
["@property"] = { fg = palette.foam, italic = styles.italic },
--- Functions
["@function"] = { fg = palette.rose },
["@function.builtin"] = { fg = palette.rose, bold = styles.bold },
-- ["@function.call"] = {},
["@function.macro"] = { link = "Function" },
["@function.method"] = { fg = palette.rose },
["@function.method.call"] = { fg = palette.iris },
["@constructor"] = { fg = palette.foam },
["@operator"] = { link = "Operator" },
--- Keywords
["@keyword"] = { link = "Keyword" },
-- ["@keyword.coroutine"] = {},
-- ["@keyword.function"] = {},
@ -327,8 +333,10 @@ local function set_highlights()
["@keyword.return"] = { fg = palette.pine },
["@keyword.debug"] = { fg = palette.rose },
["@keyword.exception"] = { fg = palette.pine },
["@keyword.conditional"] = { fg = palette.pine },
["@keyword.conditional.ternary"] = { fg = palette.pine },
["@keyword.directive"] = { fg = palette.iris },
["@keyword.directive.define"] = { fg = palette.iris },
@ -343,10 +351,10 @@ local function set_highlights()
["@comment.error"] = { fg = groups.error },
["@comment.warning"] = { fg = groups.warn },
["@comment.todo"] = { fg = groups.todo, bg = groups.todo, blend = 20 },
["@comment.hint"] = { fg = groups.hint, bg = groups.hint, blend = 20 },
["@comment.info"] = { fg = groups.info, bg = groups.info, blend = 20 },
["@comment.note"] = { fg = groups.note, bg = groups.note, blend = 20 },
["@comment.todo"] = { fg = groups.todo, bg = groups.todo, blend = 15 },
["@comment.hint"] = { fg = groups.hint, bg = groups.hint, blend = 15 },
["@comment.info"] = { fg = groups.info, bg = groups.info, blend = 15 },
["@comment.note"] = { fg = groups.note, bg = groups.note, blend = 15 },
--- Markup
["@markup.strong"] = { bold = styles.bold },
@ -356,22 +364,38 @@ local function set_highlights()
["@markup.heading"] = { fg = palette.foam, bold = styles.bold },
["@markup.quote"] = { fg = palette.subtle },
["@markup.quote"] = { fg = palette.text },
["@markup.math"] = { link = "Special" },
["@markup.environment"] = { link = "Macro" },
["@markup.environment.name"] = { link = "@type" },
-- ["@markup.link"] = {},
["@markup.link.label"] = { fg = palette.text },
["@markup.link.markdown_inline"] = { fg = palette.subtle },
["@markup.link.label.markdown_inline"] = { fg = palette.foam },
["@markup.link.url"] = { fg = groups.link },
-- ["@markup.raw"] = { bg = palette.surface },
-- ["@markup.raw.block"] = { bg = palette.surface },
["@markup.raw.delimiter.markdown"] = { fg = palette.subtle },
["@markup.list"] = { fg = palette.text },
["@markup.list"] = { fg = palette.pine },
["@markup.list.checked"] = { fg = palette.foam, bg = palette.foam, blend = 10 },
["@markup.list.unchecked"] = { fg = palette.text },
-- Markdown headings
["@markup.heading.1.markdown"] = { link = "markdownH1" },
["@markup.heading.2.markdown"] = { link = "markdownH2" },
["@markup.heading.3.markdown"] = { link = "markdownH3" },
["@markup.heading.4.markdown"] = { link = "markdownH4" },
["@markup.heading.5.markdown"] = { link = "markdownH5" },
["@markup.heading.6.markdown"] = { link = "markdownH6" },
["@markup.heading.1.marker.markdown"] = { link = "markdownH1Delimiter" },
["@markup.heading.2.marker.markdown"] = { link = "markdownH2Delimiter" },
["@markup.heading.3.marker.markdown"] = { link = "markdownH3Delimiter" },
["@markup.heading.4.marker.markdown"] = { link = "markdownH4Delimiter" },
["@markup.heading.5.marker.markdown"] = { link = "markdownH5Delimiter" },
["@markup.heading.6.marker.markdown"] = { link = "markdownH6Delimiter" },
["@diff.plus"] = { fg = groups.git_add, bg = groups.git_add, blend = 20 },
["@diff.minus"] = { fg = groups.git_delete, bg = groups.git_delete, blend = 20 },
["@diff.delta"] = { bg = groups.git_change, blend = 20 },
@ -383,22 +407,28 @@ local function set_highlights()
--- Non-highlighting captures
-- ["@none"] = {},
["@conceal"] = { link = "Conceal" },
["@conceal.markdown"] = { fg = palette.subtle },
-- ["@spell"] = {},
-- ["@nospell"] = {},
--- Semantic
["@lsp.type.comment"] = {},
["@lsp.type.comment.c"] = { link = "@comment" },
["@lsp.type.comment.cpp"] = { link = "@comment" },
["@lsp.type.enum"] = { link = "@type" },
["@lsp.type.interface"] = { link = "@interface" },
["@lsp.type.keyword"] = { link = "@keyword" },
["@lsp.type.namespace"] = { link = "@namespace" },
["@lsp.type.namespace.python"] = { link = "@variable" },
["@lsp.type.parameter"] = { link = "@parameter" },
["@lsp.type.property"] = { link = "@property" },
["@lsp.type.variable"] = {},
["@lsp.type.variable"] = {}, -- defer to treesitter for regular variables
["@lsp.type.variable.svelte"] = { link = "@variable" },
["@lsp.typemod.function.defaultLibrary"] = { link = "@function.builtin" },
["@lsp.typemod.operator.injected"] = { link = "@operator" },
["@lsp.typemod.string.injected"] = { link = "@string" },
["@lsp.typemod.variable.constant"] = { link = "@constant" },
["@lsp.typemod.variable.defaultLibrary"] = { link = "@variable.builtin" },
["@lsp.typemod.variable.injected"] = { link = "@variable" },
@ -422,9 +452,9 @@ local function set_highlights()
BufferVisibleTarget = { fg = palette.gold },
-- lewis6991/gitsigns.nvim
GitSignsAdd = { link = "SignAdd" },
GitSignsChange = { link = "SignChange" },
GitSignsDelete = { link = "SignDelete" },
GitSignsAdd = { fg = groups.git_add, bg = "NONE" },
GitSignsChange = { fg = groups.git_change, bg = "NONE" },
GitSignsDelete = { fg = groups.git_delete, bg = "NONE" },
SignAdd = { fg = groups.git_add, bg = "NONE" },
SignChange = { fg = groups.git_change, bg = "NONE" },
SignDelete = { fg = groups.git_delete, bg = "NONE" },
@ -432,7 +462,9 @@ local function set_highlights()
-- mvllow/modes.nvim
ModesCopy = { bg = palette.gold },
ModesDelete = { bg = palette.love },
ModesFormat = { bg = palette.rose },
ModesInsert = { bg = palette.foam },
ModesReplace = { bg = palette.pine },
ModesVisual = { bg = palette.iris },
-- kyazdani42/nvim-tree.lua
@ -460,6 +492,26 @@ local function set_highlights()
NvimTreeSpecialFile = { link = "NvimTreeNormal" },
NvimTreeWindowPicker = { link = "StatusLineTerm" },
-- nvim-neotest/neotest
NeotestAdapterName = { fg = palette.iris },
NeotestBorder = { fg = palette.highlight_med },
NeotestDir = { fg = palette.foam },
NeotestExpandMarker = { fg = palette.highlight_med },
NeotestFailed = { fg = palette.love },
NeotestFile = { fg = palette.text },
NeotestFocused = { fg = palette.gold, bg = palette.highlight_med },
NeotestIndent = { fg = palette.highlight_med },
NeotestMarked = { fg = palette.rose, bold = styles.bold },
NeotestNamespace = { fg = palette.gold },
NeotestPassed = { fg = palette.pine },
NeotestRunning = { fg = palette.gold },
NeotestWinSelect = { fg = palette.muted },
NeotestSkipped = { fg = palette.subtle },
NeotestTarget = { fg = palette.love },
NeotestTest = { fg = palette.gold },
NeotestUnknown = { fg = palette.subtle },
NeotestWatching = { fg = palette.iris },
-- nvim-neo-tree/neo-tree.nvim
NeoTreeGitAdded = { fg = groups.git_add },
NeoTreeGitConflict = { fg = groups.git_merge },
@ -468,6 +520,10 @@ local function set_highlights()
NeoTreeGitModified = { fg = groups.git_dirty },
NeoTreeGitRenamed = { fg = groups.git_rename },
NeoTreeGitUntracked = { fg = groups.git_untracked },
NeoTreeTabActive = { fg = palette.text, bg = palette.overlay },
NeoTreeTabInactive = { fg = palette.subtle },
NeoTreeTabSeparatorActive = { link = "WinSeparator" },
NeoTreeTabSeparatorInactive = { link = "WinSeparator" },
NeoTreeTitleBar = { link = "StatusLineTerm" },
-- folke/flash.nvim
@ -475,10 +531,23 @@ local function set_highlights()
-- folke/which-key.nvim
WhichKey = { fg = palette.iris },
WhichKeyBorder = make_border(),
WhichKeyDesc = { fg = palette.gold },
WhichKeyFloat = { bg = groups.panel },
WhichKeyGroup = { fg = palette.foam },
WhichKeyIcon = { fg = palette.pine },
WhichKeyIconAzure = { fg = palette.pine },
WhichKeyIconBlue = { fg = palette.pine },
WhichKeyIconCyan = { fg = palette.foam },
WhichKeyIconGreen = { fg = palette.leaf },
WhichKeyIconGrey = { fg = palette.subtle },
WhichKeyIconOrange = { fg = palette.rose },
WhichKeyIconPurple = { fg = palette.iris },
WhichKeyIconRed = { fg = palette.love },
WhichKeyIconYellow = { fg = palette.gold },
WhichKeyNormal = { link = "NormalFloat" },
WhichKeySeparator = { fg = palette.subtle },
WhichKeyTitle = { link = "FloatTitle" },
WhichKeyValue = { fg = palette.rose },
-- lukas-reineke/indent-blankline.nvim
@ -547,7 +616,7 @@ local function set_highlights()
-- tami5/lspsaga.nvim (fork of glepnir/lspsaga.nvim)
DefinitionCount = { fg = palette.rose },
DefinitionIcon = { fg = palette.rose },
DefintionPreviewTitle = { fg = palette.rose, bold = styles.bold },
DefinitionPreviewTitle = { fg = palette.rose, bold = styles.bold },
LspFloatWinBorder = make_border(),
LspFloatWinNormal = { bg = groups.panel },
LspSagaAutoPreview = { fg = palette.subtle },
@ -604,27 +673,35 @@ local function set_highlights()
TelescopeTitle = { fg = palette.foam, bold = styles.bold },
-- ibhagwan/fzf-lua
FzfLuaNormal = { link = "NormalFloat" },
FwzfLuaTitle = { fg = palette.foam, bold = styles.bold },
FzfLuaBorder = make_border(),
FzfLuaHeaderText = { fg = palette.love },
FzfLuaHeaderBind = { fg = palette.rose },
FzfLuaBufFlagCur = { fg = palette.subtle },
FzfLuaBufFlagAlt = { fg = palette.subtle },
FzfLuaBufFlagCur = { fg = palette.subtle },
FzfLuaCursorLine = { fg = palette.text, bg = palette.overlay },
FzfLuaFilePart = { fg = palette.text },
FzfLuaHeaderBind = { fg = palette.rose },
FzfLuaHeaderText = { fg = palette.love },
FzfLuaNormal = { link = "NormalFloat" },
FzfLuaTitle = { link = "FloatTitle" },
-- rcarriga/nvim-notify
NotifyBackground = { link = "NormalFloat" },
NotifyDEBUGBody = { link = "NormalFloat" },
NotifyDEBUGBorder = make_border(),
NotifyDEBUGIcon = { link = "NotifyDEBUGTitle" },
NotifyDEBUGTitle = { fg = palette.muted },
NotifyERRORBody = { link = "NormalFloat" },
NotifyERRORBorder = make_border(groups.error),
NotifyERRORIcon = { link = "NotifyERRORTitle" },
NotifyERRORTitle = { fg = groups.error },
NotifyINFOBody = { link = "NormalFloat" },
NotifyINFOBorder = make_border(groups.info),
NotifyINFOIcon = { link = "NotifyINFOTitle" },
NotifyINFOTitle = { fg = groups.info },
NotifyTRACEBody = { link = "NormalFloat" },
NotifyTRACEBorder = make_border(palette.iris),
NotifyTRACEIcon = { link = "NotifyTRACETitle" },
NotifyTRACETitle = { fg = palette.iris },
NotifyWARNBody = { link = "NormalFloat" },
NotifyWARNBorder = make_border(groups.warn),
NotifyWARNIcon = { link = "NotifyWARNTitle" },
NotifyWARNTitle = { fg = groups.warn },
@ -646,6 +723,7 @@ local function set_highlights()
DapUIThread = { fg = palette.gold },
DapUIValue = { fg = palette.text },
DapUIVariable = { fg = palette.text },
DapUIType = { fg = palette.iris },
DapUIWatchesEmpty = { fg = palette.love },
DapUIWatchesError = { link = "DapUIWatchesEmpty" },
DapUIWatchesValue = { link = "DapUIThread" },
@ -690,16 +768,143 @@ local function set_highlights()
-- folke/noice.nvim
NoiceCursor = { fg = palette.highlight_high, bg = palette.text },
-- echasnovski/mini.clue
-- folke/trouble.nvim
TroubleText = { fg = palette.subtle },
TroubleCount = { fg = palette.iris, bg = palette.surface },
TroubleNormal = { fg = palette.text, bg = groups.panel },
-- echasnovski/mini.nvim
MiniAnimateCursor = { reverse = true, nocombine = true },
MiniAnimateNormalFloat = { link = "NormalFloat" },
MiniClueBorder = { link = "FloatBorder" },
MiniClueDescGroup = { link = "DiagnosticFloatingWarn" },
MiniClueDescSingle = { link = "NormalFloat" },
MiniClueNextKey = { link = "DiagnosticFloatingHint" },
MiniClueNextKeyWithPostkeys = { link = "DiagnosticFloatingError" },
MiniClueSeparator = { link = "DiagnosticFloatingInfo" },
MiniClueTitle = { bg = groups.panel, bold = styles.bold },
-- echasnovski/mini.pick
MiniCompletionActiveParameter = { underline = true },
MiniCursorword = { underline = true },
MiniCursorwordCurrent = { underline = true },
MiniDepsChangeAdded = { fg = groups.git_add },
MiniDepsChangeRemoved = { fg = groups.git_delete },
MiniDepsHint = { link = "DiagnosticHint" },
MiniDepsInfo = { link = "DiagnosticInfo" },
MiniDepsMsgBreaking = { link = "DiagnosticWarn" },
MiniDepsPlaceholder = { link = "Comment" },
MiniDepsTitle = { link = "Title" },
MiniDepsTitleError = { link = "DiffDelete" },
MiniDepsTitleSame = { link = "DiffText" },
MiniDepsTitleUpdate = { link = "DiffAdd" },
MiniDiffOverAdd = { fg = groups.git_add, bg = groups.git_add, blend = 20 },
MiniDiffOverChange = { fg = groups.git_change, bg = groups.git_change, blend = 20 },
MiniDiffOverContext = { bg = palette.surface },
MiniDiffOverDelete = { fg = groups.git_delete, bg = groups.git_delete, blend = 20 },
MiniDiffSignAdd = { fg = groups.git_add },
MiniDiffSignChange = { fg = groups.git_change },
MiniDiffSignDelete = { fg = groups.git_delete },
MiniFilesBorder = { link = "FloatBorder" },
MiniFilesBorderModified = { link = "DiagnosticFloatingWarn" },
MiniFilesCursorLine = { link = "CursorLine" },
MiniFilesDirectory = { link = "Directory" },
MiniFilesFile = { fg = palette.text },
MiniFilesNormal = { link = "NormalFloat" },
MiniFilesTitle = { link = "FloatTitle" },
MiniFilesTitleFocused = { fg = palette.rose, bg = groups.panel, bold = styles.bold },
MiniHipatternsFixme = { fg = palette.base, bg = groups.error, bold = styles.bold },
MiniHipatternsHack = { fg = palette.base, bg = groups.warn, bold = styles.bold },
MiniHipatternsNote = { fg = palette.base, bg = groups.info, bold = styles.bold },
MiniHipatternsTodo = { fg = palette.base, bg = groups.hint, bold = styles.bold },
MiniIconsAzure = { fg = palette.foam },
MiniIconsBlue = { fg = palette.pine },
MiniIconsCyan = { fg = palette.foam },
MiniIconsGreen = { fg = palette.leaf },
MiniIconsGrey = { fg = palette.subtle },
MiniIconsOrange = { fg = palette.rose },
MiniIconsPurple = { fg = palette.iris },
MiniIconsRed = { fg = palette.love },
MiniIconsYellow = { fg = palette.gold },
MiniIndentscopeSymbol = { fg = palette.muted },
MiniIndentscopeSymbolOff = { fg = palette.gold },
MiniJump = { sp = palette.gold, undercurl = true },
MiniJump2dDim = { fg = palette.subtle },
MiniJump2dSpot = { fg = palette.gold, bold = styles.bold, nocombine = true },
MiniJump2dSpotAhead = { fg = palette.foam, bg = palette.surface, nocombine = true },
MiniJump2dSpotUnique = { fg = palette.rose, bold = styles.bold, nocombine = true },
MiniMapNormal = { link = "NormalFloat" },
MiniMapSymbolCount = { link = "Special" },
MiniMapSymbolLine = { link = "Title" },
MiniMapSymbolView = { link = "Delimiter" },
MiniNotifyBorder = { link = "FloatBorder" },
MiniNotifyNormal = { link = "NormalFloat" },
MiniNotifyTitle = { link = "FloatTitle" },
MiniOperatorsExchangeFrom = { link = "IncSearch" },
MiniPickBorder = { link = "FloatBorder" },
MiniPickBorderBusy = { link = "DiagnosticFloatingWarn" },
MiniPickBorderText = { bg = groups.panel },
MiniPickIconDirectory = { link = "Directory" },
MiniPickIconFile = { link = "MiniPickNormal" },
MiniPickHeader = { link = "DiagnosticFloatingHint" },
MiniPickMatchCurrent = { link = "CursorLine" },
MiniPickMatchMarked = { link = "Visual" },
MiniPickMatchRanges = { fg = palette.foam },
MiniPickNormal = { link = "NormalFloat" },
MiniPickPreviewLine = { link = "CursorLine" },
MiniPickPreviewRegion = { link = "IncSearch" },
MiniPickPrompt = { bg = groups.panel, bold = styles.bold },
-- echasnovski/mini.indentscope
MiniIndentscopeSymbol = { fg = palette.muted },
MiniIndentscopeSymbolOff = { fg = palette.muted },
MiniStarterCurrent = { nocombine = true },
MiniStarterFooter = { fg = palette.subtle },
MiniStarterHeader = { link = "Title" },
MiniStarterInactive = { link = "Comment" },
MiniStarterItem = { link = "Normal" },
MiniStarterItemBullet = { link = "Delimiter" },
MiniStarterItemPrefix = { link = "WarningMsg" },
MiniStarterSection = { fg = palette.rose },
MiniStarterQuery = { link = "MoreMsg" },
MiniStatuslineDevinfo = { fg = palette.subtle, bg = palette.overlay },
MiniStatuslineFileinfo = { link = "MiniStatuslineDevinfo" },
MiniStatuslineFilename = { fg = palette.muted, bg = palette.surface },
MiniStatuslineInactive = { link = "MiniStatuslineFilename" },
MiniStatuslineModeCommand = { fg = palette.base, bg = palette.love, bold = styles.bold },
MiniStatuslineModeInsert = { fg = palette.base, bg = palette.foam, bold = styles.bold },
MiniStatuslineModeNormal = { fg = palette.base, bg = palette.rose, bold = styles.bold },
MiniStatuslineModeOther = { fg = palette.base, bg = palette.rose, bold = styles.bold },
MiniStatuslineModeReplace = { fg = palette.base, bg = palette.pine, bold = styles.bold },
MiniStatuslineModeVisual = { fg = palette.base, bg = palette.iris, bold = styles.bold },
MiniSurround = { link = "IncSearch" },
MiniTablineCurrent = { fg = palette.text, bg = palette.overlay, bold = styles.bold },
MiniTablineFill = { link = "TabLineFill" },
MiniTablineHidden = { fg = palette.subtle, bg = groups.panel },
MiniTablineModifiedCurrent = { fg = palette.overlay, bg = palette.text, bold = styles.bold },
MiniTablineModifiedHidden = { fg = groups.panel, bg = palette.subtle },
MiniTablineModifiedVisible = { fg = groups.panel, bg = palette.text },
MiniTablineTabpagesection = { link = "Search" },
MiniTablineVisible = { fg = palette.text, bg = groups.panel },
MiniTestEmphasis = { bold = styles.bold },
MiniTestFail = { fg = palette.love, bold = styles.bold },
MiniTestPass = { fg = palette.foam, bold = styles.bold },
MiniTrailspace = { bg = palette.love },
-- goolord/alpha-nvim
AlphaButtons = { fg = palette.foam },
@ -709,14 +914,169 @@ local function set_highlights()
-- github/copilot.vim
CopilotSuggestion = { fg = palette.muted, italic = styles.italic },
-- nvim-treesitter/nvim-treesitter-context
TreesitterContext = { bg = palette.overlay },
TreesitterContextLineNumber = { fg = palette.rose, bg = palette.overlay },
-- RRethy/vim-illuminate
IlluminatedWordRead = { link = "LspReferenceRead" },
IlluminatedWordText = { link = "LspReferenceText" },
IlluminatedWordWrite = { link = "LspReferenceWrite" },
-- HiPhish/rainbow-delimiters.nvim
RainbowDelimiterBlue = { fg = palette.pine },
RainbowDelimiterCyan = { fg = palette.foam },
RainbowDelimiterGreen = { fg = palette.leaf },
RainbowDelimiterOrange = { fg = palette.rose },
RainbowDelimiterRed = { fg = palette.love },
RainbowDelimiterViolet = { fg = palette.iris },
RainbowDelimiterYellow = { fg = palette.gold },
-- MeanderingProgrammer/render-markdown.nvim
RenderMarkdownBullet = { fg = palette.rose },
RenderMarkdownChecked = { fg = palette.foam },
RenderMarkdownCode = { bg = palette.overlay },
RenderMarkdownCodeInline = { fg = palette.text, bg = palette.overlay },
RenderMarkdownDash = { fg = palette.muted },
RenderMarkdownH1Bg = { bg = groups.h1, blend = 20 },
RenderMarkdownH2Bg = { bg = groups.h2, blend = 20 },
RenderMarkdownH3Bg = { bg = groups.h3, blend = 20 },
RenderMarkdownH4Bg = { bg = groups.h4, blend = 20 },
RenderMarkdownH5Bg = { bg = groups.h5, blend = 20 },
RenderMarkdownH6Bg = { bg = groups.h6, blend = 20 },
RenderMarkdownQuote = { fg = palette.subtle },
RenderMarkdownTableFill = { link = "Conceal" },
RenderMarkdownTableHead = { fg = palette.subtle },
RenderMarkdownTableRow = { fg = palette.subtle },
RenderMarkdownUnchecked = { fg = palette.subtle },
-- MagicDuck/grug-far.nvim
GrugFarHelpHeader = { fg = palette.pine },
GrugFarHelpHeaderKey = { fg = palette.gold },
GrugFarHelpWinActionKey = { fg = palette.gold },
GrugFarHelpWinActionPrefix = { fg = palette.foam },
GrugFarHelpWinActionText = { fg = palette.pine },
GrugFarHelpWinHeader = { link = "FloatTitle" },
GrugFarInputLabel = { fg = palette.foam },
GrugFarInputPlaceholder = { link = "Comment" },
GrugFarResultsActionMessage = { fg = palette.foam },
GrugFarResultsChangeIndicator = { fg = groups.git_change },
GrugFarResultsRemoveIndicator = { fg = groups.git_delete },
GrugFarResultsAddIndicator = { fg = groups.git_add },
GrugFarResultsHeader = { fg = palette.pine },
GrugFarResultsLineNo = { fg = palette.iris },
GrugFarResultsLineColumn = { link = "GrugFarResultsLineNo" },
GrugFarResultsMatch = { link = "CurSearch" },
GrugFarResultsPath = { fg = palette.foam },
GrugFarResultsStats = { fg = palette.iris },
-- yetone/avante.nvim
AvanteTitle = { fg = palette.highlight_high, bg = palette.rose },
AvanteReversedTitle = { fg = palette.rose },
AvanteSubtitle = { fg = palette.highlight_med, bg = palette.foam },
AvanteReversedSubtitle = { fg = palette.foam },
AvanteThirdTitle = { fg = palette.highlight_med, bg = palette.iris },
AvanteReversedThirdTitle = { fg = palette.iris },
AvantePromptInput = { fg = palette.text, bg = groups.panel },
AvantePromptInputBorder = { fg = groups.border },
-- Saghen/blink.cmp
BlinkCmpDoc = { bg = palette.highlight_low },
BlinkCmpDocSeparator = { bg = palette.highlight_low },
BlinkCmpDocBorder = { fg = palette.highlight_high },
BlinkCmpGhostText = { fg = palette.muted },
BlinkCmpLabel = { fg = palette.muted },
BlinkCmpLabelDeprecated = { fg = palette.muted, strikethrough = true },
BlinkCmpLabelMatch = { fg = palette.text, bold = styles.bold },
BlinkCmpDefault = { fg = palette.highlight_med },
BlinkCmpKindText = { fg = palette.pine },
BlinkCmpKindMethod = { fg = palette.foam },
BlinkCmpKindFunction = { fg = palette.foam },
BlinkCmpKindConstructor = { fg = palette.foam },
BlinkCmpKindField = { fg = palette.pine },
BlinkCmpKindVariable = { fg = palette.rose },
BlinkCmpKindClass = { fg = palette.gold },
BlinkCmpKindInterface = { fg = palette.gold },
BlinkCmpKindModule = { fg = palette.foam },
BlinkCmpKindProperty = { fg = palette.foam },
BlinkCmpKindUnit = { fg = palette.pine },
BlinkCmpKindValue = { fg = palette.love },
BlinkCmpKindKeyword = { fg = palette.iris },
BlinkCmpKindSnippet = { fg = palette.rose },
BlinkCmpKindColor = { fg = palette.love },
BlinkCmpKindFile = { fg = palette.foam },
BlinkCmpKindReference = { fg = palette.love },
BlinkCmpKindFolder = { fg = palette.foam },
BlinkCmpKindEnum = { fg = palette.foam },
BlinkCmpKindEnumMember = { fg = palette.foam },
BlinkCmpKindConstant = { fg = palette.gold },
BlinkCmpKindStruct = { fg = palette.foam },
BlinkCmpKindEvent = { fg = palette.foam },
BlinkCmpKindOperator = { fg = palette.foam },
BlinkCmpKindTypeParameter = { fg = palette.iris },
BlinkCmpKindCodeium = { fg = palette.foam },
BlinkCmpKindCopilot = { fg = palette.foam },
BlinkCmpKindSupermaven = { fg = palette.foam },
BlinkCmpKindTabNine = { fg = palette.foam },
-- folke/snacks.nvim
SnacksIndent = { fg = palette.overlay },
SnacksIndentChunk = { fg = palette.overlay },
SnacksIndentBlank = { fg = palette.overlay },
SnacksIndentScope = { fg = palette.foam },
SnacksPickerMatch = { fg = palette.rose, bold = styles.bold },
-- justinmk/vim-sneak
Sneak = { fg = palette.base, bg = palette.love },
SneakCurrent = { link = "StatusLineTerm" },
SneakScope = { link = "IncSearch" },
-- sindrets/diffview.nvim
DiffviewPrimary = { fg = palette.pine },
DiffviewSecondary = { fg = palette.foam },
DiffviewNormal = { fg = palette.text, bg = palette.surface },
DiffviewWinSeparator = { fg = palette.text, bg = palette.surface },
DiffviewFilePanelTitle = { fg = palette.foam, bold = styles.bold },
DiffviewFilePanelCounter = { fg = palette.rose },
DiffviewFilePanelRootPath = { fg = palette.foam, bold = styles.bold },
DiffviewFilePanelFileName = { fg = palette.text },
DiffviewFilePanelSelected = { fg = palette.gold },
DiffviewFilePanelPath = { link = "Comment" },
DiffviewFilePanelInsertions = { fg = groups.git_add },
DiffviewFilePanelDeletions = { fg = groups.git_delete },
DiffviewFilePanelConflicts = { fg = groups.git_merge },
DiffviewFolderName = { fg = palette.foam, bold = styles.bold },
DiffviewFolderSign = { fg = palette.subtle },
DiffviewHash = { fg = palette.rose },
DiffviewReference = { fg = palette.foam, bold = styles.bold },
DiffviewReflogSelector = { fg = palette.rose },
DiffviewStatusAdded = { fg = groups.git_add },
DiffviewStatusUntracked = { fg = groups.untracked },
DiffviewStatusModified = { fg = groups.git_change },
DiffviewStatusRenamed = { fg = groups.git_rename },
DiffviewStatusCopied = { fg = groups.untracked },
DiffviewStatusTypeChange = { fg = groups.git_change },
DiffviewStatusUnmerged = { fg = groups.git_change },
DiffviewStatusUnknown = { fg = groups.git_delete },
DiffviewStatusDeleted = { fg = groups.git_delete },
DiffviewStatusBroken = { fg = groups.git_delete },
DiffviewStatusIgnored = { fg = groups.git_ignore },
}
local transparency_highlights = {
DiagnosticVirtualTextError = { fg = groups.error },
DiagnosticVirtualTextHint = { fg = groups.hint },
DiagnosticVirtualTextInfo = { fg = groups.info },
DiagnosticVirtualTextOk = { fg = groups.ok },
DiagnosticVirtualTextWarn = { fg = groups.warn },
FloatBorder = { fg = palette.muted, bg = "NONE" },
FloatTitle = { fg = palette.foam, bg = "NONE", bold = styles.bold },
Folded = { fg = palette.text, bg = "NONE" },
NormalFloat = { bg = "NONE" },
Normal = { fg = palette.text, bg = "NONE" },
@ -726,10 +1086,12 @@ local function set_highlights()
SignColumn = { fg = palette.text, bg = "NONE" },
StatusLine = { fg = palette.subtle, bg = "NONE" },
StatusLineNC = { fg = palette.muted, bg = "NONE" },
TabLine = { bg = "NONE", fg = palette.subtle },
TabLineFill = { bg = "NONE" },
TabLineSel = { fg = palette.text, bg = "NONE", bold = styles.bold },
-- ["@markup.raw"] = { bg = "none" },
["@markup.raw.markdown_inline"] = { fg = palette.gold },
-- ["@markup.raw.block"] = { bg = "none" },
TelescopeNormal = { fg = palette.subtle, bg = "NONE" },
@ -737,16 +1099,22 @@ local function set_highlights()
TelescopeSelection = { fg = palette.text, bg = "NONE", bold = styles.bold },
TelescopeSelectionCaret = { fg = palette.rose },
TroubleNormal = { bg = "NONE" },
WhichKeyFloat = { bg = "NONE" },
WhichKeyNormal = { bg = "NONE" },
IblIndent = { fg = palette.overlay, bg = "NONE" },
IblScope = { fg = palette.foam, bg = "NONE" },
IblWhitespace = { fg = palette.overlay, bg = "NONE" },
MiniClueTitle = { bg = "NONE", bold = styles.bold },
TreesitterContext = { bg = "NONE" },
TreesitterContextLineNumber = { fg = palette.rose, bg = "NONE" },
MiniFilesTitleFocused = { fg = palette.rose, bg = "NONE", bold = styles.bold },
MiniPickBorderText = { bg = "NONE" },
MiniPickPrompt = { bg = "NONE", bold = styles.bold },
MiniPickBorderText = { bg = "NONE" },
}
if config.options.enable.legacy_highlights then
@ -767,6 +1135,12 @@ local function set_highlights()
if config.options.highlight_groups ~= nil and next(config.options.highlight_groups) ~= nil then
for group, highlight in pairs(config.options.highlight_groups) do
local existing = highlights[group] or {}
-- Traverse link due to
-- "If link is used in combination with other attributes; only the link will take effect"
-- see: https://neovim.io/doc/user/api.html#nvim_set_hl()
while existing.link ~= nil do
existing = highlights[existing.link] or {}
end
local parsed = vim.tbl_extend("force", {}, highlight)
if highlight.fg ~= nil then
@ -780,10 +1154,10 @@ local function set_highlights()
end
if (highlight.inherit == nil or highlight.inherit) and existing ~= nil then
highlight.inherit = nil
parsed.inherit = nil
highlights[group] = vim.tbl_extend("force", existing, parsed)
else
highlight.inherit = nil
parsed.inherit = nil
highlights[group] = parsed
end
end
@ -793,9 +1167,18 @@ local function set_highlights()
if config.options.before_highlight ~= nil then
config.options.before_highlight(group, highlight, palette)
end
if highlight.blend ~= nil and (highlight.blend >= 0 and highlight.blend <= 100) and highlight.bg ~= nil then
highlight.bg = utilities.blend(highlight.bg, highlight.blend_on or palette.base, highlight.blend / 100)
end
highlight.blend = nil
highlight.blend_on = nil
if highlight._nvim_blend ~= nil then
highlight.blend = highlight._nvim_blend
end
vim.api.nvim_set_hl(0, group, highlight)
end
@ -820,9 +1203,13 @@ local function set_highlights()
-- Support StatusLineTerm & StatusLineTermNC from vim
vim.cmd([[
autocmd TermOpen * if &buftype=='terminal'
\|setlocal winhighlight=StatusLine:StatusLineTerm,StatusLineNC:StatusLineTermNC
\|else|setlocal winhighlight=|endif
augroup rose-pine
autocmd!
autocmd TermOpen * if &buftype=='terminal'
\|setlocal winhighlight=StatusLine:StatusLineTerm,StatusLineNC:StatusLineTermNC
\|else|setlocal winhighlight=|endif
autocmd ColorSchemePre * autocmd! rose-pine
augroup END
]])
end
end
@ -838,6 +1225,12 @@ function M.colorscheme(variant)
end
vim.g.colors_name = "rose-pine"
if variant == "dawn" then
vim.o.background = "light"
elseif variant == "main" or variant == "moon" then
vim.o.background = "dark"
end
set_highlights()
end

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, inherit: 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 = {}
@ -35,6 +35,9 @@ config.options = {
transparency = false,
},
---@type table<string, table<string, string>>
palette = {},
---@type table<string, string | PaletteColor>
groups = {
border = "muted",
@ -44,9 +47,10 @@ config.options = {
error = "love",
hint = "iris",
info = "foam",
ok = "leaf",
warn = "gold",
note = "pine",
todo = "rose",
warn = "gold",
git_add = "foam",
git_change = "rose",
@ -65,7 +69,7 @@ config.options = {
h3 = "rose",
h4 = "gold",
h5 = "pine",
h6 = "foam",
h6 = "leaf",
---@deprecated Replaced by `options.highlight_groups["Normal"]`
-- background = "base",
@ -133,24 +137,21 @@ local function migrate(options)
-- 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,
}
end
if type(options.groups.headings) == "table" then
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
@ -158,6 +159,7 @@ local function migrate(options)
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

@ -14,6 +14,7 @@ local variants = {
pine = "#31748f",
foam = "#9ccfd8",
iris = "#c4a7e7",
leaf = "#95b1ac",
highlight_low = "#21202e",
highlight_med = "#403d52",
highlight_high = "#524f67",
@ -33,6 +34,7 @@ local variants = {
pine = "#3e8fb0",
foam = "#9ccfd8",
iris = "#c4a7e7",
leaf = "#95b1ac",
highlight_low = "#2a283e",
highlight_med = "#44415a",
highlight_high = "#56526e",
@ -45,13 +47,14 @@ local variants = {
overlay = "#f2e9e1",
muted = "#9893a5",
subtle = "#797593",
text = "#575279",
text = "#464261",
love = "#b4637a",
gold = "#ea9d34",
rose = "#d7827e",
pine = "#286983",
foam = "#56949f",
iris = "#907aa9",
leaf = "#6d8f89",
highlight_low = "#f4ede8",
highlight_med = "#dfdad9",
highlight_high = "#cecacd",
@ -59,6 +62,15 @@ local variants = {
},
}
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
function utilities.parse_color(color)
if color_cache[color] then
return color_cache[color]
end
if color == nil then
return print("Invalid color: " .. color)
print("Invalid color: " .. color)
return nil
end
color = color:lower()
@ -26,13 +33,21 @@ function utilities.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)
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,7 +56,10 @@ function utilities.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))
local result = string.format("#%02X%02X%02X", blend_channel(1), blend_channel(2), blend_channel(3))
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,7 +66,7 @@ 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,
@ -59,10 +74,8 @@ require('rose-pine').setup({
enable = {
terminal = true,
-- Improve compatibility for previous versions of Neovim
legacy_highlights = true,
-- Handle deprecated options automatically
migrations = true,
legacy_highlights = true, -- Improve compatibility for previous versions of Neovim
migrations = true, -- Handle deprecated options automatically
},
styles = {
@ -102,9 +115,21 @@ require('rose-pine').setup({
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)
@ -120,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]