--[[ lvim is the global options object Linters should be filled in as strings with either a global executable or a path to an executable ]] -- THESE ARE EXAMPLE CONFIGS FEEL FREE TO CHANGE TO WHATEVER YOU WANT -- general lvim.log.level = "warn" lvim.format_on_save.enabled = false lvim.colorscheme = "lunar" lvim.transparent_window = true -- keymappings [view all the defaults by pressing Lk] lvim.leader = "," -- add your own keymapping -- map leader f and j to start and end of line lvim.builtin.which_key.mappings["j"] = {} lvim.keys.normal_mode["j"] = "$" lvim.keys.visual_mode["j"] = "$" lvim.builtin.which_key.mappings["f"] = {} lvim.keys.normal_mode["f"] = "0" lvim.keys.visual_mode["f"] = "0" -- map NvimTreeToggle lvim.keys.normal_mode[""] = ":NvimTreeToggle" -- lvim.keys.normal_mode[""] = ":BufferLineCycleNext" -- lvim.keys.normal_mode[""] = ":BufferLineCyclePrev" -- Change Telescope navigation to use j and k for navigation and n and p for history in both input and normal mode. -- we use protected-mode (pcall) just in case the plugin wasn't loaded yet. local _, actions = pcall(require, "telescope.actions") lvim.builtin.telescope.defaults.mappings = { -- for input mode i = { [""] = actions.move_selection_next, [""] = actions.move_selection_previous, [""] = actions.cycle_history_next, [""] = actions.cycle_history_prev, }, -- for normal mode n = { [""] = actions.move_selection_next, [""] = actions.move_selection_previous, }, } -- Use which-key to add extra bindings with the leader-key prefix lvim.builtin.which_key.mappings["P"] = { "Telescope projects", "Projects" } lvim.builtin.which_key.mappings["t"] = { name = "+Trouble", r = { "Trouble lsp_references", "References" }, f = { "Trouble lsp_definitions", "Definitions" }, d = { "Trouble document_diagnostics", "Diagnostics" }, q = { "Trouble quickfix", "QuickFix" }, l = { "Trouble loclist", "LocationList" }, w = { "Trouble workspace_diagnostics", "Workspace Diagnostics" }, } -- TODO: User Config for predefined plugins -- After changing plugin config exit and reopen LunarVim, Run :PackerInstall :PackerCompile lvim.builtin.alpha.active = true lvim.builtin.alpha.mode = "dashboard" lvim.builtin.terminal.active = true lvim.builtin.nvimtree.setup.view.side = "left" lvim.builtin.nvimtree.setup.renderer.icons.show.git = true -- if you don't want all the parsers change this to a table of the ones you want lvim.builtin.treesitter.ensure_installed = { "bash", "c", "javascript", "json", "lua", "python", "typescript", "tsx", "css", "rust", "java", "yaml", } lvim.builtin.treesitter.highlight.enable = true -- -- set a formatter, this will override the language server formatting capabilities (if it exists) local formatters = require "lvim.lsp.null-ls.formatters" formatters.setup { { command = "black", filetypes = { "python" } }, { command = "isort", filetypes = { "python" } }, { -- each formatter accepts a list of options identical to https://github.com/jose-elias-alvarez/null-ls.nvim/blob/main/doc/BUILTINS.md#Configuration command = "prettier", ---@usage arguments to pass to the formatter -- these cannot contain whitespaces, options such as `--line-width 80` become either `{'--line-width', '80'}` or `{'--line-width=80'}` extra_args = { "--print-with", "100" }, ---@usage specify which filetypes to enable. By default a providers will attach to all the filetypes it supports. filetypes = { "typescript", "typescriptreact" }, }, } -- -- set additional linters local linters = require "lvim.lsp.null-ls.linters" linters.setup { { command = "flake8", filetypes = { "python" } }, { -- each linter accepts a list of options identical to https://github.com/jose-elias-alvarez/null-ls.nvim/blob/main/doc/BUILTINS.md#Configuration command = "shellcheck", ---@usage arguments to pass to the formatter -- these cannot contain whitespaces, options such as `--line-width 80` become either `{'--line-width', '80'}` or `{'--line-width=80'}` extra_args = { "--severity", "warning" }, }, { command = "codespell", ---@usage specify which filetypes to enable. By default a providers will attach to all the filetypes it supports. filetypes = { "javascript", "python" }, }, } -- Additional Plugins lvim.plugins = { {"gosukiwi/vim-atom-dark"}, {"gregsexton/Atom"}, {"savq/melange"}, {"nvim-treesitter/playground",events="BufEnter"}, {"joshdick/onedark.vim"}, {"lunarvim/colorschemes"}, { "folke/trouble.nvim", cmd = "TroukleToggle", }, } -- Autocommands (https://neovim.io/doc/user/autocmd.html) vim.api.nvim_create_autocmd("BufEnter", { pattern = { "*.json", "*.jsonc" }, -- enable wrap mode for json files only command = "setlocal wrap", })