From 8c7f4fbf378405bf2cc3333bc2563167eef412ea Mon Sep 17 00:00:00 2001 From: KRLH Date: Thu, 21 Aug 2025 11:18:50 -0500 Subject: [PATCH] initial commit --- .luarc.json | 3 + .neoconf.json | 20 +++++++ .stylua.toml | 7 +++ README.md | 34 +++++++++++ init.lua | 27 +++++++++ lua/community.lua | 27 +++++++++ lua/lazy_setup.lua | 32 +++++++++++ lua/plugins/astrocore.lua | 88 ++++++++++++++++++++++++++++ lua/plugins/astrolsp.lua | 106 ++++++++++++++++++++++++++++++++++ lua/plugins/astroui.lua | 39 +++++++++++++ lua/plugins/mason.lua | 29 ++++++++++ lua/plugins/mkdnflow.lua | 30 ++++++++++ lua/plugins/neovide.lua | 27 +++++++++ lua/plugins/none-ls.lua | 24 ++++++++ lua/plugins/telescope.lua | 39 +++++++++++++ lua/plugins/treesitter.lua | 15 +++++ lua/plugins/user.lua | 115 +++++++++++++++++++++++++++++++++++++ lua/plugins/zk-nvim.lua | 34 +++++++++++ lua/polish.lua | 5 ++ neovim.yml | 6 ++ selene.toml | 8 +++ 21 files changed, 715 insertions(+) create mode 100644 .luarc.json create mode 100644 .neoconf.json create mode 100644 .stylua.toml create mode 100644 README.md create mode 100644 init.lua create mode 100644 lua/community.lua create mode 100644 lua/lazy_setup.lua create mode 100644 lua/plugins/astrocore.lua create mode 100644 lua/plugins/astrolsp.lua create mode 100644 lua/plugins/astroui.lua create mode 100644 lua/plugins/mason.lua create mode 100644 lua/plugins/mkdnflow.lua create mode 100644 lua/plugins/neovide.lua create mode 100644 lua/plugins/none-ls.lua create mode 100644 lua/plugins/telescope.lua create mode 100644 lua/plugins/treesitter.lua create mode 100644 lua/plugins/user.lua create mode 100644 lua/plugins/zk-nvim.lua create mode 100644 lua/polish.lua create mode 100644 neovim.yml create mode 100644 selene.toml diff --git a/.luarc.json b/.luarc.json new file mode 100644 index 0000000..8415579 --- /dev/null +++ b/.luarc.json @@ -0,0 +1,3 @@ +{ + "format.enable": false +} diff --git a/.neoconf.json b/.neoconf.json new file mode 100644 index 0000000..2d7a81f --- /dev/null +++ b/.neoconf.json @@ -0,0 +1,20 @@ +{ + "neodev": { + "library": { + "enabled": true, + "plugins": true + } + }, + "neoconf": { + "plugins": { + "lua_ls": { + "enabled": true + } + } + }, + "lspconfig": { + "lua_ls": { + "Lua.format.enable": false + } + } +} diff --git a/.stylua.toml b/.stylua.toml new file mode 100644 index 0000000..bfcffff --- /dev/null +++ b/.stylua.toml @@ -0,0 +1,7 @@ +column_width = 120 +line_endings = "Unix" +indent_type = "Spaces" +indent_width = 2 +quote_style = "AutoPreferDouble" +call_parentheses = "None" +collapse_simple_statement = "Always" diff --git a/README.md b/README.md new file mode 100644 index 0000000..71d48de --- /dev/null +++ b/README.md @@ -0,0 +1,34 @@ +# AstroNvim Template + +**NOTE:** This is for AstroNvim v5+ + +A template for getting started with [AstroNvim](https://github.com/AstroNvim/AstroNvim) + +## ЁЯЫая╕П Installation + +#### Make a backup of your current nvim and shared folder + +```shell +mv ~/.config/nvim ~/.config/nvim.bak +mv ~/.local/share/nvim ~/.local/share/nvim.bak +mv ~/.local/state/nvim ~/.local/state/nvim.bak +mv ~/.cache/nvim ~/.cache/nvim.bak +``` + +#### Create a new user repository from this template + +Press the "Use this template" button above to create a new repository to store your user configuration. + +You can also just clone this repository directly if you do not want to track your user configuration in GitHub. + +#### Clone the repository + +```shell +git clone https://github.com// ~/.config/nvim +``` + +#### Start Neovim + +```shell +nvim +``` diff --git a/init.lua b/init.lua new file mode 100644 index 0000000..424e48d --- /dev/null +++ b/init.lua @@ -0,0 +1,27 @@ +-- This file simply bootstraps the installation of Lazy.nvim and then calls other files for execution +-- This file doesn't necessarily need to be touched, BE CAUTIOUS editing this file and proceed at your own risk. +local lazypath = vim.env.LAZY or vim.fn.stdpath "data" .. "/lazy/lazy.nvim" + +if not (vim.env.LAZY or (vim.uv or vim.loop).fs_stat(lazypath)) then + -- stylua: ignore + local result = vim.fn.system({ "git", "clone", "--filter=blob:none", "https://github.com/folke/lazy.nvim.git", "--branch=stable", lazypath }) + if vim.v.shell_error ~= 0 then + -- stylua: ignore + vim.api.nvim_echo({ { ("Error cloning lazy.nvim:\n%s\n"):format(result), "ErrorMsg" }, { "Press any key to exit...", "MoreMsg" } }, true, {}) + vim.fn.getchar() + vim.cmd.quit() + end +end + +vim.opt.rtp:prepend(lazypath) + +-- validate that lazy is available +if not pcall(require, "lazy") then + -- stylua: ignore + vim.api.nvim_echo({ { ("Unable to load lazy from: %s\n"):format(lazypath), "ErrorMsg" }, { "Press any key to exit...", "MoreMsg" } }, true, {}) + vim.fn.getchar() + vim.cmd.quit() +end + +require "lazy_setup" +require "polish" diff --git a/lua/community.lua b/lua/community.lua new file mode 100644 index 0000000..ace099d --- /dev/null +++ b/lua/community.lua @@ -0,0 +1,27 @@ +-- if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- AstroCommunity: import any community modules here +-- We import this file in `lazy_setup.lua` before the `plugins/` folder. +-- This guarantees that the specs are processed before any user plugins. + +---@type LazySpec +return { + "AstroNvim/astrocommunity", + { import = "astrocommunity.pack.lua" }, + -- import/override with your plugins folder + { import = "astrocommunity.colorscheme.tokyonight-nvim" }, + { import = "astrocommunity.colorscheme.tokyodark-nvim" }, + { import = "astrocommunity.colorscheme.catppuccin" }, + { import = "astrocommunity.colorscheme.catppuccin" }, + { import = "astrocommunity.colorscheme.kanagawa-nvim" }, + { import = "astrocommunity.colorscheme.kanagawa-paper-nvim" }, + { import = "astrocommunity.colorscheme.vim-moonfly-colors" }, + { import = "astrocommunity.colorscheme.vim-nightfly-colors" }, + + { import = "astrocommunity.fuzzy-finder.fzf-lua" }, + { import = "astrocommunity.markdown-and-latex.render-markdown-nvim" }, + + { import = "astrocommunity.pack.rust" }, + -- { import = "astrocommunity.note-taking.zk-nvim" }, + -- { import = "astrocommunity.workflow.precognition-nvim" }, +} diff --git a/lua/lazy_setup.lua b/lua/lazy_setup.lua new file mode 100644 index 0000000..4d9552f --- /dev/null +++ b/lua/lazy_setup.lua @@ -0,0 +1,32 @@ +require("lazy").setup({ + { + "AstroNvim/AstroNvim", + version = "^5", -- Remove version tracking to elect for nightly AstroNvim + import = "astronvim.plugins", + opts = { -- AstroNvim options must be set here with the `import` key + mapleader = " ", -- This ensures the leader key must be configured before Lazy is set up + maplocalleader = ",", -- This ensures the localleader key must be configured before Lazy is set up + icons_enabled = true, -- Set to false to disable icons (if no Nerd Font is available) + pin_plugins = nil, -- Default will pin plugins when tracking `version` of AstroNvim, set to true/false to override + update_notifications = true, -- Enable/disable notification about running `:Lazy update` twice to update pinned plugins + }, + }, + { import = "community" }, + { import = "plugins" }, +} --[[@as LazySpec]], { + -- Configure any other `lazy.nvim` configuration options here + install = { colorscheme = { "astrotheme", "habamax" } }, + ui = { backdrop = 100 }, + performance = { + rtp = { + -- disable some rtp plugins, add more to your liking + disabled_plugins = { + "gzip", + "netrwPlugin", + "tarPlugin", + "tohtml", + "zipPlugin", + }, + }, + }, +} --[[@as LazyConfig]]) diff --git a/lua/plugins/astrocore.lua b/lua/plugins/astrocore.lua new file mode 100644 index 0000000..729f4ac --- /dev/null +++ b/lua/plugins/astrocore.lua @@ -0,0 +1,88 @@ +if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- AstroCore provides a central place to modify mappings, vim options, autocommands, and more! +-- Configuration documentation can be found with `:h astrocore` +-- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`) +-- as this provides autocomplete and documentation while editing + +---@type LazySpec +return { + "AstroNvim/astrocore", + ---@type AstroCoreOpts + opts = { + -- Configure core features of AstroNvim + features = { + large_buf = { size = 1024 * 256, lines = 10000 }, -- set global limits for large files for disabling features like treesitter + autopairs = true, -- enable autopairs at start + cmp = true, -- enable completion at start + diagnostics = { virtual_text = true, virtual_lines = false }, -- diagnostic settings on startup + highlighturl = true, -- highlight URLs at start + notifications = true, -- enable notifications at start + }, + -- Diagnostics configuration (for vim.diagnostics.config({...})) when diagnostics are on + diagnostics = { + virtual_text = true, + underline = true, + }, + -- passed to `vim.filetype.add` + filetypes = { + -- see `:h vim.filetype.add` for usage + extension = { + foo = "fooscript", + }, + filename = { + [".foorc"] = "fooscript", + }, + pattern = { + [".*/etc/foo/.*"] = "fooscript", + }, + }, + -- vim options can be configured here + options = { + opt = { -- vim.opt. + relativenumber = true, -- sets vim.opt.relativenumber + number = true, -- sets vim.opt.number + spell = false, -- sets vim.opt.spell + signcolumn = "yes", -- sets vim.opt.signcolumn to yes + wrap = false, -- sets vim.opt.wrap + }, + g = { -- vim.g. + -- configure global vim variables (vim.g) + -- NOTE: `mapleader` and `maplocalleader` must be set in the AstroNvim opts or before `lazy.setup` + -- This can be found in the `lua/lazy_setup.lua` file + }, + }, + -- Mappings can be configured through AstroCore as well. + -- NOTE: keycodes follow the casing in the vimdocs. For example, `` must be capitalized + mappings = { + -- first key is the mode + n = { + -- second key is the lefthand side of the map + + ["L"] = { function() require("astrocore.buffer").nav(vim.v.count1) end, desc = "Next buffer" }, + ["H"] = { function() require("astrocore.buffer").nav(-vim.v.count1) end, desc = "Previous buffer" }, + + ["fe"] = { "ZkNotes", desc = "Find entries" }, + ["ft"] = { "ZkTags", desc = "Find tags" }, + ["zn"] = { "ZkNew", desc = "new entry" }, + + -- mappings seen under group name "Buffer" + ["bd"] = { + function() + require("astroui.status.heirline").buffer_picker( + function(bufnr) require("astrocore.buffer").close(bufnr) end + ) + end, + desc = "Close buffer from tabline", + }, + + -- tables with just a `desc` key will be registered with which-key if it's installed + -- this is useful for naming menus + -- ["b"] = { desc = "Buffers" }, + + -- setting a mapping to false will disable it + -- [""] = false, + }, + }, + }, +} diff --git a/lua/plugins/astrolsp.lua b/lua/plugins/astrolsp.lua new file mode 100644 index 0000000..2a605cb --- /dev/null +++ b/lua/plugins/astrolsp.lua @@ -0,0 +1,106 @@ +-- if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- AstroLSP allows you to customize the features in AstroNvim's LSP configuration engine +-- Configuration documentation can be found with `:h astrolsp` +-- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`) +-- as this provides autocomplete and documentation while editing + +---@type LazySpec +return { + "AstroNvim/astrolsp", + ---@type AstroLSPOpts + opts = { + -- Configuration table of features provided by AstroLSP + features = { + codelens = true, -- enable/disable codelens refresh on start + inlay_hints = false, -- enable/disable inlay hints on start + semantic_tokens = true, -- enable/disable semantic token highlighting + }, + -- customize lsp formatting options + 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 + -- disable lua_ls formatting capability if you want to use StyLua to format your lua code + -- "lua_ls", + }, + timeout_ms = 1000, -- default format timeout + -- filter = function(client) -- fully override the default formatting function + -- return true + -- end + }, + -- enable servers that you already have installed without mason + servers = { + -- "stylua", + -- "selene" + }, + -- customize language server configuration options passed to `lspconfig` + ---@diagnostic disable: missing-fields + config = { + -- clangd = { capabilities = { offsetEncoding = "utf-8" } }, + }, + -- customize how language servers are attached + handlers = { + -- a function without a key is simply the default handler, functions take two parameters, the server name and the configured options table for that server + -- function(server, opts) require("lspconfig")[server].setup(opts) end + + -- the key is the server that is being setup with `lspconfig` + -- rust_analyzer = false, -- setting a handler to false will disable the set up of that language server + -- pyright = function(_, opts) require("lspconfig").pyright.setup(opts) end -- or a custom handler function can be passed + }, + -- Configure buffer local auto commands to add when attaching a language server + autocmds = { + -- first key is the `augroup` to add the auto commands to (:h augroup) + lsp_codelens_refresh = { + -- Optional condition to create/delete auto command group + -- can either be a string of a client capability or a function of `fun(client, bufnr): boolean` + -- condition will be resolved for each client on each execution and if it ever fails for all clients, + -- the auto commands will be deleted for that buffer + cond = "textDocument/codeLens", + -- cond = function(client, bufnr) return client.name == "lua_ls" end, + -- list of auto commands to set + { + -- events to trigger + event = { "InsertLeave", "BufEnter" }, + -- the rest of the autocmd options (:h nvim_create_autocmd) + desc = "Refresh codelens (buffer)", + callback = function(args) + if require("astrolsp").config.features.codelens then vim.lsp.codelens.refresh { bufnr = args.buf } end + end, + }, + }, + }, + -- mappings to be set up on attaching of a language server + mappings = { + n = { + -- a `cond` key can provided as the string of a server capability to be required to attach, or a function with `client` and `bufnr` parameters from the `on_attach` that returns a boolean + gD = { + function() vim.lsp.buf.declaration() end, + desc = "Declaration of current symbol", + cond = "textDocument/declaration", + }, + ["uY"] = { + function() require("astrolsp.toggles").buffer_semantic_tokens() end, + desc = "Toggle LSP semantic highlight (buffer)", + cond = function(client) + return client.supports_method "textDocument/semanticTokens/full" and vim.lsp.semantic_tokens ~= nil + end, + }, + }, + }, + -- A custom `on_attach` function to be run after the default `on_attach` function + -- takes two parameters `client` and `bufnr` (`:h lspconfig-setup`) + on_attach = function(client, bufnr) + -- this would disable semanticTokensProvider for all clients + -- client.server_capabilities.semanticTokensProvider = nil + end, + }, +} diff --git a/lua/plugins/astroui.lua b/lua/plugins/astroui.lua new file mode 100644 index 0000000..eafe895 --- /dev/null +++ b/lua/plugins/astroui.lua @@ -0,0 +1,39 @@ +-- if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- AstroUI provides the basis for configuring the AstroNvim User Interface +-- Configuration documentation can be found with `:h astroui` +-- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`) +-- as this provides autocomplete and documentation while editing + +---@type LazySpec +return { + "AstroNvim/astroui", + ---@type AstroUIOpts + opts = { + -- change colorscheme + colorscheme = "kanagawa-paper-ink", + -- AstroUI allows you to easily modify highlight groups easily for any and all colorschemes + highlights = { + init = { -- this table overrides highlights in all themes + -- Normal = { bg = "#000000" }, + }, + astrodark = { -- a table of overrides/changes when applying the astrotheme theme + -- Normal = { bg = "#000000" }, + }, + }, + -- Icons can be configured throughout the interface + icons = { + -- configure the loading of the lsp in the status line + LSPLoading1 = "таЛ", + LSPLoading2 = "таЩ", + LSPLoading3 = "та╣", + LSPLoading4 = "та╕", + LSPLoading5 = "та╝", + LSPLoading6 = "та┤", + LSPLoading7 = "таж", + LSPLoading8 = "таз", + LSPLoading9 = "таЗ", + LSPLoading10 = "таП", + }, + }, +} diff --git a/lua/plugins/mason.lua b/lua/plugins/mason.lua new file mode 100644 index 0000000..fac205f --- /dev/null +++ b/lua/plugins/mason.lua @@ -0,0 +1,29 @@ + +-- Customize Mason + +---@type LazySpec +return { + -- use mason-tool-installer for automatically installing Mason packages + { + "WhoIsSethDaniel/mason-tool-installer.nvim", + -- overrides `require("mason-tool-installer").setup(...)` + opts = { + -- Make sure to use the names found in `:Mason` + ensure_installed = { + -- install language servers + -- "lua-language-server", + + -- install formatters + -- "stylua", + -- "black", + + -- install debuggers + -- "debugpy", + + -- install any other package + -- "tree-sitter-cli", + -- "rust-analyzer", + }, + }, + }, +} diff --git a/lua/plugins/mkdnflow.lua b/lua/plugins/mkdnflow.lua new file mode 100644 index 0000000..3c364c9 --- /dev/null +++ b/lua/plugins/mkdnflow.lua @@ -0,0 +1,30 @@ +return { +{'jakewvincent/mkdnflow.nvim', + name = 'mkdnflow', + lazy = false, + ext = 'md', + config = function() + require('mkdnflow').setup({ + mappings = { + MkdnEnter = {{'n', 'v'}, ''}, + MkdnNewListItem = {'i', ''}, + }, + links = { + name_is_source = true, + conceal = true, + style = "wiki", + }, + modules = { + yaml = true, + cmp = true, + tables = false, + }, + perspective = { + priority = 'first', + root_tell = '.zk' + } + -- Config goes here; leave blank for defaults + }) + end, + } +} diff --git a/lua/plugins/neovide.lua b/lua/plugins/neovide.lua new file mode 100644 index 0000000..c4a9d15 --- /dev/null +++ b/lua/plugins/neovide.lua @@ -0,0 +1,27 @@ +if not vim.g.neovide then + return {} -- do nothing if not in a Neovide session +end + +return { + "AstroNvim/astrocore", + ---@type AstroCoreOpts + opts = { + options = { + opt = { -- configure vim.opt options + -- configure font + guifont = "Fira Code:h11", + -- line spacing + linespace = 0, + }, + g = { -- configure vim.g variables + -- configure scaling + neovide_scale_factor = 1.0, + -- configure padding + neovide_padding_top = 0, + neovide_padding_bottom = -1, + neovide_padding_right = 0, + neovide_padding_left = 0, + }, + }, + }, +} diff --git a/lua/plugins/none-ls.lua b/lua/plugins/none-ls.lua new file mode 100644 index 0000000..2b0ed18 --- /dev/null +++ b/lua/plugins/none-ls.lua @@ -0,0 +1,24 @@ +if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- Customize None-ls sources + +---@type LazySpec +return { + "nvimtools/none-ls.nvim", + opts = function(_, opts) + -- opts 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/nvimtools/none-ls.nvim/tree/main/lua/null-ls/builtins/formatting + -- https://github.com/nvimtools/none-ls.nvim/tree/main/lua/null-ls/builtins/diagnostics + + -- Only insert new sources, do not replace the existing ones + -- (If you wish to replace, use `opts.sources = {}` instead of the `list_insert_unique` function) + opts.sources = require("astrocore").list_insert_unique(opts.sources, { + -- Set a formatter + -- null_ls.builtins.formatting.stylua, + -- null_ls.builtins.formatting.prettier, + }) + end, +} diff --git a/lua/plugins/telescope.lua b/lua/plugins/telescope.lua new file mode 100644 index 0000000..05b38ae --- /dev/null +++ b/lua/plugins/telescope.lua @@ -0,0 +1,39 @@ +if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +return { + "nvim-telescope/telescope.nvim", + dependencies = { + { "nvim-telescope/telescope-fzf-native.nvim", enabled = vim.fn.executable "make" == 1, build = "make" }, + }, + cmd = "Telescope", + opts = function() + local actions = require "telescope.actions" + local get_icon = require("astronvim.utils").get_icon + return { + defaults = { + git_worktrees = vim.g.git_worktrees, + prompt_prefix = get_icon("Selected", 1), + selection_caret = get_icon("Selected", 1), + path_display = { "truncate" }, + sorting_strategy = "ascending", + layout_config = { + horizontal = { prompt_position = "top", preview_width = 0.55 }, + vertical = { mirror = false }, + width = 0.87, + height = 0.80, + preview_cutoff = 120, + }, + mappings = { + i = { + [""] = actions.cycle_history_next, + [""] = actions.cycle_history_prev, + [""] = actions.move_selection_next, + [""] = actions.move_selection_previous, + }, + n = { q = actions.close }, + }, + }, + } + end, + config = require "plugins.configs.telescope", +} diff --git a/lua/plugins/treesitter.lua b/lua/plugins/treesitter.lua new file mode 100644 index 0000000..94436aa --- /dev/null +++ b/lua/plugins/treesitter.lua @@ -0,0 +1,15 @@ +if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- Customize Treesitter + +---@type LazySpec +return { + "nvim-treesitter/nvim-treesitter", + opts = { + ensure_installed = { + "lua", + "vim", + -- add more arguments for adding more treesitter parsers + }, + }, +} diff --git a/lua/plugins/user.lua b/lua/plugins/user.lua new file mode 100644 index 0000000..0b444b9 --- /dev/null +++ b/lua/plugins/user.lua @@ -0,0 +1,115 @@ +return { + ---@type LazySpec + { "aspeddro/pandoc.nvim", name = "pandoc", priority = 1000 }, + { "ellisonleao/glow.nvim", config = true, cmd = "Glow" }, + { "dfendr/clipboard-image.nvim", name = "clipboard-image", lazy = false }, + { "tpope/vim-repeat", name = "repeat", priority = 1000, lazy = false }, + { "tpope/vim-surround", name = "surround", priority = 1000, lazy = false }, + { "tricktux/pomodoro.vim", name = "pomo", cmd = "PomodoroStart" }, + { "DAmesberger/sc-im.nvim", name = "sc-im", lazy = false }, + { "williamboman/mason-lspconfig.nvim", lazy = false }, + { "neovim/nvim-lspconfig", lazy = false }, + { "robertbasic/vim-hugo-helper", cmd = "HugoHelperDateIsNow" }, + { "tikhomirov/vim-glsl", lazy = false }, + { "direnv/direnv.vim", lazy = false }, + { "elkowar/yuck.vim", lazy = false }, + + -- Add plugins, the lazy syntax + -- "andweeb/presence.nvim", + -- { + -- "ray-x/lsp_signature.nvim", + -- event = "BufRead", + -- config = function() + -- require("lsp_signature").setup() + -- end, + -- }, + + -- You can also add or configure plugins by creating files in this `plugins/` folder + -- PLEASE REMOVE THE EXAMPLES YOU HAVE NO INTEREST IN BEFORE ENABLING THIS FILE + -- Here are some examples: + + -- == Examples of Adding Plugins == + + "andweeb/presence.nvim", + { + "ray-x/lsp_signature.nvim", + event = "BufRead", + config = function() require("lsp_signature").setup() end, + }, + + -- == Examples of Overriding Plugins == + + -- customize dashboard options + { + "folke/snacks.nvim", + opts = { + dashboard = { + preset = { + header = table.concat({ + " ,c8888888:;. ", + " ;8888888888888c,. ", + " .888 `8888: ", + " .888' .'8888 , ", + " .8888' .d8 8888 88. ", + " .8888.^** oo; .888' ", + " `*88888,. *88' ..88888. ", + " ,xx.`*888888;. *^^.l8888888888: ", + " 888' Xx. `*88*^`d88888`` ,88c ", + " :88' 888 .xx88888**` '888. ", + " ^^^^'. 888 8888x' '^**;, .888: ", + " .8888X**.888 88' ;xx.. .8888' ", + " 888:'.xx 888 ,...... l88888888` ", + " .888 888 88888888,`8888' ", + " .888 .888 `````` ", + " ;88, ,88, ", + " :88, .888 ", + " :888.888. ", + " '88888. ", + " `'` ", + }, "\n"), + }, + }, + }, + }, + + -- 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 "astronvim.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 "astronvim.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, + }, +} diff --git a/lua/plugins/zk-nvim.lua b/lua/plugins/zk-nvim.lua new file mode 100644 index 0000000..0421b45 --- /dev/null +++ b/lua/plugins/zk-nvim.lua @@ -0,0 +1,34 @@ +return { + {'zk-org/zk-nvim', name = 'zk', lazy = false, + config = function () + require('zk').setup({ + picker = 'snacks_picker', + + lsp = { + config = { + cmd = { "zk", "lsp" }, + name = "zk", + }, + + auto_attach = { + enabled = true, + filetypes = { 'markdown' }, + } + } + }) + local zk = require("zk") + local commands = require("zk.commands") + + local function make_edit_fn(defaults, picker_options) + return function(options) + options = vim.tbl_extend("force", defaults, options or {}) + zk.edit(options, picker_options) + end + end + + commands.add("ZkOrphans", make_edit_fn({ orphan = true }, { title = "Zk Orphans" })) + commands.add("ZkRecents", make_edit_fn({ createdAfter = "2 weeks ago" }, { title = "Zk Recents" })) + + end, + } +} diff --git a/lua/polish.lua b/lua/polish.lua new file mode 100644 index 0000000..642719f --- /dev/null +++ b/lua/polish.lua @@ -0,0 +1,5 @@ +if true then return end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE + +-- This will run last in the setup process. +-- This is just pure lua so anything that doesn't +-- fit in the normal config locations above can go here diff --git a/neovim.yml b/neovim.yml new file mode 100644 index 0000000..b9235ab --- /dev/null +++ b/neovim.yml @@ -0,0 +1,6 @@ +--- +base: lua51 + +globals: + vim: + any: true diff --git a/selene.toml b/selene.toml new file mode 100644 index 0000000..e7005c3 --- /dev/null +++ b/selene.toml @@ -0,0 +1,8 @@ +std = "neovim" + +[rules] +global_usage = "allow" +if_same_then_else = "allow" +incorrect_standard_library_use = "allow" +mixed_table = "allow" +multiple_statements = "allow"