-- AstroNvim Configuration Table -- All configuration changes should go inside of the table below -- -- A split up user configuration example can be found at: https://github.com/AstroNvim/split_user_example -- -- You can think of a Lua "table" as a dictionary like data structure the -- normal format is "key = value". These also handle array like data structures -- where a value with no key simply has an implicit numeric key local config = { -- Configure AstroNvim updates updater = { remote = "origin", -- remote to use channel = "nightly", -- "stable" or "nightly" version = "latest", -- "latest", tag name, or regex search like "v1.*" to only do updates before v2 (STABLE ONLY) branch = "v3", -- branch name (NIGHTLY ONLY) commit = nil, -- commit hash (NIGHTLY ONLY) pin_plugins = nil, -- nil, true, false (nil will pin plugins on stable only) skip_prompts = false, -- skip prompts about breaking changes show_changelog = true, -- show the changelog after performing an update auto_quit = true, -- automatically quit the current session after a successful update -- remotes = { -- easily add new remotes to track -- ["remote_name"] = "https://remote_url.come/repo.git", -- full remote url -- ["remote2"] = "github_user/repo", -- GitHub user/repo shortcut, -- ["remote3"] = "github_user", -- GitHub user assume AstroNvim fork -- }, }, -- Set colorscheme to use colorscheme = "astrodark", -- Add highlight groups in any theme highlights = { -- init = { -- this table overrides highlights in all themes -- Normal = { bg = "#000000" }, -- } -- duskfox = { -- a table of overrides/changes to the duskfox theme -- Normal = { bg = "#000000" }, -- }, }, -- set vim options here (vim.. = value) options = { opt = { -- set to true or false etc. relativenumber = true, -- sets vim.opt.relativenumber number = true, -- sets vim.opt.number spell = false, -- sets vim.opt.spell signcolumn = "auto", -- sets vim.opt.signcolumn to auto wrap = true, -- sets vim.opt.wrap }, g = { mapleader = " ", -- sets vim.g.mapleader autoformat_enabled = true, -- enable or disable auto formatting at start (lsp.formatting.format_on_save must be enabled) cmp_enabled = true, -- enable completion at start autopairs_enabled = true, -- enable autopairs at start diagnostics_enabled = true, -- enable diagnostics at start status_diagnostics_enabled = true, -- enable diagnostics in statusline icons_enabled = true, -- disable icons in the UI (disable if no nerd font is available, requires :PackerSync after changing) ui_notifications_enabled = true, -- disable notifications when toggling UI elements }, }, -- If you need more control, you can use the function()...end notation -- options = function(local_vim) -- local_vim.opt.relativenumber = true -- local_vim.g.mapleader = " " -- local_vim.opt.whichwrap = vim.opt.whichwrap - { 'b', 's' } -- removing option from list -- local_vim.opt.shortmess = vim.opt.shortmess + { I = true } -- add to option list -- -- return local_vim -- end, -- Diagnostics configuration (for vim.diagnostics.config({...})) when diagnostics are on diagnostics = { virtual_text = true, underline = true, }, -- Extend LSP configuration lsp = { -- enable servers that you already have installed without mason servers = { -- "pyright" }, formatting = { -- control auto formatting on save format_on_save = { enabled = true, -- enable or disable format on save globally allow_filetypes = { -- enable format on save for specified filetypes only -- "go", }, ignore_filetypes = { -- disable format on save for specified filetypes -- "python", }, }, disabled = { -- disable formatting capabilities for the listed language servers -- "lua_ls", }, timeout_ms = 1000, -- default format timeout -- filter = function(client) -- fully override the default formatting function -- return true -- end }, -- easily add or disable built in mappings added during LSP attaching mappings = { n = { -- ["lf"] = false -- disable formatting keymap }, }, -- add to the global LSP on_attach function -- on_attach = function(client, bufnr) -- end, -- override the LSP setup handler function based on server name -- setup_handlers = { -- -- first function changes the default setup handler -- function(server, opts) require("lspconfig")[server].setup(opts) end, -- -- keys for a specific server name will be used for that LSP -- lua_ls = function(server, opts) -- -- custom lua_ls setup handler -- require("lspconfig")["lua_ls"].setup(opts) -- end, -- }, -- Add overrides for LSP server settings, the keys are the name of the server config = { -- example for addings schemas to yamlls yamlls = { -- override table for require("lspconfig").yamlls.setup({...}) settings = { yaml = { schemas = { ["http://json.schemastore.org/github-workflow"] = ".github/workflows/*.{yml,yaml}", ["http://json.schemastore.org/github-action"] = ".github/action.{yml,yaml}", ["http://json.schemastore.org/ansible-stable-2.9"] = "roles/tasks/*.{yml,yaml}", }, }, }, }, }, }, -- Mapping data with "desc" stored directly by vim.keymap.set(). -- -- Please use this mappings table to set keyboard mapping since this is the -- lower level configuration and more robust one. (which-key will -- automatically pick-up stored data by this setting.) mappings = { -- first key is the mode n = { -- second key is the lefthand side of the map -- mappings seen under group name "Buffer" ["bb"] = { "tabnew", desc = "New tab" }, ["bc"] = { "BufferLinePickClose", desc = "Pick to close" }, ["bj"] = { "BufferLinePick", desc = "Pick to jump" }, ["bt"] = { "BufferLineSortByTabs", desc = "Sort by tabs" }, -- tables with the `name` key will be registered with which-key if it's installed -- this is useful for naming menus ["b"] = { name = "Buffers" }, -- quick save -- [""] = { ":w!", desc = "Save File" }, -- change description but the same command }, t = { -- setting a mapping to false will disable it -- [""] = false, }, }, -- Configure require("lazy").setup() options lazy = { defaults = { lazy = true }, performance = { rtp = { -- customize default disabled vim plugins disabled_plugins = { "tohtml", "gzip", "matchit", "zipPlugin", "netrwPlugin", "tarPlugin", "matchparen" }, }, }, }, -- Configure plugins plugins = { -- You can disable default plugins as follows: -- { "max397574/better-escape.nvim", enabled = false }, -- -- You can also easily customize additional setup of plugins that is outside of the plugin's setup call -- { -- "L3MON4D3/LuaSnip", -- config = function(plugin, opts) -- require "plugins.configs.luasnip"(plugin, opts) -- include the default astronvim config that calls the setup call -- -- add more custom luasnip configuration such as filetype extend or custom snippets -- local luasnip = require "luasnip" -- luasnip.filetype_extend("javascript", { "javascriptreact" }) -- end, -- }, -- { -- "windwp/nvim-autopairs", -- config = function(plugin, opts) -- require "plugins.configs.nvim-autopairs"(plugin, opts) -- include the default astronvim config that calls the setup call -- -- add more custom autopairs configuration such as custom rules -- local npairs = require "nvim-autopairs" -- local Rule = require "nvim-autopairs.rule" -- local cond = require "nvim-autopairs.conds" -- npairs.add_rules( -- { -- Rule("$", "$", { "tex", "latex" }) -- -- don't add a pair if the next character is % -- :with_pair(cond.not_after_regex "%%") -- -- don't add a pair if the previous character is xxx -- :with_pair( -- cond.not_before_regex("xxx", 3) -- ) -- -- don't move right when repeat character -- :with_move(cond.none()) -- -- don't delete if the next character is xx -- :with_del(cond.not_after_regex "xx") -- -- disable adding a newline when you press -- :with_cr(cond.none()), -- }, -- -- disable for .vim files, but it work for another filetypes -- Rule("a", "a", "-vim") -- ) -- end, -- }, -- By adding to the which-key config and using our helper function you can add more which-key registered bindings -- { -- "folke/which-key.nvim", -- config = function(plugin, opts) -- require "plugins.configs.which-key"(plugin, opts) -- -- Add bindings which show up as group name -- local wk = require "which-key" -- wk.register({ -- b = { name = "Buffer" }, -- }, { mode = "n", prefix = "" }) -- end, -- }, -- You can also add new plugins here as well: -- Add plugins, the lazy syntax "andweeb/presence.nvim", -- { -- "ray-x/lsp_signature.nvim", -- event = "BufRead", -- config = function() -- require("lsp_signature").setup() -- end, -- }, -- Plugin entries can also be used to override the default options for plugins as well { "goolord/alpha-nvim", opts = function(_, opts) -- customize the dashboard header opts.section.header.val = { " █████ ███████ ████████ ██████ ██████", "██ ██ ██ ██ ██ ██ ██ ██", "███████ ███████ ██ ██████ ██ ██", "██ ██ ██ ██ ██ ██ ██ ██", "██ ██ ███████ ██ ██ ██ ██████", " ", " ███  ██ ██  ██ ██ ███  ███", " ████  ██ ██  ██ ██ ████  ████", " ██ ██  ██ ██  ██ ██ ██ ████ ██", " ██  ██ ██  ██  ██  ██ ██  ██  ██", " ██   ████   ████   ██ ██      ██", } return opts end, }, { "jose-elias-alvarez/null-ls.nvim", opts = function(_, config) -- config variable is the default configuration table for the setup function call local null_ls = require "null-ls" -- Check supported formatters and linters -- https://github.com/jose-elias-alvarez/null-ls.nvim/tree/main/lua/null-ls/builtins/formatting -- https://github.com/jose-elias-alvarez/null-ls.nvim/tree/main/lua/null-ls/builtins/diagnostics config.sources = { null_ls.builtins.code_actions.eslint, null_ls.builtins.code_actions.refactoring, null_ls.builtins.code_actions.shellcheck, null_ls.builtins.code_actions.xo, null_ls.builtins.diagnostics.actionlint, null_ls.builtins.diagnostics.alex, null_ls.builtins.diagnostics.ansiblelint, null_ls.builtins.diagnostics.dotenv_linter, null_ls.builtins.diagnostics.editorconfig_checker, null_ls.builtins.diagnostics.eslint, null_ls.builtins.diagnostics.flake8, null_ls.builtins.diagnostics.jsonlint, null_ls.builtins.diagnostics.luacheck, null_ls.builtins.diagnostics.markdownlint, null_ls.builtins.diagnostics.mypy, null_ls.builtins.diagnostics.php, null_ls.builtins.diagnostics.phpcs, null_ls.builtins.diagnostics.phpmd, null_ls.builtins.diagnostics.phpstan, null_ls.builtins.diagnostics.psalm, null_ls.builtins.diagnostics.pycodestyle, null_ls.builtins.diagnostics.pydocstyle, null_ls.builtins.diagnostics.pylint, null_ls.builtins.diagnostics.semgrep, null_ls.builtins.diagnostics.shellcheck, null_ls.builtins.diagnostics.standardjs, null_ls.builtins.diagnostics.stylelint, null_ls.builtins.diagnostics.tfsec, null_ls.builtins.diagnostics.trail_space, null_ls.builtins.diagnostics.tsc, null_ls.builtins.diagnostics.vacuum, null_ls.builtins.diagnostics.vint, null_ls.builtins.diagnostics.vulture, null_ls.builtins.diagnostics.xo, null_ls.builtins.diagnostics.yamllint, null_ls.builtins.diagnostics.zsh, null_ls.builtins.formatting.autoflake, null_ls.builtins.formatting.autopep8, null_ls.builtins.formatting.black, null_ls.builtins.formatting.blade_formatter, null_ls.builtins.formatting.cbfmt, null_ls.builtins.formatting.clang_format, null_ls.builtins.formatting.eslint, null_ls.builtins.formatting.fixjson, null_ls.builtins.formatting.isort, null_ls.builtins.formatting.isort, null_ls.builtins.formatting.jq, null_ls.builtins.formatting.markdownlint, null_ls.builtins.formatting.nginx_beautifier, null_ls.builtins.formatting.pg_format, null_ls.builtins.formatting.phpcsfixer, null_ls.builtins.formatting.prettier_eslint, null_ls.builtins.formatting.prettier, null_ls.builtins.formatting.prettier, null_ls.builtins.formatting.puppet_lint, null_ls.builtins.formatting.rome, null_ls.builtins.formatting.rustfmt, null_ls.builtins.formatting.shfmt.with { args = { "-i", "1", "-bn", "-ci", "-sr", "-kb", "-fn" } }, null_ls.builtins.formatting.stylelint } return config -- return final config table end, }, { "nvim-treesitter/nvim-treesitter", opts = { ensure_installed = { "help", "bash", "c", "cmake", "comment", "diff", "dockerfile", "gitignore", "graphql", "html", "javascript", "json", "json5", "latex", "lua", "markdown", "php", "phpdoc", "python", "scss", "sql", "terraform", "todotxt", "toml", "typescript", "vim", "vue", "yaml", }, }, }, -- use mason-lspconfig to configure LSP installations { "williamboman/mason-lspconfig.nvim", -- overrides `require("mason-lspconfig").setup(...)` opts = { ensure_installed = { "ansiblels", "bashls", "clangd", "codeqlls", "cssls", "diagnosticls", "docker_compose_language_service", "dockerls", "emmet_ls", "eslint", "graphql", "html", "intelephense", "jsonls", "lua_ls", "marksman", "phpactor", "psalm", "pyright", "stylelint_lsp", "sqls", "tailwindcss", "tsserver", "vuels", "yamlls" }, }, }, -- use mason-null-ls to configure Formatters/Linter installation for null-ls sources { "jay-babu/mason-null-ls.nvim", -- overrides `require("mason-null-ls").setup(...)` opts = { automatic_setup = true, -- ensure_installed = { "prettier", "stylua" }, }, }, { "jay-babu/mason-nvim-dap.nvim", -- overrides `require("mason-nvim-dap").setup(...)` opts = { -- ensure_installed = { "python" }, }, }, { "wakatime/vim-wakatime" }, }, -- Customize Heirline options heirline = { -- -- Customize different separators between sections -- separators = { -- breadcrumbs = " > ", -- tab = { "", "" }, -- }, -- -- Customize colors for each element each element has a `_fg` and a `_bg` -- colors = function(colors) -- colors.git_branch_fg = require("core.utils").get_hlgroup "Conditional" -- return colors -- end, -- -- Customize attributes of highlighting in Heirline components -- attributes = { -- -- styling choices for each heirline element, check possible attributes with `:h attr-list` -- git_branch = { bold = true }, -- bold the git branch statusline component -- }, -- -- Customize if icons should be highlighted -- icon_highlights = { -- breadcrumbs = false, -- LSP symbols in the breadcrumbs -- file_icon = { -- winbar = false, -- Filetype icon in the winbar inactive windows -- statusline = true, -- Filetype icon in the statusline -- tabline = true, -- Filetype icon in the tabline -- }, -- }, }, -- This function is run last and is a good place to configuring -- augroups/autocommands and custom filetypes also this just pure lua so -- anything that doesn't fit in the normal config locations above can go here polish = function() -- Set up custom filetypes -- vim.filetype.add { -- extension = { -- foo = "fooscript", -- }, -- filename = { -- ["Foofile"] = "fooscript", -- }, -- pattern = { -- ["~/%.config/foo/.*"] = "fooscript", -- }, -- } end, } return config