328 lines
11 KiB
Lua
328 lines
11 KiB
Lua
return {
|
|
-- ╭───────────────────────────────────────╮
|
|
-- │ bufferline - for mistakes and stuff.. │
|
|
-- ╰───────────────────────────────────────╯
|
|
{
|
|
"akinsho/bufferline.nvim",
|
|
dependencies = { "echasnovski/mini.icons" },
|
|
version = "*",
|
|
opts = {
|
|
options = {
|
|
diagnostics = "nvim_lsp",
|
|
diagnostics_update_on_event = true, -- use nvim's diagnostic handler
|
|
diagnostics_indicator = function(count, level)
|
|
local icon = level:match("error") and " " or " "
|
|
return " " .. icon .. count
|
|
end,
|
|
offsets = { { filetype = "neo-tree", text = "File Explorer", highlight = "Directory" } },
|
|
-- ─< style >───────────────────────────────────────────────────────────────────────────
|
|
indicator = {
|
|
icon = "▎", -- this should be omitted if indicator style is not 'icon'
|
|
style = "icon",
|
|
},
|
|
move_wraps_at_ends = true, -- whether or not the move command "wraps" at the first or last position
|
|
separator_style = "slope",
|
|
-- ─< icons >───────────────────────────────────────────────────────────────────────────
|
|
modified_icon = "",
|
|
left_trunc_marker = "",
|
|
right_trunc_marker = "",
|
|
themable = true, -- allows highlight groups to be overriden i.e. sets highlights as default
|
|
close_icon = "",
|
|
buffer_close_icon = "",
|
|
show_buffer_icons = true, -- disable filetype icons for buffers
|
|
show_buffer_close_icons = true,
|
|
show_close_icon = true,
|
|
show_tab_indicators = true,
|
|
hover = {
|
|
enabled = true,
|
|
delay = 80,
|
|
reveal = { "close" },
|
|
hide = { "nvim_lsp" },
|
|
},
|
|
-- You can set buffer_mode to "list" or "tabbed" based on your preference.
|
|
buffer_mode = "list",
|
|
color_icons = true, -- whether or not to add the filetype icon highlights
|
|
},
|
|
},
|
|
config = function(_, opts)
|
|
require("bufferline").setup(opts)
|
|
-- Remap the tab key for buffer navigation (you can adjust the keys as needed)
|
|
vim.keymap.set("n", "<Tab>", "<cmd>BufferLineCycleNext<CR>")
|
|
vim.keymap.set("n", "<S-Tab>", "<cmd>BufferLineCyclePrev<CR>")
|
|
end,
|
|
},
|
|
|
|
-- ╭───────────────────────────────────╮
|
|
-- │ cmdline - for nice command inputs │
|
|
-- ╰───────────────────────────────────╯
|
|
{
|
|
"VonHeikemen/fine-cmdline.nvim",
|
|
dependencies = {
|
|
{ "MunifTanjim/nui.nvim" },
|
|
},
|
|
config = function()
|
|
require("fine-cmdline").setup({
|
|
cmdline = {
|
|
enable_keymaps = true,
|
|
smart_history = true,
|
|
prompt = " ",
|
|
},
|
|
popup = {
|
|
position = {
|
|
row = "10%",
|
|
col = "50%",
|
|
},
|
|
size = {
|
|
width = "60%",
|
|
},
|
|
border = {
|
|
style = "rounded",
|
|
},
|
|
win_options = {
|
|
winhighlight = "Normal:Normal,FloatBorder:FloatBorder",
|
|
},
|
|
},
|
|
-- hooks = {
|
|
-- before_mount = function(input)
|
|
-- -- code
|
|
-- end,
|
|
-- after_mount = function(input)
|
|
-- -- code
|
|
-- end,
|
|
-- set_keymaps = function(imap, feedkeys)
|
|
-- -- code
|
|
-- end,
|
|
-- },
|
|
})
|
|
end,
|
|
vim.api.nvim_set_keymap("n", ":", "<cmd>FineCmdline<CR>", { noremap = true }),
|
|
vim.keymap.set("n", "T", "<cmd>FineCmdline<CR>"),
|
|
},
|
|
|
|
-- ╭───────────────────────────────────────╮
|
|
-- │ barbecue - for a nice breadcrump menu │
|
|
-- ╰───────────────────────────────────────╯
|
|
-- {
|
|
-- "utilyre/barbecue.nvim",
|
|
-- name = "barbecue",
|
|
-- version = "*",
|
|
-- dependencies = {
|
|
-- "SmiteshP/nvim-navic",
|
|
-- "echasnovski/mini.icons", -- optional dependency
|
|
-- },
|
|
-- opts = {
|
|
-- theme = {
|
|
-- -- this highlight is used to override other highlights
|
|
-- -- you can take advantage of its `bg` and set a background throughout your winbar
|
|
-- -- (e.g. basename will look like this: { fg = "#c0caf5", bold = true })
|
|
-- normal = { fg = "#c0caf5" },
|
|
--
|
|
-- -- these highlights correspond to symbols table from config
|
|
-- ellipsis = { fg = "#737aa2" },
|
|
-- separator = { fg = "#737aa2" },
|
|
-- modified = { fg = "#737aa2" },
|
|
--
|
|
-- -- these highlights represent the _text_ of three main parts of barbecue
|
|
-- dirname = { fg = "#737aa2" },
|
|
-- basename = { bold = true },
|
|
-- context = {},
|
|
--
|
|
-- -- these highlights are used for context/navic icons
|
|
-- context_file = { fg = "#ac8fe4" },
|
|
-- context_module = { fg = "#ac8fe4" },
|
|
-- context_namespace = { fg = "#ac8fe4" },
|
|
-- context_package = { fg = "#ac8fe4" },
|
|
-- context_class = { fg = "#ac8fe4" },
|
|
-- context_method = { fg = "#ac8fe4" },
|
|
-- context_property = { fg = "#ac8fe4" },
|
|
-- context_field = { fg = "#ac8fe4" },
|
|
-- context_constructor = { fg = "#ac8fe4" },
|
|
-- context_enum = { fg = "#ac8fe4" },
|
|
-- context_interface = { fg = "#ac8fe4" },
|
|
-- context_function = { fg = "#ac8fe4" },
|
|
-- context_variable = { fg = "#ac8fe4" },
|
|
-- context_constant = { fg = "#ac8fe4" },
|
|
-- context_string = { fg = "#ac8fe4" },
|
|
-- context_number = { fg = "#ac8fe4" },
|
|
-- context_boolean = { fg = "#ac8fe4" },
|
|
-- context_array = { fg = "#ac8fe4" },
|
|
-- context_object = { fg = "#ac8fe4" },
|
|
-- context_key = { fg = "#ac8fe4" },
|
|
-- context_null = { fg = "#ac8fe4" },
|
|
-- context_enum_member = { fg = "#ac8fe4" },
|
|
-- context_struct = { fg = "#ac8fe4" },
|
|
-- context_event = { fg = "#ac8fe4" },
|
|
-- context_operator = { fg = "#ac8fe4" },
|
|
-- context_type_parameter = { fg = "#ac8fe4" },
|
|
-- },
|
|
-- },
|
|
-- },
|
|
-- ╭─────────────────────────────────╮
|
|
-- │ indentlines - nice indent lines │
|
|
-- ╰─────────────────────────────────╯
|
|
{
|
|
"lukas-reineke/indent-blankline.nvim",
|
|
event = { "BufReadPre", "BufNewFile" },
|
|
main = "ibl",
|
|
opts = {
|
|
indent = {
|
|
char = "┊",
|
|
tab_char = "┊",
|
|
-- char = "│",
|
|
-- tab_char = "│",
|
|
},
|
|
},
|
|
},
|
|
|
|
-- ╭──────────────────╮
|
|
-- │ markdown plugins │
|
|
-- ╰──────────────────╯
|
|
{
|
|
"MeanderingProgrammer/render-markdown.nvim",
|
|
opts = {},
|
|
-- dependencies = { 'nvim-treesitter/nvim-treesitter', 'echasnovski/mini.nvim' }, -- if you use the mini.nvim suite
|
|
dependencies = { "nvim-treesitter/nvim-treesitter", "echasnovski/mini.icons" }, -- if you use standalone mini plugins
|
|
-- dependencies = { 'nvim-treesitter/nvim-treesitter', 'nvim-tree/nvim-web-devicons' }, -- if you prefer nvim-web-devicons
|
|
},
|
|
|
|
-- ╭────────────────────────────────────╮
|
|
-- │ notify for excellent notifications │
|
|
-- ╰────────────────────────────────────╯
|
|
-- {
|
|
-- "rcarriga/nvim-notify",
|
|
-- config = function()
|
|
-- require("notify").setup({
|
|
-- stages = "slide",
|
|
-- background_colour = "FloatShadow",
|
|
-- max_width = 120,
|
|
-- timeout = 2750,
|
|
-- render = "wrapped-compact",
|
|
-- -- Minimum/Maximum width for notification windows
|
|
-- minimum_width = 30,
|
|
-- maximum_width = 120,
|
|
--
|
|
-- -- Function called when a new window is opened, use for changing win settings/config
|
|
-- on_open = nil,
|
|
--
|
|
-- -- Function called when a window is closed
|
|
-- on_close = nil,
|
|
-- icons = {
|
|
-- ERROR = "", -- alternate symbol
|
|
-- WARN = "",
|
|
-- INFO = "",
|
|
-- DEBUG = "",
|
|
-- TRACE = "",
|
|
-- },
|
|
-- })
|
|
-- vim.notify = require("notify")
|
|
-- end,
|
|
-- },
|
|
|
|
-- ╭──────────────────────────────╮
|
|
-- │ slimline - nice bar for nvim │
|
|
-- ╰──────────────────────────────╯
|
|
{
|
|
-- Calls `require('slimline').setup({})`
|
|
"sschleemilch/slimline.nvim",
|
|
opts = {
|
|
bold = true, -- makes primary parts and mode bold
|
|
verbose_mode = false, -- Mode as single letter or as a word
|
|
style = "bg", -- or "fg". Whether highlights should be applied to bg or fg of components
|
|
mode_follow_style = true, -- Whether the mode color components should follow the style option
|
|
spaces = {
|
|
components = "─",
|
|
left = "─",
|
|
right = "─",
|
|
},
|
|
configs = {
|
|
path = {
|
|
hl = {
|
|
primary = "Define",
|
|
},
|
|
},
|
|
git = {
|
|
hl = {
|
|
primary = "Function",
|
|
},
|
|
},
|
|
diagnostics = {
|
|
hl = {
|
|
primary = "Statement",
|
|
},
|
|
},
|
|
filetype_lsp = {
|
|
hl = {
|
|
primary = "String",
|
|
},
|
|
},
|
|
},
|
|
components = { -- Choose components and their location
|
|
left = {
|
|
"mode",
|
|
"progress",
|
|
-- "path",
|
|
-- "git",
|
|
},
|
|
center = {
|
|
"path",
|
|
"git",
|
|
},
|
|
right = {
|
|
"diagnostics",
|
|
"filetype_lsp",
|
|
"progress",
|
|
},
|
|
},
|
|
sep = {
|
|
hide = {
|
|
first = false, -- hides the first separator
|
|
last = false, -- hides the last separator
|
|
},
|
|
left = "", -- left separator of components
|
|
right = "", -- right separator of components
|
|
},
|
|
hl = {
|
|
modes = {
|
|
normal = "Type", -- highlight base of modes
|
|
insert = "Function",
|
|
pending = "Boolean",
|
|
visual = "Keyword",
|
|
command = "String",
|
|
},
|
|
base = "Comment", -- highlight of everything in in between components
|
|
primary = "Normal", -- highlight of primary parts (e.g. filename)
|
|
secondary = "Comment", -- highlight of secondary parts (e.g. filepath)
|
|
},
|
|
icons = {
|
|
diagnostics = {
|
|
ERROR = " ",
|
|
WARN = " ",
|
|
HINT = " ",
|
|
INFO = " ",
|
|
},
|
|
git = {
|
|
branch = "",
|
|
},
|
|
folder = " ",
|
|
lines = " ",
|
|
},
|
|
},
|
|
},
|
|
|
|
-- ╭────────────────────────────────────────╮
|
|
-- │ which key - to know what to press next │
|
|
-- ╰────────────────────────────────────────╯
|
|
{
|
|
"folke/which-key.nvim",
|
|
event = "VeryLazy",
|
|
init = function()
|
|
vim.o.timeout = true
|
|
vim.o.timeoutlen = 350
|
|
end,
|
|
opts = {
|
|
-- your configuration comes here
|
|
-- or leave it empty to use the default settings
|
|
-- refer to the configuration section below
|
|
},
|
|
},
|
|
}
|