astronvim-user-config/plugins.lua

189 lines
7.7 KiB
Lua
Raw Normal View History

return {{
"mbbill/undotree",
name = "undotree",
lazy = false,
}, {
"lewis6991/satellite.nvim",
name = "satellite",
lazy = false,
config = function()
require("satellite").setup {
current_only = false,
winblend = 50,
zindex = 40,
excluded_filetypes = {},
width = 2,
handlers = {
cursor = {
enable = true,
overlap = true,
-- Supports any number of symbols
symbols = { '', '', '', '' }
-- symbols = { '⎻', '⎼' }
-- Highlights:
-- - SatelliteCursor (default links to NonText
},
search = {
enable = true,
-- Highlights:
-- - SatelliteSearch (default links to Search)
-- - SatelliteSearchCurrent (default links to SearchCurrent)
},
diagnostic = {
enable = true,
signs = {'-', '=', ''},
min_severity = vim.diagnostic.severity.HINT,
-- Highlights:
-- - SatelliteDiagnosticError (default links to DiaSatelliteEnablegnosticError)
-- - SatelliteDiagnosticWarn (default links to DiagnosticWarn)
-- - SatelliteDiagnosticInfo (default links to DiagnosticInfo)
-- - SatelliteDiagnosticHint (default links to DiagnosticHint)
},
gitsigns = {
enable = true,
signs = { -- can only be a single character (multibyte is okay)
add = "",
change = "",
delete = "-",
},
-- Highlights:
-- SatelliteGitSignsAdd (default links to GitSignsAdd)
-- SatelliteGitSignsChange (default links to GitSignsChange)
-- SatelliteGitSignsDelete (default links to GitSignsDelete)
},
marks = {
enable = true,
show_builtins = false, -- shows the builtin marks like [ ] < >
key = 'm'
-- Highlights:
-- SatelliteMark (default links to Normal)
},
quickfix = {
signs = { '-', '=', '' },
-- Highlights:
-- SatelliteQuickfix (default links to WarningMsg)
}
},
}
end,
}, {
2023-12-19 00:55:54 +00:00
"catppuccin/nvim",
name = "catppuccin",
config = function()
require("catppuccin").setup {
flavour = "mocha",
-- Colors adapted from https://github.com/one-dark/jetbrains-one-dark-theme
-- Catppuccin colors: https://github.com/catppuccin/catppuccin/blob/main/docs/style-guide.md
-- Catppuccin Neovim config: https://github.com/catppuccin/nvim/#configuration
color_overrides = {
mocha = {
text = "#BBBBBB",
base = "#282c34",
crust = "#21252b",
mauve = "#D55FDE",
blue = "#61AFEF",
teal = "#2BBAC5",
red = "#EF596F",
green = "#89CA78",
peach = "#D19A66",
yellow = "#E5C07B",
sapphire = "#009191",
maroon = "#f9c89a"
}
},
integrations = {
cmp = true,
neotree = true,
mason = true,
},
custom_highlights = function(C)
-- :Telescope highlights for a general list
-- Rust-analyzer tokens: https://rust-analyzer.github.io/manual.html#semantic-syntax-highlighting
-- @lsp.mod.* for modifiers
-- @lsp.modtype.* for types with modifiers
-- @lsp.type.* for token types
return {
Error = { fg = C.red, italic = true, underline = true },
["@lsp.type.interface"] = { fg = C.yellow },
["@function.builtin"] = { fg = C.blue },
["@lsp.typemod.method.builtIn"] = { fg = C.blue },
["@lsp.mod.mutable"] = { underline = true },
["@lsp.mod.consuming"] = { bold = true },
["@lsp.type.lifetime"] = { fg = C.teal },
["@variable.builtin"] = { fg = C.mauve },
["StorageClass"] = { fg = C.mauve },
["@constructor.lua"] = { fg = C.overlay2 },
["@preproc"] = { fg = C.maroon },
["@debug"] = { fg = C.maroon },
["@field"] = { fg = C.red },
["@property"] = { fg = C.red },
["@lsp.type.formatSpecifier"] = { fg = C.teal },
["@lsp.type.escapeSequence"] = { fg = C.teal },
PreProc = { fg = C.maroon },
Special = { fg = C.teal },
["@namespace"] = { fg = C.overlay2 },
["@define"] = { fg = C.maroon },
["@string.escape"] = { fg = C.teal },
Operator = { fg = C.text },
CmpItemKindSnippet = { fg = C.base, bg = C.green },
CmpItemKindKeyword = { fg = C.base, bg = C.mauve },
CmpItemKindText = { fg = C.base, bg = C.teal },
CmpItemKindMethod = { fg = C.base, bg = C.blue },
CmpItemKindConstructor = { fg = C.base, bg = C.blue },
CmpItemKindFunction = { fg = C.base, bg = C.blue },
CmpItemKindFolder = { fg = C.base, bg = C.blue },
CmpItemKindModule = { fg = C.base, bg = C.blue },
CmpItemKindConstant = { fg = C.base, bg = C.peach },
CmpItemKindField = { fg = C.base, bg = C.red },
CmpItemKindProperty = { fg = C.base, bg = C.red },
CmpItemKindEnum = { fg = C.base, bg = C.peach },
CmpItemKindUnit = { fg = C.base, bg = C.peach },
CmpItemKindClass = { fg = C.base, bg = C.yellow },
CmpItemKindVariable = { fg = C.base, bg = C.flamingo },
CmpItemKindFile = { fg = C.base, bg = C.blue },
CmpItemKindInterface = { fg = C.base, bg = C.yellow },
CmpItemKindColor = { fg = C.base, bg = C.red },
CmpItemKindReference = { fg = C.base, bg = C.red },
CmpItemKindEnumMember = { fg = C.base, bg = C.red },
CmpItemKindStruct = { fg = C.base, bg = C.blue },
CmpItemKindValue = { fg = C.base, bg = C.peach },
CmpItemKindEvent = { fg = C.base, bg = C.blue },
CmpItemKindOperator = { fg = C.base, bg = C.blue },
CmpItemKindTypeParameter = { fg = C.base, bg = C.blue },
CmpItemKindCopilot = { fg = C.base, bg = C.teal },
}
end,
2023-12-19 00:55:54 +00:00
}
end,
}, {
"hrsh7th/nvim-cmp",
-- override the options table that is used in the `require("cmp").setup()` call
opts = function(_, opts)
-- opts parameter is the default options table
-- the function is lazy loaded so cmp is able to be required
local lspkind = require("lspkind")
-- modify the sources part of the options table
-- Make the cmp prompt pretty
-- How to customize: https://docs.astronvim.com/recipes/cmp/
-- From: https://github.com/johnallen3d/dotfiles/blob/46300be412aba524743f8e3d47fff4df3deb2857/dot_config/nvim/lua/config/plugins/cmp.lua
opts.formatting = {
fields = { "kind", "abbr", "menu" },
format = function(entry, vim_item)
local kind = lspkind.cmp_format({
mode = "symbol_text",
maxwidth = 50,
})(entry, vim_item)
local strings = vim.split(kind.kind, "%s", { trimempty = true })
kind.kind = " " .. strings[1] .. " "
kind.menu = " (" .. strings[2] .. ")"
return kind
end,
}
-- return the new table to be used
return opts
end,
}}