diff --git a/README.md b/README.md
index 8c20ae37..fd8deed0 100644
--- a/README.md
+++ b/README.md
@@ -1,9 +1,6 @@
> [!WARNING]
> This plugin is _beta_ quality. Expect breaking changes and many bugs
-> [!NOTE]
-> The configuration was recently reworked, please read the [configuration section](#configuration) for the new schema
-
> [!NOTE]
> If you're on a release tag, ensure you're viewing the README for [the latest release](https://github.com/Saghen/blink.cmp/tree/v0.8.0)
@@ -18,982 +15,17 @@
- Works out of the box with no additional configuration
- Updates on every keystroke (0.5-4ms async, single core)
- [Typo resistant fuzzy](https://github.com/saghen/frizbee) with frecency and proximity bonus
-- Extensive LSP support ([tracker](./LSP_TRACKER.md))
+- Extensive LSP support ([tracker](./docs/development/lsp-tracker.md))
- Native `vim.snippet` support (including `friendly-snippets`)
-- External sources support ([compatibility layer for `nvim-cmp` sources](https://github.com/Saghen/blink.compat))
+- External sources support ([compatibility layer for `nvim-cmp` sources](https://github.com/saghen/blink.compat))
- Auto-bracket support based on semantic tokens
- Signature help (experimental, opt-in)
- Command line completion
- [Comparison with nvim-cmp](#compared-to-nvim-cmp)
-## Requirements
-
-- Neovim 0.10+
-- curl
-- git
-
-## Installation
-
-`lazy.nvim`
-
-```lua
-{
- 'saghen/blink.cmp',
- -- optional: provides snippets for the snippet source
- dependencies = 'rafamadriz/friendly-snippets',
-
- -- use a release tag to download pre-built binaries
- version = 'v0.*',
- -- AND/OR build from source, requires nightly: https://rust-lang.github.io/rustup/concepts/channels.html#working-with-nightly-rust
- -- build = 'cargo build --release',
- -- If you use nix, you can build from source using latest nightly rust with:
- -- build = 'nix run .#build-plugin',
-
- ---@module 'blink.cmp'
- ---@type blink.cmp.Config
- opts = {
- -- 'default' for mappings similar to built-in completion
- -- 'super-tab' for mappings similar to vscode (tab to accept, arrow keys to navigate)
- -- 'enter' for mappings similar to 'super-tab' but with 'enter' to accept
- -- see the "default configuration" section below for full documentation on how to define
- -- your own keymap.
- keymap = { preset = 'default' },
-
- appearance = {
- -- Sets the fallback highlight groups to nvim-cmp's highlight groups
- -- Useful for when your theme doesn't support blink.cmp
- -- will be removed in a future release
- use_nvim_cmp_as_default = true,
- -- Set to 'mono' for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
- -- Adjusts spacing to ensure icons are aligned
- nerd_font_variant = 'mono'
- },
-
- -- default list of enabled providers defined so that you can extend it
- -- elsewhere in your config, without redefining it, due to `opts_extend`
- sources = {
- default = { 'lsp', 'path', 'snippets', 'buffer' },
- -- optionally disable cmdline completions
- -- cmdline = {},
- },
-
- -- experimental signature help support
- -- signature = { enabled = true }
- },
- -- allows extending the providers array elsewhere in your config
- -- without having to redefine it
- opts_extend = { "sources.default" }
-},
-```
-
-Setting capabilities for `nvim-lspconfig`:
-
-```lua
--- LSP servers and clients communicate which features they support through "capabilities".
--- By default, Neovim supports a subset of the LSP specification.
--- With blink.cmp, Neovim has *more* capabilities which are communicated to the LSP servers.
--- Explanation from TJ: https://youtu.be/m8C0Cq9Uv9o?t=1275
---
--- This can vary by config, but in general for nvim-lspconfig:
-
-{
- 'neovim/nvim-lspconfig',
- dependencies = { 'saghen/blink.cmp' },
-
- -- example using `opts` for defining servers
- opts = {
- servers = {
- lua_ls = {}
- }
- },
- config = function(_, opts)
- local lspconfig = require('lspconfig')
- for server, config in pairs(opts.servers) do
- -- passing config.capabilities to blink.cmp merges with the capabilities in your
- -- `opts[server].capabilities, if you've defined it
- config.capabilities = require('blink.cmp').get_lsp_capabilities(config.capabilities)
- lspconfig[server].setup(config)
- end
- end
-
- -- example calling setup directly for each LSP
- config = function()
- local capabilities = require('blink.cmp').get_lsp_capabilities()
- local lspconfig = require('lspconfig')
-
- lspconfig['lua-ls'].setup({ capabilities = capabilities })
- end
-}
-```
-
-
-mini.deps
-
-```lua
--- use a release tag to download pre-built binaries
-MiniDeps.add({
- source = "saghen/blink.cmp",
- depends = {
- "rafamadriz/friendly-snippets",
- },
- checkout = "some.version", -- check releases for latest tag
-})
-
--- OR build from source, requires nightly: https://rust-lang.github.io/rustup/concepts/channels.html#working-with-nightly-rust
-local function build_blink(params)
- vim.notify('Building blink.cmp', vim.log.levels.INFO)
- local obj = vim.system({ 'cargo', 'build', '--release' }, { cwd = params.path }):wait()
- if obj.code == 0 then
- vim.notify('Building blink.cmp done', vim.log.levels.INFO)
- else
- vim.notify('Building blink.cmp failed', vim.log.levels.ERROR)
- end
-end
-
-MiniDeps.add({
- source = 'Saghen/blink.cmp',
- hooks = {
- post_install = build_blink,
- post_checkout = build_blink,
- },
-})
-```
-
-
-
-## Configuration
-
-
-Default configuration
-
-
-
-```lua
-{
- -- When specifying 'preset' in the keymap table, the custom key mappings are merged with the preset,
- -- and any conflicting keys will overwrite the preset mappings.
- -- The "fallback" command will run the next non blink keymap.
- --
- -- Example:
- --
- -- keymap = {
- -- preset = 'default',
- -- [''] = { 'select_prev', 'fallback' },
- -- [''] = { 'select_next', 'fallback' },
- --
- -- -- disable a keymap from the preset
- -- [''] = {},
- --
- -- -- show with a list of providers
- -- [''] = { function(cmp) cmp.show({ providers = { 'snippets' } }) end },
- --
- -- -- note that your function will often be run in a "fast event" where most vim.api functions will throw an error
- -- -- you may want to wrap your function in `vim.schedule` or use `vim.schedule_wrap`
- -- [''] = { function(cmp) vim.schedule(function() your_behavior end) },
- --
- -- -- optionally, define different keymaps for cmdline
- -- cmdline = {
- -- preset = 'super-tab'
- -- }
- -- }
- --
- -- When defining your own keymaps without a preset, no keybinds will be assigned automatically.
- --
- -- Available commands:
- -- show, hide, cancel, accept, select_and_accept, select_prev, select_next, show_documentation, hide_documentation,
- -- scroll_documentation_up, scroll_documentation_down, snippet_forward, snippet_backward, fallback
- --
- -- "default" keymap
- -- [''] = { 'show', 'show_documentation', 'hide_documentation' },
- -- [''] = { 'hide' },
- -- [''] = { 'select_and_accept' },
- --
- -- [''] = { 'select_prev', 'fallback' },
- -- [''] = { 'select_next', 'fallback' },
- --
- -- [''] = { 'scroll_documentation_up', 'fallback' },
- -- [''] = { 'scroll_documentation_down', 'fallback' },
- --
- -- [''] = { 'snippet_forward', 'fallback' },
- -- [''] = { 'snippet_backward', 'fallback' },
- --
- -- "super-tab" keymap
- -- you may want to set `completion.trigger.show_in_snippet = false`
- -- or use `completion.list.selection = "manual" | "auto_insert"`
- --
- -- [''] = { 'show', 'show_documentation', 'hide_documentation' },
- -- [''] = { 'hide', 'fallback' },
- --
- -- [''] = {
- -- function(cmp)
- -- if cmp.snippet_active() then return cmp.accept()
- -- else return cmp.select_and_accept() end
- -- end,
- -- 'snippet_forward',
- -- 'fallback'
- -- },
- -- [''] = { 'snippet_backward', 'fallback' },
- --
- -- [''] = { 'select_prev', 'fallback' },
- -- [''] = { 'select_next', 'fallback' },
- -- [''] = { 'select_prev', 'fallback' },
- -- [''] = { 'select_next', 'fallback' },
- --
- -- [''] = { 'scroll_documentation_up', 'fallback' },
- -- [''] = { 'scroll_documentation_down', 'fallback' },
- --
- -- "enter" keymap
- -- you may want to set `completion.list.selection = "manual" | "auto_insert"`
- --
- -- [''] = { 'show', 'show_documentation', 'hide_documentation' },
- -- [''] = { 'hide', 'fallback' },
- -- [''] = { 'accept', 'fallback' },
- --
- -- [''] = { 'snippet_forward', 'fallback' },
- -- [''] = { 'snippet_backward', 'fallback' },
- --
- -- [''] = { 'select_prev', 'fallback' },
- -- [''] = { 'select_next', 'fallback' },
- -- [''] = { 'select_prev', 'fallback' },
- -- [''] = { 'select_next', 'fallback' },
- --
- -- [''] = { 'scroll_documentation_up', 'fallback' },
- -- [''] = { 'scroll_documentation_down', 'fallback' },
- keymap = { preset = 'default' },
-
- -- Enables keymaps, completions and signature help when true
- enabled = function() return vim.bo.buftype ~= "prompt" and vim.b.completion ~= false end,
- -- Example for blocking multiple filetypes
- -- enabled = function()
- -- return not vim.tbl_contains({ "lua", "markdown" }, vim.bo.filetype)
- -- and vim.bo.buftype ~= "prompt"
- -- and vim.b.completion ~= false
- -- end,
-
- snippets = {
- -- Function to use when expanding LSP provided snippets
- expand = function(snippet) vim.snippet.expand(snippet) end,
- -- Function to use when checking if a snippet is active
- active = function(filter) return vim.snippet.active(filter) end,
- -- Function to use when jumping between tab stops in a snippet, where direction can be negative or positive
- jump = function(direction) vim.snippet.jump(direction) end,
- },
-
- completion = {
- keyword = {
- -- 'prefix' will fuzzy match on the text before the cursor
- -- 'full' will fuzzy match on the text before *and* after the cursor
- -- example: 'foo_|_bar' will match 'foo_' for 'prefix' and 'foo__bar' for 'full'
- range = 'prefix',
- -- Regex used to get the text when fuzzy matching
- regex = '[-_]\\|\\k',
- -- After matching with regex, any characters matching this regex at the prefix will be excluded
- exclude_from_prefix_regex = '[\\-]',
- },
-
- trigger = {
- -- When true, will prefetch the completion items when entering insert mode
- -- WARN: buggy, not recommended unless you'd like to help develop prefetching
- prefetch_on_insert = false,
- -- When false, will not show the completion window automatically when in a snippet
- show_in_snippet = true,
- -- When true, will show the completion window after typing a character that matches the `keyword.regex`
- show_on_keyword = true,
- -- When true, will show the completion window after typing a trigger character
- show_on_trigger_character = true,
- -- LSPs can indicate when to show the completion window via trigger characters
- -- however, some LSPs (i.e. tsserver) return characters that would essentially
- -- always show the window. We block these by default.
- show_on_blocked_trigger_characters = function()
- if vim.api.nvim_get_mode().mode == 'c' then return {} end
-
- -- you can also block per filetype, for example:
- -- if vim.bo.filetype == 'markdown' then
- -- return { ' ', '\n', '\t', '.', '/', '(', '[' }
- -- end
-
- return { ' ', '\n', '\t' }
- end,
- -- When both this and show_on_trigger_character are true, will show the completion window
- -- when the cursor comes after a trigger character after accepting an item
- show_on_accept_on_trigger_character = true,
- -- When both this and show_on_trigger_character are true, will show the completion window
- -- when the cursor comes after a trigger character when entering insert mode
- show_on_insert_on_trigger_character = true,
- -- List of trigger characters (on top of `show_on_blocked_trigger_characters`) that won't trigger
- -- the completion window when the cursor comes after a trigger character when
- -- entering insert mode/accepting an item
- show_on_x_blocked_trigger_characters = { "'", '"', '(', '{' },
- -- or a function, similar to show_on_blocked_trigger_character
- },
-
- list = {
- -- Maximum number of items to display
- max_items = 200,
- -- Controls if completion items will be selected automatically,
- -- and whether selection automatically inserts
- selection = 'preselect',
- -- Controls how the completion items are selected
- -- 'preselect' will automatically select the first item in the completion list
- -- 'manual' will not select any item by default
- -- 'auto_insert' will not select any item by default, and insert the completion items automatically
- -- when selecting them
- --
- -- You may want to bind a key to the `cancel` command, which will undo the selection
- -- when using 'auto_insert'
- cycle = {
- -- When `true`, calling `select_next` at the *bottom* of the completion list
- -- will select the *first* completion item.
- from_bottom = true,
- -- When `true`, calling `select_prev` at the *top* of the completion list
- -- will select the *last* completion item.
- from_top = true,
- },
- },
-
- accept = {
- -- Create an undo point when accepting a completion item
- create_undo_point = true,
- -- Experimental auto-brackets support
- auto_brackets = {
- -- Whether to auto-insert brackets for functions
- enabled = true,
- -- Default brackets to use for unknown languages
- default_brackets = { '(', ')' },
- -- Overrides the default blocked filetypes
- override_brackets_for_filetypes = {},
- -- Synchronously use the kind of the item to determine if brackets should be added
- kind_resolution = {
- enabled = true,
- blocked_filetypes = { 'typescriptreact', 'javascriptreact', 'vue' },
- },
- -- Asynchronously use semantic token to determine if brackets should be added
- semantic_token_resolution = {
- enabled = true,
- blocked_filetypes = {},
- -- How long to wait for semantic tokens to return before assuming no brackets should be added
- timeout_ms = 400,
- },
- },
- },
-
- menu = {
- enabled = true,
- min_width = 15,
- max_height = 10,
- border = 'none',
- winblend = 0,
- winhighlight = 'Normal:BlinkCmpMenu,FloatBorder:BlinkCmpMenuBorder,CursorLine:BlinkCmpMenuSelection,Search:None',
- -- Keep the cursor X lines away from the top/bottom of the window
- scrolloff = 2,
- -- Note that the gutter will be disabled when border ~= 'none'
- scrollbar = true,
- -- Which directions to show the window,
- -- falling back to the next direction when there's not enough space
- direction_priority = { 's', 'n' },
-
- -- Whether to automatically show the window when new completion items are available
- auto_show = true,
-
- -- Screen coordinates of the command line
- cmdline_position = function()
- if vim.g.ui_cmdline_pos ~= nil then
- local pos = vim.g.ui_cmdline_pos -- (1, 0)-indexed
- return { pos[1] - 1, pos[2] }
- end
- local height = (vim.o.cmdheight == 0) and 1 or vim.o.cmdheight
- return { vim.o.lines - height, 0 }
- end,
-
- -- Controls how the completion items are rendered on the popup window
- draw = {
- -- Aligns the keyword you've typed to a component in the menu
- align_to_component = 'label', -- or 'none' to disable
- -- Left and right padding, optionally { left, right } for different padding on each side
- padding = 1,
- -- Gap between columns
- gap = 1,
- -- Use treesitter to highlight the label text of completions from these sources
- treesitter = {},
- -- Recommended to enable it just for the LSP source
- -- treesitter = { 'lsp' }
-
- -- Components to render, grouped by column
- columns = { { 'kind_icon' }, { 'label', 'label_description', gap = 1 } },
- -- for a setup similar to nvim-cmp: https://github.com/Saghen/blink.cmp/pull/245#issuecomment-2463659508
- -- columns = { { "label", "label_description", gap = 1 }, { "kind_icon", "kind" } },
-
- -- Definitions for possible components to render. Each component defines:
- -- ellipsis: whether to add an ellipsis when truncating the text
- -- width: control the min, max and fill behavior of the component
- -- text function: will be called for each item
- -- highlight function: will be called only when the line appears on screen
- components = {
- kind_icon = {
- ellipsis = false,
- text = function(ctx) return ctx.kind_icon .. ctx.icon_gap end,
- highlight = function(ctx)
- return require('blink.cmp.completion.windows.render.tailwind').get_hl(ctx) or 'BlinkCmpKind' .. ctx.kind
- end,
- },
-
- kind = {
- ellipsis = false,
- width = { fill = true },
- text = function(ctx) return ctx.kind end,
- highlight = function(ctx)
- return require('blink.cmp.completion.windows.render.tailwind').get_hl(ctx) or 'BlinkCmpKind' .. ctx.kind
- end,
- },
-
- label = {
- width = { fill = true, max = 60 },
- text = function(ctx) return ctx.label .. ctx.label_detail end,
- highlight = function(ctx)
- -- label and label details
- local highlights = {
- { 0, #ctx.label, group = ctx.deprecated and 'BlinkCmpLabelDeprecated' or 'BlinkCmpLabel' },
- }
- if ctx.label_detail then
- table.insert(highlights, { #ctx.label, #ctx.label + #ctx.label_detail, group = 'BlinkCmpLabelDetail' })
- end
-
- -- characters matched on the label by the fuzzy matcher
- for _, idx in ipairs(ctx.label_matched_indices) do
- table.insert(highlights, { idx, idx + 1, group = 'BlinkCmpLabelMatch' })
- end
-
- return highlights
- end,
- },
-
- label_description = {
- width = { max = 30 },
- text = function(ctx) return ctx.label_description end,
- highlight = 'BlinkCmpLabelDescription',
- },
-
- source_name = {
- width = { max = 30 },
- text = function(ctx) return ctx.source_name end,
- highlight = 'BlinkCmpSource',
- },
- },
- },
- },
-
- documentation = {
- -- Controls whether the documentation window will automatically show when selecting a completion item
- auto_show = false,
- -- Delay before showing the documentation window
- auto_show_delay_ms = 500,
- -- Delay before updating the documentation window when selecting a new item,
- -- while an existing item is still visible
- update_delay_ms = 50,
- -- Whether to use treesitter highlighting, disable if you run into performance issues
- treesitter_highlighting = true,
- window = {
- min_width = 10,
- max_width = 60,
- max_height = 20,
- border = 'padded',
- winblend = 0,
- winhighlight = 'Normal:BlinkCmpDoc,FloatBorder:BlinkCmpDocBorder,CursorLine:BlinkCmpDocCursorLine,Search:None',
- -- Note that the gutter will be disabled when border ~= 'none'
- scrollbar = true,
- -- Which directions to show the documentation window,
- -- for each of the possible menu window directions,
- -- falling back to the next direction when there's not enough space
- direction_priority = {
- menu_north = { 'e', 'w', 'n', 's' },
- menu_south = { 'e', 'w', 's', 'n' },
- },
- },
- },
- -- Displays a preview of the selected item on the current line
- ghost_text = {
- enabled = false,
- },
- },
-
- -- Experimental signature help support
- signature = {
- enabled = false,
- trigger = {
- blocked_trigger_characters = {},
- blocked_retrigger_characters = {},
- -- When true, will show the signature help window when the cursor comes after a trigger character when entering insert mode
- show_on_insert_on_trigger_character = true,
- },
- window = {
- min_width = 1,
- max_width = 100,
- max_height = 10,
- border = 'padded',
- winblend = 0,
- winhighlight = 'Normal:BlinkCmpSignatureHelp,FloatBorder:BlinkCmpSignatureHelpBorder',
- scrollbar = false, -- Note that the gutter will be disabled when border ~= 'none'
- -- Which directions to show the window,
- -- falling back to the next direction when there's not enough space,
- -- or another window is in the way
- direction_priority = { 'n', 's' },
- -- Disable if you run into performance issues
- treesitter_highlighting = true,
- },
- },
-
- fuzzy = {
- -- when enabled, allows for a number of typos relative to the length of the query
- -- disabling this matches the behavior of fzf
- use_typo_resistance = true,
- -- frecency tracks the most recently/frequently used items and boosts the score of the item
- use_frecency = true,
- -- proximity bonus boosts the score of items matching nearby words
- use_proximity = true,
- max_items = 200,
- -- controls which sorts to use and in which order, falling back to the next sort if the first one returns nil
- -- you may pass a function instead of a string to customize the sorting
- sorts = { 'score', 'sort_text' },
-
- prebuilt_binaries = {
- -- Whether or not to automatically download a prebuilt binary from github. If this is set to `false`
- -- you will need to manually build the fuzzy binary dependencies by running `cargo build --release`
- download = true,
- -- When downloading a prebuilt binary, force the downloader to resolve this version. If this is unset
- -- then the downloader will attempt to infer the version from the checked out git tag (if any).
- --
- -- Beware that if the FFI ABI changes while tracking main then this may result in blink breaking.
- force_version = nil,
- -- When downloading a prebuilt binary, force the downloader to use this system triple. If this is unset
- -- then the downloader will attempt to infer the system triple from `jit.os` and `jit.arch`.
- -- Check the latest release for all available system triples
- --
- -- Beware that if the FFI ABI changes while tracking main then this may result in blink breaking.
- force_system_triple = nil,
- -- Extra arguments that will be passed to curl like { 'curl', ..extra_curl_args, ..built_in_args }
- extra_curl_args = {}
- },
- },
-
- sources = {
- -- Static list of providers to enable, or a function to dynamically enable/disable providers based on the context
- default = { 'lsp', 'path', 'snippets', 'buffer' },
- -- Example dynamically picking providers based on the filetype and treesitter node:
- -- providers = function(ctx)
- -- local node = vim.treesitter.get_node()
- -- if vim.bo.filetype == 'lua' then
- -- return { 'lsp', 'path' }
- -- elseif node and vim.tbl_contains({ 'comment', 'line_comment', 'block_comment' }, node:type()) then
- -- return { 'buffer' }
- -- else
- -- return { 'lsp', 'path', 'snippets', 'buffer' }
- -- end
- -- end
-
- -- You may also define providers per filetype
- per_filetype = {
- -- lua = { 'lsp', 'path' },
- },
-
- -- By default, we choose providers for the cmdline based on the current cmdtype
- -- You may disable cmdline completions by replacing this with an empty table
- cmdline = function()
- local type = vim.fn.getcmdtype()
- -- Search forward and backward
- if type == '/' or type == '?' then return { 'buffer' } end
- -- Commands
- if type == ':' then return { 'cmdline' } end
- return {}
- end,
-
- -- Function to use when transforming the items before they're returned for all providers
- -- The default will lower the score for snippets to sort them lower in the list
- transform_items = function(_, items) return items end,
- -- Minimum number of characters in the keyword to trigger all providers
- -- May also be `function(ctx: blink.cmp.Context): number`
- min_keyword_length = 0,
- -- Example for setting a minimum keyword length for markdown files
- -- min_keyword_length = function()
- -- return vim.bo.filetype == 'markdown' and 2 or 0
- -- end,
-
- -- Please see https://github.com/Saghen/blink.compat for using `nvim-cmp` sources
- providers = {
- lsp = {
- name = 'LSP',
- module = 'blink.cmp.sources.lsp',
- transform_items = function(_, items)
- -- demote snippets
- for _, item in ipairs(items) do
- if item.kind == require('blink.cmp.types').CompletionItemKind.Snippet then
- item.score_offset = item.score_offset - 3
- end
- end
-
- -- filter out text items, since we have the buffer source
- return vim.tbl_filter(
- function(item) return item.kind ~= require('blink.cmp.types').CompletionItemKind.Text end,
- items
- )
- end,
-
- --- *All* providers have the following options available
- --- NOTE: All of these options may be functions to get dynamic behavior
- --- See the type definitions for more information.
- enabled = true, -- Whether or not to enable the provider
- async = false, -- Whether we should wait for the provider to return before showing the completions
- timeout_ms = 2000, -- How long to wait for the provider to return before showing completions and treating it as asynchronous
- transform_items = nil, -- Function to transform the items before they're returned
- should_show_items = true, -- Whether or not to show the items
- max_items = nil, -- Maximum number of items to display in the menu
- min_keyword_length = 0, -- Minimum number of characters in the keyword to trigger the provider
- -- If this provider returns 0 items, it will fallback to these providers.
- -- If multiple providers falback to the same provider, all of the providers must return 0 items for it to fallback
- fallbacks = { 'buffer' },
- score_offset = 0, -- Boost/penalize the score of the items
- override = nil, -- Override the source's functions
- },
- path = {
- name = 'Path',
- module = 'blink.cmp.sources.path',
- score_offset = 3,
- fallbacks = { 'buffer' },
- opts = {
- trailing_slash = false,
- label_trailing_slash = true,
- get_cwd = function(context) return vim.fn.expand(('#%d:p:h'):format(context.bufnr)) end,
- show_hidden_files_by_default = false,
- }
- },
- snippets = {
- name = 'Snippets',
- module = 'blink.cmp.sources.snippets',
- score_offset = -3,
- opts = {
- friendly_snippets = true,
- search_paths = { vim.fn.stdpath('config') .. '/snippets' },
- global_snippets = { 'all' },
- extended_filetypes = {},
- ignored_filetypes = {},
- get_filetype = function(context)
- return vim.bo.filetype
- end
- }
-
- --- Example usage for disabling the snippet provider after pressing trigger characters (i.e. ".")
- -- enabled = function(ctx)
- -- return ctx ~= nil and ctx.trigger.kind == vim.lsp.protocol.CompletionTriggerKind.TriggerCharacter
- -- end,
- },
- luasnip = {
- name = 'Luasnip',
- module = 'blink.cmp.sources.luasnip',
- score_offset = -3,
- opts = {
- -- Whether to use show_condition for filtering snippets
- use_show_condition = true,
- -- Whether to show autosnippets in the completion list
- show_autosnippets = true,
- }
- },
- buffer = {
- name = 'Buffer',
- module = 'blink.cmp.sources.buffer',
- score_offset = -3,
- opts = {
- -- default to all visible buffers
- get_bufnrs = function()
- return vim
- .iter(vim.api.nvim_list_wins())
- :map(function(win) return vim.api.nvim_win_get_buf(win) end)
- :filter(function(buf) return vim.bo[buf].buftype ~= 'nofile' end)
- :totable()
- end,
- }
- },
- },
- },
-
- appearance = {
- highlight_ns = vim.api.nvim_create_namespace('blink_cmp'),
- -- Sets the fallback highlight groups to nvim-cmp's highlight groups
- -- Useful for when your theme doesn't support blink.cmp
- -- Will be removed in a future release
- use_nvim_cmp_as_default = false,
- -- Set to 'mono' for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
- -- Adjusts spacing to ensure icons are aligned
- nerd_font_variant = 'mono',
- kind_icons = {
- Text = '',
- Method = '',
- Function = '',
- Constructor = '',
-
- Field = '',
- Variable = '',
- Property = '',
-
- Class = '',
- Interface = '',
- Struct = '',
- Module = '',
-
- Unit = '',
- Value = '',
- Enum = '',
- EnumMember = '',
-
- Keyword = '',
- Constant = '',
-
- Snippet = '',
- Color = '',
- File = '',
- Reference = '',
- Folder = '',
- Event = '',
- Operator = '',
- TypeParameter = '',
- },
- },
-}
-```
-
-
-
-
-
-
-
-Highlight groups
-
-| Group | Default | Description |
-| ----- | ------- | ----------- |
-| `BlinkCmpMenu` | Pmenu | The completion menu window |
-| `BlinkCmpMenuBorder` | Pmenu | The completion menu window border |
-| `BlinkCmpMenuSelection` | PmenuSel | The completion menu window selected item |
-| `BlinkCmpScrollBarThumb` | PmenuThumb | The scrollbar thumb |
-| `BlinkCmpScrollBarGutter` | PmenuSbar | The scrollbar gutter |
-| `BlinkCmpLabel` | Pmenu | Label of the completion item |
-| `BlinkCmpLabelDeprecated` | NonText | Deprecated label of the completion item |
-| `BlinkCmpLabelMatch` | Pmenu | (Currently unused) Label of the completion item when it matches the query |
-| `BlinkCmpLabelDetail` | NonText | Label description of the completion item |
-| `BlinkCmpLabelDescription` | NonText | Label description of the completion item |
-| `BlinkCmpKind` | Special | Kind icon/text of the completion item |
-| `BlinkCmpKind` | Special | Kind icon/text of the completion item |
-| `BlinkCmpSource` | NonText | Source of the completion item |
-| `BlinkCmpGhostText` | NonText | Preview item with ghost text |
-| `BlinkCmpDoc` | NormalFloat | The documentation window |
-| `BlinkCmpDocBorder` | NormalFloat | The documentation window border |
-| `BlinkCmpDocSeparator` | NormalFloat | The documentation separator between doc and detail |
-| `BlinkCmpDocCursorLine` | Visual | The documentation window cursor line |
-| `BlinkCmpSignatureHelp` | NormalFloat | The signature help window |
-| `BlinkCmpSignatureHelpBorder` | NormalFloat | The signature help window border |
-| `BlinkCmpSignatureHelpActiveParameter` | LspSignatureActiveParameter | Active parameter of the signature help |
-
-
-
-
-### Community Sources
-
-- [lazydev](https://github.com/folke/lazydev.nvim)
-- [vim-dadbod-completion](https://github.com/kristijanhusak/vim-dadbod-completion)
-- [blink-ripgrep](https://github.com/mikavilpas/blink-ripgrep.nvim)
-- [blink-cmp-ripgrep](https://github.com/niuiic/blink-cmp-rg.nvim)
-- [blink-cmp-ctags](https://github.com/netmute/blink-cmp-ctags)
-- [blink-cmp-copilot](https://github.com/giuxtaposition/blink-cmp-copilot)
-- [minuet-ai.nvim](https://github.com/milanglacier/minuet-ai.nvim)
-
-### Luasnip
-
-```lua
-{
- 'saghen/blink.cmp',
- version = 'v0.*',
- -- !Important! Make sure you're using the latest release of LuaSnip
- -- `main` does not work at the moment
- dependencies = { 'L3MON4D3/LuaSnip', version = 'v2.*' },
- opts = {
- snippets = {
- expand = function(snippet) require('luasnip').lsp_expand(snippet) end,
- active = function(filter)
- if filter and filter.direction then
- return require('luasnip').jumpable(filter.direction)
- end
- return require('luasnip').in_snippet()
- end,
- jump = function(direction) require('luasnip').jump(direction) end,
- },
- sources = {
- default = { 'lsp', 'path', 'luasnip', 'buffer' },
- },
- }
-}
-```
-
-### Menu Appearance/Drawing
-
-
-Default draw configuration
-
-
-```lua
---- @module 'blink.cmp'
---- @type blink.cmp.Draw
-completion.menu.draw = {
- -- Aligns the keyword you've typed to a component in the menu
- align_to_component = 'label', -- or 'none' to disable
- -- Left and right padding, optionally { left, right } for different padding on each side
- padding = 1,
- -- Gap between columns
- gap = 1,
- -- Use treesitter to highlight the label text of completions from these sources
- treesitter = {},
-
- -- Components to render, grouped by column
- columns = { { 'kind_icon' }, { 'label', 'label_description', gap = 1 } },
- -- for a setup similar to nvim-cmp: https://github.com/Saghen/blink.cmp/pull/245#issuecomment-2463659508
- -- columns = { { "label", "label_description", gap = 1 }, { "kind_icon", "kind" } },
-
- -- Definitions for possible components to render. Each component defines:
- -- ellipsis: whether to add an ellipsis when truncating the text
- -- width: control the min, max and fill behavior of the component
- -- text function: will be called for each item
- -- highlight function: will be called only when the line appears on screen
- components = {
- kind_icon = {
- ellipsis = false,
- text = function(ctx) return ctx.kind_icon .. ctx.icon_gap end,
- highlight = function(ctx)
- return require('blink.cmp.completion.windows.render.tailwind').get_hl(ctx) or 'BlinkCmpKind' .. ctx.kind
- end,
- },
-
- kind = {
- ellipsis = false,
- width = { fill = true },
- text = function(ctx) return ctx.kind end,
- highlight = function(ctx)
- return require('blink.cmp.completion.windows.render.tailwind').get_hl(ctx) or 'BlinkCmpKind' .. ctx.kind
- end,
- },
-
- label = {
- width = { fill = true, max = 60 },
- text = function(ctx) return ctx.label .. ctx.label_detail end,
- highlight = function(ctx)
- -- label and label details
- local highlights = {
- { 0, #ctx.label, group = ctx.deprecated and 'BlinkCmpLabelDeprecated' or 'BlinkCmpLabel' },
- }
- if ctx.label_detail then
- table.insert(highlights, { #ctx.label, #ctx.label + #ctx.label_detail, group = 'BlinkCmpLabelDetail' })
- end
-
- -- characters matched on the label by the fuzzy matcher
- for _, idx in ipairs(ctx.label_matched_indices) do
- table.insert(highlights, { idx, idx + 1, group = 'BlinkCmpLabelMatch' })
- end
-
- return highlights
- end,
- },
-
- label_description = {
- width = { max = 30 },
- text = function(ctx) return ctx.label_description end,
- highlight = 'BlinkCmpLabelDescription',
- },
-
- source_name = {
- width = { max = 30 },
- -- source_name or source_id are supported
- text = function(ctx) return ctx.source_name end,
- highlight = 'BlinkCmpSource',
- },
- },
-}
-```
-
-
-
-
-
-blink.cmp uses a grid-based layout to render the completion menu. The components, defined in `draw.components[string]`, define `text` and `highlight` functions which are called for each completion item. The `highlight` function will be called only when the item appears on screen, so expensive operations such as Treesitter highlighting may be performed (contributions welcome!, [for example](https://www.reddit.com/r/neovim/comments/1ca4gm2/colorful_cmp_menu_powered_by_treesitter/)). The components may define their min and max width, where `ellipsis = true` (enabled by default), will draw the `…` character when the text is truncated. Setting `width.fill = true` will fill the remaining space, effectively making subsequent components right aligned, with respect to their column.
-
-Columns effectively allow you to vertically align a set of components. Each column, defined as an array in `draw.columns`, will be rendered for all of the completion items, where the longest rendered row will determine the width of the column. You may define `gap = number` in your column to insert a gap between components.
-
-For a setup similar to nvim-cmp, use the following config:
-
-```lua
-{
- completion = {
- menu = {
- draw = {
- columns = { { "label", "label_description", gap = 1 }, { "kind_icon", "kind" } },
- },
- },
- }
-}
-```
-
-### Select Nth item from the list
-
-Here's an example configuration that allows you to select the nth item from the list, based on [#382](https://github.com/Saghen/blink.cmp/issues/382):
-
-```lua
-keymap = {
- preset = 'default',
- [''] = { function(cmp) cmp.accept({ index = 1 }) end },
- [''] = { function(cmp) cmp.accept({ index = 2 }) end },
- [''] = { function(cmp) cmp.accept({ index = 3 }) end },
- [''] = { function(cmp) cmp.accept({ index = 4 }) end },
- [''] = { function(cmp) cmp.accept({ index = 5 }) end },
- [''] = { function(cmp) cmp.accept({ index = 6 }) end },
- [''] = { function(cmp) cmp.accept({ index = 7 }) end },
- [''] = { function(cmp) cmp.accept({ index = 8 }) end },
- [''] = { function(cmp) cmp.accept({ index = 9 }) end },
-},
-completion = {
- menu = {
- draw = {
- columns = { { 'item_idx' }, { 'kind_icon' }, { 'label', 'label_description', gap = 1 } },
- components = {
- item_idx = {
- text = function(ctx) return ctx.idx >= 10 and ' ' or tostring(ctx.idx) end,
- highlight = 'BlinkCmpItemIdx' -- optional, only if you want to change its color
- }
- }
- }
- }
-}
-```
-
-## How it works
-
-The plugin use a 4 stage pipeline: trigger -> sources -> fuzzy -> render
-1. **Trigger:** Controls when to request completion items from the sources and provides a context downstream with the current query (i.e. `hello.wo|`, the query would be `wo`) and the treesitter object under the cursor (i.e. for intelligently enabling/disabling sources). It respects trigger characters passed by the LSP (or any other source) and includes it in the context for sending to the LSP.
-2. **Sources:** Provides a common interface for and merges the results of completion, trigger character, resolution of additional information and cancellation. Some sources are builtin: `LSP`, `buffer`, `path`, `snippets`
-3. **Fuzzy:** Rust <-> Lua FFI which performs both filtering and sorting of the items
- - **Filtering:** The fuzzy matching uses smith-waterman, same as FZF, but implemented in SIMD for ~6x the performance of FZF (TODO: add benchmarks). Due to the SIMD's performance, the prefiltering phase on FZF was dropped to allow for typos. Similar to fzy/fzf, additional points are given to prefix matches, characters with capitals (to promote camelCase/PascalCase first char matching) and matches after delimiters (to promote snake_case first char matching)
- - **Sorting:** Combines fuzzy matching score with frecency and proximity bonus. Each completion item may also include a `score_offset` which will be added to this score to demote certain sources. The `snippets` source takes advantage of this to avoid taking precedence over the LSP source. The parameters here still need to be tuned, so please let me know if you find some magical parameters!
-4. **Windows:** Responsible for placing the menu, documentation and function parameters windows. It uses a grid based layout for drawing, and uses a window decoration provider to provide ~0 overhead highlighting.
-
-## Compared to nvim-cmp
-
-### Advantages
-
-- Avoids the complexity of nvim-cmp's configuration by providing sensible defaults
-- Updates on every keystroke with 0.5-4ms of overhead, versus nvim-cmp's default debounce of 60ms with 2-50ms hitches from processing
- - Setting nvim-cmp's debounce to 0ms leads to visible stuttering. If you'd like to stick with nvim-cmp, try [yioneko's fork](https://github.com/yioneko/nvim-cmp) or the more recent [magazine.nvim](https://github.com/iguanacucumber/magazine.nvim)
-- Boosts completion item score via frecency _and_ proximity bonus. nvim-cmp boosts score via proximity bonus and optionally by recency
-- Typo-resistant fuzzy matching unlike nvim-cmp's fzf-style fuzzy matching
-- Core sources (buffer, snippets, path, lsp) are built-in versus nvim-cmp's exclusively external sources
-- Built-in auto bracket and signature help support
-
-### Planned missing features
+## Getting Started
-- Significantly more testing and documentation
+Head over to the [documentation website](https://cmp.saghen.dev) for installation instructions and configuration options.
## Special Thanks
diff --git a/ROADMAP.md b/ROADMAP.md
deleted file mode 100644
index 4750b95d..00000000
--- a/ROADMAP.md
+++ /dev/null
@@ -1,10 +0,0 @@
-# Ideas to explore
-
-- [x] Support auto brackets on function completion
-- [ ] LSP signature help ([ref](https://github.com/ray-x/lsp_signature.nvim)) (currently experimental)
-- [x] Ship pre-built binaries
-- [x] Output preview with ghost text, including for snippets
-- [ ] Show sources dynamically based on treesitter nodes
-- [x] Apply treesitter highlights to completion labels ([ref](https://github.com/hrsh7th/nvim-cmp/issues/1887#issue-2246686828))
-- [ ] Get query for fuzzy from treesitter node
-- [ ] Cmdline support (including noice.nvim support)
diff --git a/docs/.gitignore b/docs/.gitignore
new file mode 100644
index 00000000..55065682
--- /dev/null
+++ b/docs/.gitignore
@@ -0,0 +1,3 @@
+node_modules
+.vitepress/cache
+.vitepress/dist
diff --git a/docs/.prettierrc b/docs/.prettierrc
new file mode 100644
index 00000000..31ba22d8
--- /dev/null
+++ b/docs/.prettierrc
@@ -0,0 +1,5 @@
+{
+ "semi": false,
+ "singleQuote": true,
+ "printWidth": 120
+}
diff --git a/docs/.vitepress/config.mts b/docs/.vitepress/config.mts
new file mode 100644
index 00000000..3427cd15
--- /dev/null
+++ b/docs/.vitepress/config.mts
@@ -0,0 +1,53 @@
+import { defineConfig } from 'vitepress'
+import { tabsMarkdownPlugin } from 'vitepress-plugin-tabs'
+
+// https://vitepress.dev/reference/site-config
+export default defineConfig({
+ title: 'Blink Completion (blink.cmp)',
+ description: 'Performant, batteries-included completion plugin for Neovim',
+ sitemap: { hostname: 'https://cmp.saghen.dev/' },
+ head: [['link', { rel: 'icon', href: '/favicon.png' }]],
+ themeConfig: {
+ sidebar: [
+ { text: 'Introduction', link: '/' },
+ { text: 'Installation', link: '/installation' },
+ {
+ text: 'Configuration',
+ items: [
+ { text: 'General', link: '/configuration/general' },
+ { text: 'Appearance', link: '/configuration/appearance' },
+ { text: 'Completion', link: '/configuration/completion' },
+ { text: 'Keymap', link: '/configuration/keymap' },
+ { text: 'Signature', link: '/configuration/signature' },
+ { text: 'Sources', link: '/configuration/sources' },
+ { text: 'Snippets', link: '/configuration/snippets' },
+ { text: 'Reference', link: '/configuration/reference' },
+ ],
+ },
+ {
+ text: 'Development',
+ items: [
+ { text: 'Architecture', link: '/development/architecture' },
+ { text: 'Writing Sources', link: '/development/writing-sources' },
+ { text: 'LSP Tracker', link: '/development/lsp-tracker' },
+ ],
+ },
+ ],
+
+ socialLinks: [{ icon: 'github', link: 'https://github.com/saghen/blink.cmp' }],
+
+ search: {
+ provider: 'local',
+ },
+ },
+
+ markdown: {
+ theme: {
+ light: 'catppuccin-latte',
+ dark: 'catppuccin-mocha',
+ },
+ config(md) {
+ md.use(tabsMarkdownPlugin)
+ },
+ },
+})
diff --git a/docs/.vitepress/theme/index.ts b/docs/.vitepress/theme/index.ts
new file mode 100644
index 00000000..f13e9f9a
--- /dev/null
+++ b/docs/.vitepress/theme/index.ts
@@ -0,0 +1,14 @@
+// https://vitepress.dev/guide/custom-theme
+import DefaultTheme from 'vitepress/theme'
+import type { Theme } from 'vitepress'
+import { enhanceAppWithTabs } from 'vitepress-plugin-tabs/client'
+
+import '@catppuccin/vitepress/theme/mocha/blue.css'
+import './style.css'
+
+export default {
+ extends: DefaultTheme,
+ enhanceApp({ app }) {
+ enhanceAppWithTabs(app)
+ },
+} satisfies Theme
diff --git a/docs/.vitepress/theme/style.css b/docs/.vitepress/theme/style.css
new file mode 100644
index 00000000..40354f4f
--- /dev/null
+++ b/docs/.vitepress/theme/style.css
@@ -0,0 +1,9 @@
+/* Wrap text in code blocks */
+code {
+ white-space: pre-wrap !important;
+ word-break: break-word !important;
+}
+
+.content-container {
+ max-width: 800px !important;
+}
diff --git a/docs/configuration/appearance.md b/docs/configuration/appearance.md
new file mode 100644
index 00000000..fb25e40f
--- /dev/null
+++ b/docs/configuration/appearance.md
@@ -0,0 +1,29 @@
+# Appearance
+
+If you're looking for how to change the appearance of the completion menu, check out the [menu draw configuration](./completion#completion-menu-draw).
+
+## Highlight groups
+
+| Group | Default | Description |
+| ----- | ------- | ----------- |
+| `BlinkCmpMenu` | Pmenu | The completion menu window |
+| `BlinkCmpMenuBorder` | Pmenu | The completion menu window border |
+| `BlinkCmpMenuSelection` | PmenuSel | The completion menu window selected item |
+| `BlinkCmpScrollBarThumb` | PmenuThumb | The scrollbar thumb |
+| `BlinkCmpScrollBarGutter` | PmenuSbar | The scrollbar gutter |
+| `BlinkCmpLabel` | Pmenu | Label of the completion item |
+| `BlinkCmpLabelDeprecated` | NonText | Deprecated label of the completion item |
+| `BlinkCmpLabelMatch` | Pmenu | (Currently unused) Label of the completion item when it matches the query |
+| `BlinkCmpLabelDetail` | NonText | Label description of the completion item |
+| `BlinkCmpLabelDescription` | NonText | Label description of the completion item |
+| `BlinkCmpKind` | Special | Kind icon/text of the completion item |
+| `BlinkCmpKind` | Special | Kind icon/text of the completion item |
+| `BlinkCmpSource` | NonText | Source of the completion item |
+| `BlinkCmpGhostText` | NonText | Preview item with ghost text |
+| `BlinkCmpDoc` | NormalFloat | The documentation window |
+| `BlinkCmpDocBorder` | NormalFloat | The documentation window border |
+| `BlinkCmpDocSeparator` | NormalFloat | The documentation separator between doc and detail |
+| `BlinkCmpDocCursorLine` | Visual | The documentation window cursor line |
+| `BlinkCmpSignatureHelp` | NormalFloat | The signature help window |
+| `BlinkCmpSignatureHelpBorder` | NormalFloat | The signature help window border |
+| `BlinkCmpSignatureHelpActiveParameter` | LspSignatureActiveParameter | Active parameter of the signature help |
diff --git a/docs/configuration/completion.md b/docs/configuration/completion.md
new file mode 100644
index 00000000..c44e637c
--- /dev/null
+++ b/docs/configuration/completion.md
@@ -0,0 +1,100 @@
+# Completion
+
+Blink cmp has *a lot* of configuration options, the following document tries to highlight the ones you'll likely care the most about for each section. For all options, click on the "Go to default configuration" button next to each header.
+
+## Keyword
+
+Controls what the plugin considers to be a keyword, used for fuzzy matching and triggering completions. Most notably, the `range` option controls whether the keyword should match against the text before *and* after the cursor, or just before the cursor.
+
+:::tabs
+== Prefix
+
+== Full
+
+:::
+
+## Trigger
+
+Controls when to request completion items from the sources and show the completion menu. The following options are available, excluding their `show_on` prefix:
+
+:::tabs
+== Keyword
+
+== Trigger Character
+
+== Insert on Trigger Character
+
+== Accept on Trigger Character
+TODO: Find a case where this actually fires : )
+:::
+
+## List
+
+Manages the completion list and its behavior when selecting items. The most commonly changed option is `completion.list.selection`, which controls whether the list will automatically select the first item in the list, and whether selection shows a preview:
+
+:::tabs
+== Preselect
+Selects the first item automatically
+
+
+== Manual
+No item will be selected by default. You may use the `select_and_accept` keymap command to select the first item and accept it when there's no selection. The `accept` keymap command, on the other hand, will only trigger if an item is selected.
+
+
+== Auto Insert
+No item will be selected by default, and selecting an item will insert a "preview" of the item automatically. You may use the `select_and_accept` keymap command to select the first item and accept it when there's no selection. The `accept` keymap command, on the other hand, will only trigger if an item is selected.
+
+
+:::
+
+## Accept
+
+Manages the behavior when accepting an item in the completion menu.
+
+### Auto Brackets
+
+> [!NOTE]
+> Some LSPs may add auto brackets themselves. You may be able to configure this behavior in your LSP client configuration
+
+LSPs provide a `kind` field for completion items, indicating whether the item is a function, method, variable, etc. The plugin will automatically add brackets for functions/methods and place the cursor inside the brackets. For items not marked as such, the plugin will asynchronously resolve the semantic tokens from the LSP and add brackets if marked as a function. A default list of brackets have been included in the default configuration, but you may add more in the configuration (contributions welcome!).
+
+If brackets are showing when you don't expect them, try disabling `kind_resolution` or `semantic_token_resolution` for that filetype (`echo &filetype`). If that fixes the issue, please open a PR setting this as the default!
+
+## Menu
+
+Manages the appearance of the completion menu. You may prevent the menu from automatically showing by setting `completion.menu.auto_show = false` and manually showing it with the `show` keymap command.
+
+### Menu Draw
+
+blink.cmp uses a grid-based layout to render the completion menu. The components, defined in `draw.components[string]`, define `text` and `highlight` functions which are called for each completion item. The `highlight` function will be called only when the item appears on screen, so expensive operations such as Treesitter highlighting may be performed (contributions welcome!, [for example](https://www.reddit.com/r/neovim/comments/1ca4gm2/colorful_cmp_menu_powered_by_treesitter/)). The components may define their min and max width, where `ellipsis = true` (enabled by default), will draw the `…` character when the text is truncated. Setting `width.fill = true` will fill the remaining space, effectively making subsequent components right aligned, with respect to their column.
+
+Columns effectively allow you to vertically align a set of components. Each column, defined as an array in `draw.columns`, will be rendered for all of the completion items, where the longest rendered row will determine the width of the column. You may define `gap = number` in your column to insert a gap between components.
+
+For a setup similar to nvim-cmp, use the following config:
+
+```lua
+completion.menu.draw.columns = { { "label", "label_description", gap = 1 }, { "kind_icon", "kind" } },
+```
+
+## Documentation
+
+By default, the documentation window will only show when triggered by the `show_documentation` keymap command. However, you may add the following configuration to show the documentation whenever an item is selected.
+
+```lua
+completion.documentation = {
+ auto_show = true,
+ auto_show_delay_ms = 500,
+}
+```
+
+If you're noticing high CPU usage or stuttering when opening the documentation, you may try setting `completion.documentation.treesitter_highlighting = false`.
+
+## Ghost Text
+
+Ghost text shows a preview of the currently selected item as virtual text inline. You may want to try setting `completion.menu.auto_show = false` and enabling ghost text, or you may use both in parallel.
+
+```lua
+completion.ghost_text.enabled = true
+```
+
+
diff --git a/docs/configuration/fuzzy.md b/docs/configuration/fuzzy.md
new file mode 100644
index 00000000..7ef1a5b6
--- /dev/null
+++ b/docs/configuration/fuzzy.md
@@ -0,0 +1,30 @@
+# Fuzzy
+
+Blink uses a SIMD fuzzy matcher called [frizbee](https://github.com/saghen/frizbee) which achieves ~6x the performance of fzf while ignoring typos. Check out the repo for more information!
+
+## Installation
+
+### Prebuilt binaries (default on a release tag)
+
+By default, Blink will download a prebuilt binary from the latest release, when you're on a release tag (via `version = '*'` on `lazy.nvim` for example). If you're not on a release tag, you may force a specific version via `fuzzy.prebuilt_binaries.force_version`. See [the latest release](https://github.com/saghen/blink.cmp/releases/latest) for supported systems. See `prebuilt_binaries` section of the [reference configuration](./reference.md#prebuilt-binaries) for more options.
+
+You may instead install the prebuilt binaries manually by downloading the appropriate binary from the [latest release](https://github.com/saghen/blink.cmp/releases/latest) and placing it at `$data/lazy/blink.cmp/target/release/libblink_cmp_fuzzy.$ext`. Get the `$data` path via `:echo stdpath('data')`. Use `.so` for linux, `.dylib` for mac, and `.dll` for windows. If you're unsure whether you want `-musl` or `-gnu` for linux, you very likely want `-gnu`.
+
+```sh
+# Linux
+~/.local/share/nvim/lazy/blink.cmp/target/release/libblink_cmp_fuzzy.so
+
+# Mac
+~/.local/share/nvim/lazy/blink.cmp/target/release/libblink_cmp_fuzzy.dylib
+
+# Windows
+~/Appdata/Local/nvim/lazy/blink.cmp/target/release/libblink_cmp_fuzzy.dll
+```
+
+### Build from source (recommended for `main`)
+
+When on `main`, it's highly recommended to build from source via `cargo build --release` (via `build = '...'` on `lazy.nvim` for example). This requires a nightly rust toolchain, which will be automatically downloaded when using `rustup`.
+
+## Configuration
+
+See the [fuzzy section of the reference configuration](./reference.md#fuzzy)
diff --git a/docs/configuration/general.md b/docs/configuration/general.md
new file mode 100644
index 00000000..00e1cddd
--- /dev/null
+++ b/docs/configuration/general.md
@@ -0,0 +1,59 @@
+# General
+
+Blink cmp has *a lot* of configuration options, the following code block highlights some changes you're most likely to care about. For more information, check out the additional pages.
+
+For more common configurations, see the [recipes](./recipes.md).
+
+```lua
+{
+ -- Disable for some filetypes
+ enabled = function()
+ return not vim.tbl_contains({ "lua", "markdown" }, vim.bo.filetype)
+ and vim.bo.buftype ~= "prompt"
+ and vim.b.completion ~= false
+ end,
+
+ completion = {
+ -- 'prefix' will fuzzy match on the text before the cursor
+ -- 'full' will fuzzy match on the text before *and* after the cursor
+ -- example: 'foo_|_bar' will match 'foo_' for 'prefix' and 'foo__bar' for 'full'
+ keyword = { range = 'full' },
+
+ -- Disable auto brackets
+ -- NOTE: some LSPs may add auto brackets themselves anyway
+ accept = { auto_brackets = { enabled = false }, }
+
+ -- Insert completion item on selection, don't select by default
+ list = { selection = 'auto_insert' },
+
+ menu = {
+ -- Don't automatically show the completion menu
+ auto_show = false,
+
+ -- nvim-cmp style menu
+ draw = {
+ columns = {
+ { "label", "label_description", gap = 1 },
+ { "kind_icon", "kind" }
+ },
+ }
+ },
+
+ -- Show documentation when selecting a completion item
+ documentation = { auto_show = true, auto_show_delay_ms = 500 },
+
+ -- Display a preview of the selected item on the current line
+ ghost_text = { enabled = true },
+ },
+
+ sources = {
+ -- Remove 'buffer' if you don't want text completions, by default it's only enabled when LSP returns no items
+ default = { 'lsp', 'path', 'snippets', 'buffer' },
+ -- Disable cmdline completions
+ cmdline = {},
+ }
+
+ -- Experimental signature help support
+ signature = { enabled = true }
+}
+```
diff --git a/docs/configuration/keymap.md b/docs/configuration/keymap.md
new file mode 100644
index 00000000..2e40a5f5
--- /dev/null
+++ b/docs/configuration/keymap.md
@@ -0,0 +1,125 @@
+# Keymap
+
+Blink uses a custom DSL for defining keymaps since it needs to handle falling back to other mappings. However, there's nothing stopping you from using `require('blink.cmp')` and implementing these keymaps yourself.
+
+Your custom key mappings are merged with a `preset` and any conflicting keys will overwrite the preset mappings. The `fallback` command will run the next non blink keymap.
+
+## Example
+
+Each keymap may be a list of commands and/or functions, where commands map directly to `require('blink.cmp')[command]()`. If the command/function returns `false` or `nil`, the next command/function will be run.
+
+```lua
+keymap = {
+ -- set to 'none' to disable the 'default' preset
+ preset = 'default',
+
+ [''] = { 'select_prev', 'fallback' },
+ [''] = { 'select_next', 'fallback' },
+
+ -- disable a keymap from the preset
+ [''] = {},
+
+ -- show with a list of providers
+ [''] = { function(cmp) cmp.show({ providers = { 'snippets' } }) end },
+
+ -- control whether the next command will be run when using a function
+ [''] = {
+ function(cmp)
+ if some_condition then return end -- runs the next command
+ return true -- doesn't run the next command
+ end,
+ 'select_next'
+ },
+}
+```
+
+## Commands
+
+- `show`: Shows the completion menu
+ - Optionally use `function(cmp) cmp.show({ providers = { 'snippets' } }) end` to show with a specific list of providers
+- `hide`: Hides the completion menu
+- `cancel`: Reverts `completion.list.selection = 'auto_insert'` and hides the completion menu
+- `accept`: Accepts the currently selected item
+ - Optionally pass an index to select a specific item in the list: `function(cmp) cmp.accept({ index = 1 }) end`
+ - Optionally pass a `callback` to run after the item is accepted: `function(cmp) cmp.accept({ callback = function() vim.api.nvim_feedkeys('\n', 'n', true) end }) end`
+- `select_and_accept`: Accepts the currently selected item, or the first item if none are selected
+- `select_prev`: Selects the previous item, cycling to the bottom of the list if at the top, if `completion.list.cycle.from_top == true`
+- `select_next`: Selects the next item, cycling to the top of the list if at the bottom, if `completion.list.cycle.from_bottom == true`
+- `show_documentation`: Shows the documentation for the currently selected item
+- `hide_documentation`: Hides the documentation
+- `scroll_documentation_up`: Scrolls the documentation up by 4 lines
+ - Optionally use `function(cmp) cmp.scroll_documentation_up(4) end` to scroll by a specific number of lines
+- `scroll_documentation_down`: Scrolls the documentation down by 4 lines
+ - Optionally use `function(cmp) cmp.scroll_documentation_down(4) end` to scroll by a specific number of lines
+- `snippet_forward`: Jumps to the next snippet placeholder
+- `snippet_backward`: Jumps to the previous snippet placeholder
+- `fallback`: Runs the next non-blink keymap, or runs the built-in neovim binding
+
+## Presets
+
+Set the preset to `none` to disable the presets
+
+### `default`
+
+```lua
+[''] = { 'show', 'show_documentation', 'hide_documentation' },
+[''] = { 'hide' },
+[''] = { 'select_and_accept' },
+
+[''] = { 'select_prev', 'fallback' },
+[''] = { 'select_next', 'fallback' },
+
+[''] = { 'scroll_documentation_up', 'fallback' },
+[''] = { 'scroll_documentation_down', 'fallback' },
+
+[''] = { 'snippet_forward', 'fallback' },
+[''] = { 'snippet_backward', 'fallback' },
+```
+
+### `super-tab`
+
+You may want to set `completion.trigger.show_in_snippet = false` or use `completion.list.selection = "manual" | "auto_insert"`
+
+```lua
+[''] = { 'show', 'show_documentation', 'hide_documentation' },
+[''] = { 'hide', 'fallback' },
+
+[''] = {
+ function(cmp)
+ if cmp.snippet_active() then return cmp.accept()
+ else return cmp.select_and_accept() end
+ end,
+ 'snippet_forward',
+ 'fallback'
+},
+[''] = { 'snippet_backward', 'fallback' },
+
+[''] = { 'select_prev', 'fallback' },
+[''] = { 'select_next', 'fallback' },
+[''] = { 'select_prev', 'fallback' },
+[''] = { 'select_next', 'fallback' },
+
+[''] = { 'scroll_documentation_up', 'fallback' },
+[''] = { 'scroll_documentation_down', 'fallback' },
+```
+
+### `enter`
+
+You may want to set `completion.list.selection = "manual" | "auto_insert"`
+
+```lua
+[''] = { 'show', 'show_documentation', 'hide_documentation' },
+[''] = { 'hide', 'fallback' },
+[''] = { 'accept', 'fallback' },
+
+[''] = { 'snippet_forward', 'fallback' },
+[''] = { 'snippet_backward', 'fallback' },
+
+[''] = { 'select_prev', 'fallback' },
+[''] = { 'select_next', 'fallback' },
+[''] = { 'select_prev', 'fallback' },
+[''] = { 'select_next', 'fallback' },
+
+[''] = { 'scroll_documentation_up', 'fallback' },
+[''] = { 'scroll_documentation_down', 'fallback' },
+```
diff --git a/docs/configuration/recipes.md b/docs/configuration/recipes.md
new file mode 100644
index 00000000..5ad51eb9
--- /dev/null
+++ b/docs/configuration/recipes.md
@@ -0,0 +1,125 @@
+# Recipes
+
+
+## Disable per filetype
+
+```lua
+enabled = function()
+ return not vim.tbl_contains({ "lua", "markdown" }, vim.bo.filetype)
+ and vim.bo.buftype ~= "prompt"
+ and vim.b.completion ~= false
+end,
+```
+
+## Border
+
+```lua
+completion = {
+ menu = { border = 'single' }
+ documentation = { border = 'single' }
+},
+signature = { window = { border = 'single' } }
+```
+
+## Select Nth item from the list
+
+Here's an example configuration that allows you to select the nth item from the list, based on [#382](https://github.com/Saghen/blink.cmp/issues/382):
+
+```lua
+keymap = {
+ preset = 'default',
+ [''] = { function(cmp) cmp.accept({ index = 1 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 2 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 3 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 4 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 5 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 6 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 7 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 8 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 9 }) end },
+ [''] = { function(cmp) cmp.accept({ index = 10 }) end },
+},
+completion = {
+ menu = {
+ draw = {
+ columns = { { 'item_idx' }, { 'kind_icon' }, { 'label', 'label_description', gap = 1 } },
+ components = {
+ item_idx = {
+ text = function(ctx) return ctx.idx == 10 and '0' or ctx.idx >= 10 and ' ' or tostring(ctx.idx) end,
+ highlight = 'BlinkCmpItemIdx' -- optional, only if you want to change its color
+ }
+ }
+ }
+ }
+}
+```
+
+## `mini.icons`
+
+[Original discussion](https://github.com/Saghen/blink.cmp/discussions/458)
+
+```lua
+completion = {
+ menu = {
+ draw = {
+ components = {
+ kind_icon = {
+ ellipsis = false,
+ text = function(ctx)
+ local kind_icon, _, _ = require('mini.icons').get('lsp', ctx.kind)
+ return kind_icon
+ end,
+ -- Optionally, you may also use the highlights from mini.icons
+ highlight = function(ctx)
+ local _, hl, _ = require('mini.icons').get('lsp', ctx.kind)
+ return hl
+ end,
+ }
+ }
+ }
+ }
+}
+```
+
+
+## Sources
+
+### Dynamically picking providers by treesitter node/filetype
+
+```lua
+sources.default = function(ctx)
+ local node = vim.treesitter.get_node()
+ if vim.bo.filetype == 'lua' then
+ return { 'lsp', 'path' }
+ elseif node and vim.tbl_contains({ 'comment', 'line_comment', 'block_comment' }, node:type()) then
+ return { 'buffer' }
+ else
+ return { 'lsp', 'path', 'snippets', 'buffer' }
+ end
+end
+```
+
+### Hide snippets after trigger character
+
+> [!NOTE]
+> Untested, might not work well, please open a PR if you find a better solution!
+
+Trigger characters are defined by the sources. For example, for Lua, the trigger characters are `.`, `"`, `'`.
+
+```lua
+sources.providers.snippets.should_show_items = function(ctx)
+ return ctx.trigger.kind == vim.lsp.protocol.CompletionTriggerKind.TriggerCharacter
+end
+```
+
+### Disable all snippets
+
+See the [relevant section in the snippets documentation](./snippets.md#disable-all-snippets)
+
+### Set minimum keyword length by filetype
+
+```lua
+sources.min_keyword_length = function()
+ return vim.bo.filetype == 'markdown' and 2 or 0
+end
+```
diff --git a/docs/configuration/reference.md b/docs/configuration/reference.md
new file mode 100644
index 00000000..3e86035c
--- /dev/null
+++ b/docs/configuration/reference.md
@@ -0,0 +1,533 @@
+# Reference
+
+> [!IMPORTANT]
+> Do not copy the default configuration! Only include options you want to change in your configuration
+```lua
+-- Enables keymaps, completions and signature help when true
+enabled = function() return vim.bo.buftype ~= "prompt" and vim.b.completion ~= false end,
+
+-- See the "keymap" page for more information
+keymap = 'default',
+```
+
+## Snippets
+
+```lua
+snippets = {
+ -- Function to use when expanding LSP provided snippets
+ expand = function(snippet) vim.snippet.expand(snippet) end,
+ -- Function to use when checking if a snippet is active
+ active = function(filter) return vim.snippet.active(filter) end,
+ -- Function to use when jumping between tab stops in a snippet, where direction can be negative or positive
+ jump = function(direction) vim.snippet.jump(direction) end,
+}
+```
+
+## Completion
+
+### Completion Keyword
+
+```lua
+completion.keyword = {
+ -- 'prefix' will fuzzy match on the text before the cursor
+ -- 'full' will fuzzy match on the text before *and* after the cursor
+ -- example: 'foo_|_bar' will match 'foo_' for 'prefix' and 'foo__bar' for 'full'
+ range = 'prefix',
+ -- Regex used to get the text when fuzzy matching
+ regex = '[-_]\\|\\k',
+ -- After matching with regex, any characters matching this regex at the prefix will be excluded
+ exclude_from_prefix_regex = '[\\-]',
+}
+```
+
+### Completion Trigger
+
+```lua
+completion.trigger = {
+ -- When true, will prefetch the completion items when entering insert mode
+ prefetch_on_insert = false,
+
+ -- When false, will not show the completion window automatically when in a snippet
+ show_in_snippet = true,
+
+ -- When true, will show the completion window after typing a character that matches the `keyword.regex`
+ show_on_keyword = true,
+
+ -- When true, will show the completion window after typing a trigger character
+ show_on_trigger_character = true,
+
+ -- LSPs can indicate when to show the completion window via trigger characters
+ -- however, some LSPs (i.e. tsserver) return characters that would essentially
+ -- always show the window. We block these by default.
+ show_on_blocked_trigger_characters = function()
+ if vim.api.nvim_get_mode().mode == 'c' then return {} end
+
+ -- you can also block per filetype, for example:
+ -- if vim.bo.filetype == 'markdown' then
+ -- return { ' ', '\n', '\t', '.', '/', '(', '[' }
+ -- end
+
+ return { ' ', '\n', '\t' }
+ end,
+
+ -- When both this and show_on_trigger_character are true, will show the completion window
+ -- when the cursor comes after a trigger character after accepting an item
+ show_on_accept_on_trigger_character = true,
+
+ -- When both this and show_on_trigger_character are true, will show the completion window
+ -- when the cursor comes after a trigger character when entering insert mode
+ show_on_insert_on_trigger_character = true,
+
+ -- List of trigger characters (on top of `show_on_blocked_trigger_characters`) that won't trigger
+ -- the completion window when the cursor comes after a trigger character when
+ -- entering insert mode/accepting an item
+ show_on_x_blocked_trigger_characters = { "'", '"', '(' },
+ -- or a function, similar to show_on_blocked_trigger_character
+}
+```
+
+### Completion List
+
+```lua
+completion.list = {
+ -- Maximum number of items to display
+ max_items = 200,
+ -- Controls if completion items will be selected automatically,
+ -- and whether selection automatically inserts
+ selection = 'preselect',
+ -- Controls how the completion items are selected
+ -- 'preselect' will automatically select the first item in the completion list
+ -- 'manual' will not select any item by default
+ -- 'auto_insert' will not select any item by default, and insert the completion items automatically when selecting them
+ --
+ -- You may want to bind a key to the `cancel` command, which will undo the selection
+ -- when using 'auto_insert'
+ cycle = {
+ -- When `true`, calling `select_next` at the *bottom* of the completion list
+ -- will select the *first* completion item.
+ from_bottom = true,
+ -- When `true`, calling `select_prev` at the *top* of the completion list
+ -- will select the *last* completion item.
+ from_top = true,
+ },
+},
+```
+
+### Completion Accept
+
+```lua
+completion.accept = {
+ -- Create an undo point when accepting a completion item
+ create_undo_point = true,
+ -- Experimental auto-brackets support
+ auto_brackets = {
+ -- Whether to auto-insert brackets for functions
+ enabled = true,
+ -- Default brackets to use for unknown languages
+ default_brackets = { '(', ')' },
+ -- Overrides the default blocked filetypes
+ override_brackets_for_filetypes = {},
+ -- Synchronously use the kind of the item to determine if brackets should be added
+ kind_resolution = {
+ enabled = true,
+ blocked_filetypes = { 'typescriptreact', 'javascriptreact', 'vue' },
+ },
+ -- Asynchronously use semantic token to determine if brackets should be added
+ semantic_token_resolution = {
+ enabled = true,
+ blocked_filetypes = {},
+ -- How long to wait for semantic tokens to return before assuming no brackets should be added
+ timeout_ms = 400,
+ },
+ },
+},
+```
+
+### Completion Menu
+
+```lua
+completion.menu = {
+ enabled = true,
+ min_width = 15,
+ max_height = 10,
+ border = 'none',
+ winblend = 0,
+ winhighlight = 'Normal:BlinkCmpMenu,FloatBorder:BlinkCmpMenuBorder,CursorLine:BlinkCmpMenuSelection,Search:None',
+ -- Keep the cursor X lines away from the top/bottom of the window
+ scrolloff = 2,
+ -- Note that the gutter will be disabled when border ~= 'none'
+ scrollbar = true,
+ -- Which directions to show the window,
+ -- falling back to the next direction when there's not enough space
+ direction_priority = { 's', 'n' },
+
+ -- Whether to automatically show the window when new completion items are available
+ auto_show = true,
+
+ -- Screen coordinates of the command line
+ cmdline_position = function()
+ if vim.g.ui_cmdline_pos ~= nil then
+ local pos = vim.g.ui_cmdline_pos -- (1, 0)-indexed
+ return { pos[1] - 1, pos[2] }
+ end
+ local height = (vim.o.cmdheight == 0) and 1 or vim.o.cmdheight
+ return { vim.o.lines - height, 0 }
+ end,
+}
+```
+
+### Completion Menu Draw
+
+```lua
+-- Controls how the completion items are rendered on the popup window
+completion.menu.draw = {
+ -- Aligns the keyword you've typed to a component in the menu
+ align_to_component = 'label', -- or 'none' to disable
+ -- Left and right padding, optionally { left, right } for different padding on each side
+ padding = 1,
+ -- Gap between columns
+ gap = 1,
+ -- Use treesitter to highlight the label text
+ treesitter = false,
+
+ -- Components to render, grouped by column
+ columns = { { 'kind_icon' }, { 'label', 'label_description', gap = 1 } },
+
+ -- Definitions for possible components to render. Each defines:
+ -- ellipsis: whether to add an ellipsis when truncating the text
+ -- width: control the min, max and fill behavior of the component
+ -- text function: will be called for each item
+ -- highlight function: will be called only when the line appears on screen
+ components = {
+ kind_icon = {
+ ellipsis = false,
+ text = function(ctx) return ctx.kind_icon .. ctx.icon_gap end,
+ highlight = function(ctx)
+ return require('blink.cmp.completion.windows.render.tailwind').get_hl(ctx) or 'BlinkCmpKind' .. ctx.kind
+ end,
+ },
+
+ kind = {
+ ellipsis = false,
+ width = { fill = true },
+ text = function(ctx) return ctx.kind end,
+ highlight = function(ctx)
+ return require('blink.cmp.completion.windows.render.tailwind').get_hl(ctx) or 'BlinkCmpKind' .. ctx.kind
+ end,
+ },
+
+ label = {
+ width = { fill = true, max = 60 },
+ text = function(ctx) return ctx.label .. ctx.label_detail end,
+ highlight = function(ctx)
+ -- label and label details
+ local highlights = {
+ { 0, #ctx.label, group = ctx.deprecated and 'BlinkCmpLabelDeprecated' or 'BlinkCmpLabel' },
+ }
+ if ctx.label_detail then
+ table.insert(highlights, { #ctx.label, #ctx.label + #ctx.label_detail, group = 'BlinkCmpLabelDetail' })
+ end
+
+ -- characters matched on the label by the fuzzy matcher
+ for _, idx in ipairs(ctx.label_matched_indices) do
+ table.insert(highlights, { idx, idx + 1, group = 'BlinkCmpLabelMatch' })
+ end
+
+ return highlights
+ end,
+ },
+
+ label_description = {
+ width = { max = 30 },
+ text = function(ctx) return ctx.label_description end,
+ highlight = 'BlinkCmpLabelDescription',
+ },
+
+ source_name = {
+ width = { max = 30 },
+ text = function(ctx) return ctx.source_name end,
+ highlight = 'BlinkCmpSource',
+ },
+ },
+},
+```
+
+### Completion Documentation
+
+```lua
+completion.documentation = {
+ -- Controls whether the documentation window will automatically show when selecting a completion item
+ auto_show = false,
+ -- Delay before showing the documentation window
+ auto_show_delay_ms = 500,
+ -- Delay before updating the documentation window when selecting a new item,
+ -- while an existing item is still visible
+ update_delay_ms = 50,
+ -- Whether to use treesitter highlighting, disable if you run into performance issues
+ treesitter_highlighting = true,
+ window = {
+ min_width = 10,
+ max_width = 60,
+ max_height = 20,
+ border = 'padded',
+ winblend = 0,
+ winhighlight = 'Normal:BlinkCmpDoc,FloatBorder:BlinkCmpDocBorder,CursorLine:BlinkCmpDocCursorLine,Search:None',
+ -- Note that the gutter will be disabled when border ~= 'none'
+ scrollbar = true,
+ -- Which directions to show the documentation window,
+ -- for each of the possible menu window directions,
+ -- falling back to the next direction when there's not enough space
+ direction_priority = {
+ menu_north = { 'e', 'w', 'n', 's' },
+ menu_south = { 'e', 'w', 's', 'n' },
+ },
+ },
+}
+```
+
+### Completion Ghost Text
+
+```lua
+-- Displays a preview of the selected item on the current line
+completion.ghost_text = {
+ enabled = false,
+},
+```
+
+## Signature
+
+```lua
+-- Experimental signature help support
+signature = {
+ enabled = false,
+ trigger = {
+ blocked_trigger_characters = {},
+ blocked_retrigger_characters = {},
+ -- When true, will show the signature help window when the cursor comes after a trigger character when entering insert mode
+ show_on_insert_on_trigger_character = true,
+ },
+ window = {
+ min_width = 1,
+ max_width = 100,
+ max_height = 10,
+ border = 'padded',
+ winblend = 0,
+ winhighlight = 'Normal:BlinkCmpSignatureHelp,FloatBorder:BlinkCmpSignatureHelpBorder',
+ scrollbar = false, -- Note that the gutter will be disabled when border ~= 'none'
+ -- Which directions to show the window,
+ -- falling back to the next direction when there's not enough space,
+ -- or another window is in the way
+ direction_priority = { 'n', 's' },
+ -- Disable if you run into performance issues
+ treesitter_highlighting = true,
+ },
+}
+```
+
+## Fuzzy
+
+```lua
+fuzzy = {
+ -- When enabled, allows for a number of typos relative to the length of the query
+ -- Disabling this matches the behavior of fzf
+ use_typo_resistance = true,
+ -- Frecency tracks the most recently/frequently used items and boosts the score of the item
+ use_frecency = true,
+ -- Proximity bonus boosts the score of items matching nearby words
+ use_proximity = true,
+ max_items = 200,
+ -- Controls which sorts to use and in which order, falling back to the next sort if the first one returns nil
+ -- You may pass a function instead of a string to customize the sorting
+ sorts = { 'score', 'sort_text' },
+
+ prebuilt_binaries = {
+ -- Whether or not to automatically download a prebuilt binary from github. If this is set to `false`
+ -- you will need to manually build the fuzzy binary dependencies by running `cargo build --release`
+ download = true,
+ -- When downloading a prebuilt binary, force the downloader to resolve this version. If this is unset
+ -- then the downloader will attempt to infer the version from the checked out git tag (if any).
+ --
+ -- Beware that if the fuzzy matcher changes while tracking main then this may result in blink breaking.
+ force_version = nil,
+ -- When downloading a prebuilt binary, force the downloader to use this system triple. If this is unset
+ -- then the downloader will attempt to infer the system triple from `jit.os` and `jit.arch`.
+ -- Check the latest release for all available system triples
+ --
+ -- Beware that if the fuzzy matcher changes while tracking main then this may result in blink breaking.
+ force_system_triple = nil,
+ -- Extra arguments that will be passed to curl like { 'curl', ..extra_curl_args, ..built_in_args }
+ extra_curl_args = {}
+ },
+}
+```
+
+## Sources
+
+```lua
+sources = {
+ -- Static list of providers to enable, or a function to dynamically enable/disable providers based on the context
+ default = { 'lsp', 'path', 'snippets', 'buffer' },
+
+ -- You may also define providers per filetype
+ per_filetype = {
+ -- lua = { 'lsp', 'path' },
+ },
+
+ -- By default, we choose providers for the cmdline based on the current cmdtype
+ -- You may disable cmdline completions by replacing this with an empty table
+ cmdline = function()
+ local type = vim.fn.getcmdtype()
+ -- Search forward and backward
+ if type == '/' or type == '?' then return { 'buffer' } end
+ -- Commands
+ if type == ':' then return { 'cmdline' } end
+ return {}
+ end,
+
+ -- Function to use when transforming the items before they're returned for all providers
+ -- The default will lower the score for snippets to sort them lower in the list
+ transform_items = function(_, items) return items end,
+
+ -- Minimum number of characters in the keyword to trigger all providers
+ -- May also be `function(ctx: blink.cmp.Context): number`
+ min_keyword_length = 0,
+}
+```
+
+### Providers
+
+```lua
+-- Please see https://github.com/Saghen/blink.compat for using `nvim-cmp` sources
+sources.providers = {
+ lsp = {
+ name = 'LSP',
+ module = 'blink.cmp.sources.lsp',
+ fallbacks = { 'buffer' },
+ -- Filter text items from the LSP provider, since we have the buffer provider for that
+ transform_items = function(_, items)
+ for _, item in ipairs(items) do
+ if item.kind == require('blink.cmp.types').CompletionItemKind.Snippet then
+ item.score_offset = item.score_offset - 3
+ end
+ end
+
+ return vim.tbl_filter(
+ function(item) return item.kind ~= require('blink.cmp.types').CompletionItemKind.Text end,
+ items
+ )
+ end,
+
+ --- NOTE: All of these options may be functions to get dynamic behavior
+ --- See the type definitions for more information
+ enabled = true, -- Whether or not to enable the provider
+ async = false, -- Whether we should wait for the provider to return before showing the completions
+ timeout_ms = 2000, -- How long to wait for the provider to return before showing completions and treating it as asynchronous
+ transform_items = nil, -- Function to transform the items before they're returned
+ should_show_items = true, -- Whether or not to show the items
+ max_items = nil, -- Maximum number of items to display in the menu
+ min_keyword_length = 0, -- Minimum number of characters in the keyword to trigger the provider
+ -- If this provider returns 0 items, it will fallback to these providers.
+ -- If multiple providers falback to the same provider, all of the providers must return 0 items for it to fallback
+ fallbacks = {},
+ score_offset = 0, -- Boost/penalize the score of the items
+ override = nil, -- Override the source's functions
+ },
+ path = {
+ name = 'Path',
+ module = 'blink.cmp.sources.path',
+ score_offset = 3,
+ fallbacks = { 'buffer' },
+ opts = {
+ trailing_slash = false,
+ label_trailing_slash = true,
+ get_cwd = function(context) return vim.fn.expand(('#%d:p:h'):format(context.bufnr)) end,
+ show_hidden_files_by_default = false,
+ }
+ },
+ snippets = {
+ name = 'Snippets',
+ module = 'blink.cmp.sources.snippets',
+ opts = {
+ friendly_snippets = true,
+ search_paths = { vim.fn.stdpath('config') .. '/snippets' },
+ global_snippets = { 'all' },
+ extended_filetypes = {},
+ ignored_filetypes = {},
+ get_filetype = function(context)
+ return vim.bo.filetype
+ end
+ }
+ },
+ luasnip = {
+ name = 'Luasnip',
+ module = 'blink.cmp.sources.luasnip',
+ opts = {
+ -- Whether to use show_condition for filtering snippets
+ use_show_condition = true,
+ -- Whether to show autosnippets in the completion list
+ show_autosnippets = true,
+ }
+ },
+ buffer = {
+ name = 'Buffer',
+ module = 'blink.cmp.sources.buffer',
+ opts = {
+ -- default to all visible buffers
+ get_bufnrs = function()
+ return vim
+ .iter(vim.api.nvim_list_wins())
+ :map(function(win) return vim.api.nvim_win_get_buf(win) end)
+ :filter(function(buf) return vim.bo[buf].buftype ~= 'nofile' end)
+ :totable()
+ end,
+ }
+ },
+}
+```
+
+## Appearance
+
+```lua
+appearance = {
+ highlight_ns = vim.api.nvim_create_namespace('blink_cmp'),
+ -- Sets the fallback highlight groups to nvim-cmp's highlight groups
+ -- Useful for when your theme doesn't support blink.cmp
+ -- Will be removed in a future release
+ use_nvim_cmp_as_default = false,
+ -- Set to 'mono' for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
+ -- Adjusts spacing to ensure icons are aligned
+ nerd_font_variant = 'mono',
+ kind_icons = {
+ Text = '',
+ Method = '',
+ Function = '',
+ Constructor = '',
+
+ Field = '',
+ Variable = '',
+ Property = '',
+
+ Class = '',
+ Interface = '',
+ Struct = '',
+ Module = '',
+
+ Unit = '',
+ Value = '',
+ Enum = '',
+ EnumMember = '',
+
+ Keyword = '',
+ Constant = '',
+
+ Snippet = '',
+ Color = '',
+ File = '',
+ Reference = '',
+ Folder = '',
+ Event = '',
+ Operator = '',
+ TypeParameter = '',
+ },
+}
+```
diff --git a/docs/configuration/signature.md b/docs/configuration/signature.md
new file mode 100644
index 00000000..f9c39acf
--- /dev/null
+++ b/docs/configuration/signature.md
@@ -0,0 +1,13 @@
+# Signature
+
+> [!IMPORTANT]
+> This feature is *experimental*, contributions welcome!
+
+Blink supports signature help, automatically triggered when typing trigger characters, defined by the LSP, such as `(` for `lua`. The menu will be updated when pressing a retrigger character, such as `,`. Due to it being experimental, this feature is opt-in.
+
+```lua
+signature = { enabled = true }
+```
+
+
+
diff --git a/docs/configuration/snippets.md b/docs/configuration/snippets.md
new file mode 100644
index 00000000..b67bf83b
--- /dev/null
+++ b/docs/configuration/snippets.md
@@ -0,0 +1,109 @@
+# Snippets
+
+Blink uses the `vim.snippet` API by default for expanding and navigating snippets. The built-in `snippets` source will load [friendly-snippets](https://github.com/rafamadriz/friendly-snippets), if available, and load any snippets found at `~/.config/nvim/snippets/`. For use with Luasnip, see the [Luasnip section](#luasnip).
+
+## Custom snippets
+
+By default, the `snippets` source will check `~/.config/nvim/snippets` for your custom snippets, but you may add additional folders via `sources.providers.snippets.opts.search_paths`. Currently, only VSCode style snippets are supported, but you may look into [Luasnip](https://github.com/L3MON4D3/LuaSnip) if you'd like more advanced functionality.
+
+[Chris Grieser](https://github.com/chrisgrieser) has made a great introduction to writing custom snippets [in the nvim-scissors repo](https://github.com/chrisgrieser/nvim-scissors?tab=readme-ov-file#cookbook--faq). Here's an example, using the linux/mac path for the neovim configuration:
+
+```jsonc
+// ~/.config/nvim/snippets/package.json
+{
+ "name": "personal-snippets",
+ "contributes": {
+ "snippets": [
+ { "language": "lua", "path": "./lua.json" }
+ ]
+ }
+}
+```
+
+```jsonc
+// ~/.config/nvim/snippets/lua.json
+{
+ "foo": {
+ "prefix": "foo",
+ "body": [
+ "local ${1:foo} = ${2:bar}",
+ "return ${3:baz}"
+ ],
+ }
+}
+```
+
+## Luasnip
+
+```lua
+{
+ 'saghen/blink.cmp',
+ version = '*',
+ -- !Important! Make sure you're using the latest release of LuaSnip
+ -- `main` does not work at the moment
+ dependencies = { 'L3MON4D3/LuaSnip', version = 'v2.*' },
+ opts = {
+ snippets = {
+ expand = function(snippet) require('luasnip').lsp_expand(snippet) end,
+ active = function(filter)
+ if filter and filter.direction then
+ return require('luasnip').jumpable(filter.direction)
+ end
+ return require('luasnip').in_snippet()
+ end,
+ jump = function(direction) require('luasnip').jump(direction) end,
+ },
+ sources = {
+ default = { 'lsp', 'path', 'luasnip', 'buffer' },
+ },
+ }
+}
+```
+
+## Disable all snippets
+
+```lua
+sources.providers.transform_items = function(_, items)
+ return vim.tbl_filter(function(item)
+ return item.kind ~= require('blink.cmp.types').CompletionItemKind.Snippet
+ end, items)
+end
+```
+
+When setting up your capabilities with `lspconfig`, add the following:
+
+```lua
+capabilities = require('blink.cmp').get_lsp_capabilities({
+ textDocument = { completion = { completionItem = { snippetSupport = false } } },
+})
+```
+
+Some LSPs may ignore the `snippetSupport` field, in which case, you need to set LSP specific options while setting them up. Some examples:
+
+```lua
+-- If you're using `opts = { ['rust-analyzer'] = { } }` in your lspconfig configuration,
+-- simply put these options in there instead
+
+-- For `rust-analyzer`
+lspconfig['rust-analyzer'].setup({
+ completion = {
+ capable = {
+ snippets = 'add_parenthesis'
+ }
+ }
+})
+
+-- For `lua_ls`
+lspconfig.lua_ls.setup({
+ settings = {
+ Lua = {
+ completion = {
+ callSnippet = 'Disable',
+ keywordSnippet = 'Disable',
+ }
+ }
+ }
+})
+```
+
+Please open a PR if you know of any other LSPs that require special configuration!
diff --git a/docs/configuration/sources.md b/docs/configuration/sources.md
new file mode 100644
index 00000000..e1feb408
--- /dev/null
+++ b/docs/configuration/sources.md
@@ -0,0 +1,63 @@
+# Sources
+
+> [!NOTE]
+> Check out the [recipes](./recipes.md) for some common configurations
+
+Blink provides a sources interface, modelled after LSPs, for getting completion items, trigger characters, documentation and signature help. The `lsp`, `path`, `snippets`, `luasnip` and `buffer` sources are built-in. You may add additional [community sources](#community-sources) as well. Check out [writing sources](../development/writing-sources.md) to learn how to write your own!
+
+## Providers
+
+Sources are configured via the `sources.providers` table, where each `id` (`key`) must have a `name` and `module` field. The `id` (`key`) may be used in the `sources.default/per_filetype/cmdline` to enable the source.
+
+```lua
+sources = {
+ default = { 'lsp' },
+ providers = {
+ lsp = {
+ name = 'LSP',
+ module = 'blink.cmp.sources.lsp',
+ }
+ }
+}
+```
+
+### Provider options
+
+All of the fields shown below apply to all sources. The `opts` field is passed to the source directly, and will vary by source.
+
+```lua
+sources.providers.lsp = {
+ name = 'LSP',
+ module = 'blink.cmp.sources.lsp',
+ opts = {} -- Passed to the source directly, varies by source
+
+ --- NOTE: All of these options may be functions to get dynamic behavior
+ --- See the type definitions for more information
+ enabled = true, -- Whether or not to enable the provider
+ async = false, -- Whether we should wait for the provider to return before showing the completions
+ timeout_ms = 2000, -- How long to wait for the provider to return before showing completions and treating it as asynchronous
+ transform_items = nil, -- Function to transform the items before they're returned
+ should_show_items = true, -- Whether or not to show the items
+ max_items = nil, -- Maximum number of items to display in the menu
+ min_keyword_length = 0, -- Minimum number of characters in the keyword to trigger the provider
+ -- If this provider returns 0 items, it will fallback to these providers.
+ -- If multiple providers falback to the same provider, all of the providers must return 0 items for it to fallback
+ fallbacks = {},
+ score_offset = 0, -- Boost/penalize the score of the items
+ override = nil, -- Override the source's functions
+}
+```
+
+## Using `nvim-cmp` sources
+
+Blink can use `nvim-cmp` sources through a compatibility layer developed by [stefanboca](https://github.com/stefanboca): [blink.compat](https://github.com/Saghen/blink.compat). Please open any issues with `blink.compat` in that repo
+
+## Community sources
+
+- [lazydev](https://github.com/folke/lazydev.nvim)
+- [vim-dadbod-completion](https://github.com/kristijanhusak/vim-dadbod-completion)
+- [blink-ripgrep](https://github.com/mikavilpas/blink-ripgrep.nvim)
+- [blink-cmp-ripgrep](https://github.com/niuiic/blink-cmp-rg.nvim)
+- [blink-cmp-ctags](https://github.com/netmute/blink-cmp-ctags)
+- [blink-cmp-copilot](https://github.com/giuxtaposition/blink-cmp-copilot)
+- [minuet-ai.nvim](https://github.com/milanglacier/minuet-ai.nvim)
diff --git a/docs/development/architecture.md b/docs/development/architecture.md
new file mode 100644
index 00000000..9904897e
--- /dev/null
+++ b/docs/development/architecture.md
@@ -0,0 +1,9 @@
+# Architecture
+
+The plugin use a 4 stage pipeline: trigger -> sources -> fuzzy -> render
+1. **Trigger:** Controls when to request completion items from the sources and provides a context downstream with the current query (i.e. `hello.wo|`, the query would be `wo`) and the treesitter object under the cursor (i.e. for intelligently enabling/disabling sources). It respects trigger characters passed by the LSP (or any other source) and includes it in the context for sending to the LSP.
+2. **Sources:** Provides a common interface for and merges the results of completion, trigger character, resolution of additional information and cancellation. Some sources are builtin: `LSP`, `buffer`, `path`, `snippets`
+3. **Fuzzy:** Rust <-> Lua FFI which performs both filtering and sorting of the items
+ - **Filtering:** The fuzzy matching uses smith-waterman, same as FZF, but implemented in SIMD for ~6x the performance of FZF (TODO: add benchmarks). Due to the SIMD's performance, the prefiltering phase on FZF was dropped to allow for typos. Similar to fzy/fzf, additional points are given to prefix matches, characters with capitals (to promote camelCase/PascalCase first char matching) and matches after delimiters (to promote snake_case first char matching)
+ - **Sorting:** Combines fuzzy matching score with frecency and proximity bonus. Each completion item may also include a `score_offset` which will be added to this score to demote certain sources. The `snippets` source takes advantage of this to avoid taking precedence over the LSP source. The parameters here still need to be tuned, so please let me know if you find some magical parameters!
+4. **Windows:** Responsible for placing the menu, documentation and function parameters windows. All of the rendering can be overridden following a syntax similar to incline.nvim. It uses the neovim window decoration provider to provide next to no overhead from highlighting.
diff --git a/LSP_TRACKER.md b/docs/development/lsp-tracker.md
similarity index 98%
rename from LSP_TRACKER.md
rename to docs/development/lsp-tracker.md
index a966487a..5f694170 100644
--- a/LSP_TRACKER.md
+++ b/docs/development/lsp-tracker.md
@@ -56,7 +56,7 @@
- [x] `documentation` <- both string and markup content
- [x] `deprecated`
- [ ] `preselect`
-- [ ] `sortText`
+- [x] `sortText`
- [x] `filterText`
- [x] `insertText`
- [x] `insertTextFormat` <- regular or snippet
diff --git a/docs/development/writing-sources.md b/docs/development/writing-sources.md
new file mode 100644
index 00000000..81048e9e
--- /dev/null
+++ b/docs/development/writing-sources.md
@@ -0,0 +1,3 @@
+# Writing Sources
+
+TODO
diff --git a/docs/favicon.png b/docs/favicon.png
new file mode 100644
index 00000000..d40a3969
Binary files /dev/null and b/docs/favicon.png differ
diff --git a/docs/index.md b/docs/index.md
new file mode 100644
index 00000000..1caffd83
--- /dev/null
+++ b/docs/index.md
@@ -0,0 +1,47 @@
+# Blink Completion (blink.cmp)
+
+> [!IMPORTANT]
+> This plugin is *beta* quality. Expect breaking changes and many bugs
+
+**blink.cmp** is a completion plugin with support for LSPs and external sources that updates on every keystroke with minimal overhead (0.5-4ms async). It use a [custom SIMD fuzzy searcher](https://github.com/saghen/frizbee) to easily handle >20k items. It provides extensibility via hooks into the trigger, sources and rendering pipeline. Plenty of work has been put into making each stage of the pipeline as intelligent as possible, such as frecency and proximity bonus on fuzzy matching, and this work is on-going.
+
+
+
+## Features
+
+- Works out of the box with no additional configuration
+- Updates on every keystroke (0.5-4ms async, single core)
+- [Typo resistant fuzzy](https://github.com/saghen/frizbee) with frecency and proximity bonus
+- Extensive LSP support ([tracker](./development/lsp-tracker.md))
+- Native `vim.snippet` support (including `friendly-snippets`)
+- External sources support ([compatibility layer for `nvim-cmp` sources](https://github.com/Saghen/blink.compat))
+- Auto-bracket support based on semantic tokens
+- Signature help (experimental, opt-in)
+
+## Special Thanks
+
+- [@hrsh7th](https://github.com/hrsh7th/) nvim-cmp used as inspiration and cmp-path/cmp-cmdline implementations modified for path/cmdline sources
+- [@garymjr](https://github.com/garymjr) nvim-snippets implementation modified for snippets source
+- [@redxtech](https://github.com/redxtech) Help with design and testing
+- [@aaditya-sahay](https://github.com/aaditya-sahay) Help with rust, design and testing
+
+### Contributors
+
+- [@stefanboca](https://github.com/stefanboca) Author of [blink.compat](https://github.com/saghen/blink.compat)
+- [@lopi-py](https://github.com/lopi-py) Contributes to the windowing code
+- [@scottmckendry](https://github.com/scottmckendry) Contributes to the CI and prebuilt binaries
+- [@balssh](https://github.com/Balssh) Manages nixpkg and nixvim
+
+## Compared to nvim-cmp
+
+- Avoids the complexity of nvim-cmp's configuration by providing sensible defaults
+- Updates on every keystroke with 0.5-4ms of overhead, versus nvim-cmp's default debounce of 60ms with 2-50ms hitches from processing
+ - Setting nvim-cmp's debounce to 0ms leads to visible stuttering. If you'd like to stick with nvim-cmp, try [yioneko's fork](https://github.com/yioneko/nvim-cmp) or the more recent [magazine.nvim](https://github.com/iguanacucumber/magazine.nvim)
+- Boosts completion item score via frecency _and_ proximity bonus. nvim-cmp boosts score via proximity bonus and optionally by recency
+- Typo-resistant fuzzy matching unlike nvim-cmp's fzf-style fuzzy matching
+- Core sources (buffer, snippets, path, lsp) are built-in versus nvim-cmp's exclusively external sources
+- Built-in auto bracket and signature help support
+
+### Planned missing features
+
+- Significantly more testing and documentation
diff --git a/docs/installation.md b/docs/installation.md
new file mode 100644
index 00000000..1f50dca8
--- /dev/null
+++ b/docs/installation.md
@@ -0,0 +1,132 @@
+# Installation
+
+> [!IMPORTANT]
+> Blink uses a prebuilt binary for the fuzzy matcher which will be downloaded automatically when on a tag.
+> You may build from source with rust nightly. See the [fuzzy documentation](./configuration/fuzzy.md) for more information.
+
+## Requirements
+
+- Neovim 0.10+
+- Using prebuilt binaries:
+ - curl
+ - git
+- Building from source:
+ - Rust nightly or [rustup](https://rustup.rs/)
+
+## `lazy.nvim`
+
+```lua
+{
+ 'saghen/blink.cmp',
+ -- optional: provides snippets for the snippet source
+ dependencies = 'rafamadriz/friendly-snippets',
+
+ -- use a release tag to download pre-built binaries
+ version = '*',
+ -- AND/OR build from source, requires nightly: https://rust-lang.github.io/rustup/concepts/channels.html#working-with-nightly-rust
+ -- build = 'cargo build --release',
+ -- If you use nix, you can build from source using latest nightly rust with:
+ -- build = 'nix run .#build-plugin',
+
+ ---@module 'blink.cmp'
+ ---@type blink.cmp.Config
+ opts = {
+ -- 'default' for mappings similar to built-in completion
+ -- 'super-tab' for mappings similar to vscode (tab to accept, arrow keys to navigate)
+ -- 'enter' for mappings similar to 'super-tab' but with 'enter' to accept
+ -- See the full "keymap" documentation for information on defining your own keymap.
+ keymap = { preset = 'default' },
+
+ appearance = {
+ -- Sets the fallback highlight groups to nvim-cmp's highlight groups
+ -- Useful for when your theme doesn't support blink.cmp
+ -- Will be removed in a future release
+ use_nvim_cmp_as_default = true,
+ -- Set to 'mono' for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
+ -- Adjusts spacing to ensure icons are aligned
+ nerd_font_variant = 'mono'
+ },
+
+ -- Default list of enabled providers defined so that you can extend it
+ -- elsewhere in your config, without redefining it, due to `opts_extend`
+ sources = {
+ default = { 'lsp', 'path', 'snippets', 'buffer' },
+ },
+ },
+ opts_extend = { "sources.default" }
+}
+```
+
+Setting capabilities for `nvim-lspconfig`:
+
+```lua
+-- LSP servers and clients communicate which features they support through "capabilities".
+-- By default, Neovim supports a subset of the LSP specification.
+-- With blink.cmp, Neovim has *more* capabilities which are communicated to the LSP servers.
+-- Explanation from TJ: https://youtu.be/m8C0Cq9Uv9o?t=1275
+--
+-- This can vary by config, but in general for nvim-lspconfig:
+
+{
+ 'neovim/nvim-lspconfig',
+ dependencies = { 'saghen/blink.cmp' },
+
+ -- example using `opts` for defining servers
+ opts = {
+ servers = {
+ lua_ls = {}
+ }
+ },
+ config = function(_, opts)
+ local lspconfig = require('lspconfig')
+ for server, config in pairs(opts.servers) do
+ -- passing config.capabilities to blink.cmp merges with the capabilities in your
+ -- `opts[server].capabilities, if you've defined it
+ config.capabilities = require('blink.cmp').get_lsp_capabilities(config.capabilities)
+ lspconfig[server].setup(config)
+ end
+ end
+
+ -- example calling setup directly for each LSP
+ config = function()
+ local capabilities = require('blink.cmp').get_lsp_capabilities()
+ local lspconfig = require('lspconfig')
+
+ lspconfig['lua-ls'].setup({ capabilities = capabilities })
+ end
+}
+```
+
+## `mini.deps`
+
+The following section includes only the installation and, optionally, building of the fuzzy matcher. Check the [lazy.nvim](#lazy.nvim) section for recommended configuration options and setting up `nvim-lspconfig`.
+
+```lua
+-- use a release tag to download pre-built binaries
+MiniDeps.add({
+ source = "saghen/blink.cmp",
+ depends = {
+ "rafamadriz/friendly-snippets",
+ },
+ checkout = "some.version", -- check releases for latest tag
+})
+
+-- OR build from source, requires nightly: https://rust-lang.github.io/rustup/concepts/channels.html#working-with-nightly-rust
+local function build_blink(params)
+ vim.notify('Building blink.cmp', vim.log.levels.INFO)
+ local obj = vim.system({ 'cargo', 'build', '--release' }, { cwd = params.path }):wait()
+ if obj.code == 0 then
+ vim.notify('Building blink.cmp done', vim.log.levels.INFO)
+ else
+ vim.notify('Building blink.cmp failed', vim.log.levels.ERROR)
+ end
+end
+
+MiniDeps.add({
+ source = 'Saghen/blink.cmp',
+ hooks = {
+ post_install = build_blink,
+ post_checkout = build_blink,
+ },
+})
+```
diff --git a/docs/package-lock.json b/docs/package-lock.json
new file mode 100644
index 00000000..619e23b9
--- /dev/null
+++ b/docs/package-lock.json
@@ -0,0 +1,2499 @@
+{
+ "name": "docs",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "devDependencies": {
+ "@catppuccin/vitepress": "^0.1.0",
+ "vitepress": "^1.5.0",
+ "vitepress-plugin-tabs": "^0.5.0"
+ }
+ },
+ "node_modules/@algolia/autocomplete-core": {
+ "version": "1.17.7",
+ "resolved": "https://registry.npmjs.org/@algolia/autocomplete-core/-/autocomplete-core-1.17.7.tgz",
+ "integrity": "sha512-BjiPOW6ks90UKl7TwMv7oNQMnzU+t/wk9mgIDi6b1tXpUek7MW0lbNOUHpvam9pe3lVCf4xPFT+lK7s+e+fs7Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/autocomplete-plugin-algolia-insights": "1.17.7",
+ "@algolia/autocomplete-shared": "1.17.7"
+ }
+ },
+ "node_modules/@algolia/autocomplete-plugin-algolia-insights": {
+ "version": "1.17.7",
+ "resolved": "https://registry.npmjs.org/@algolia/autocomplete-plugin-algolia-insights/-/autocomplete-plugin-algolia-insights-1.17.7.tgz",
+ "integrity": "sha512-Jca5Ude6yUOuyzjnz57og7Et3aXjbwCSDf/8onLHSQgw1qW3ALl9mrMWaXb5FmPVkV3EtkD2F/+NkT6VHyPu9A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/autocomplete-shared": "1.17.7"
+ },
+ "peerDependencies": {
+ "search-insights": ">= 1 < 3"
+ }
+ },
+ "node_modules/@algolia/autocomplete-preset-algolia": {
+ "version": "1.17.7",
+ "resolved": "https://registry.npmjs.org/@algolia/autocomplete-preset-algolia/-/autocomplete-preset-algolia-1.17.7.tgz",
+ "integrity": "sha512-ggOQ950+nwbWROq2MOCIL71RE0DdQZsceqrg32UqnhDz8FlO9rL8ONHNsI2R1MH0tkgVIDKI/D0sMiUchsFdWA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/autocomplete-shared": "1.17.7"
+ },
+ "peerDependencies": {
+ "@algolia/client-search": ">= 4.9.1 < 6",
+ "algoliasearch": ">= 4.9.1 < 6"
+ }
+ },
+ "node_modules/@algolia/autocomplete-shared": {
+ "version": "1.17.7",
+ "resolved": "https://registry.npmjs.org/@algolia/autocomplete-shared/-/autocomplete-shared-1.17.7.tgz",
+ "integrity": "sha512-o/1Vurr42U/qskRSuhBH+VKxMvkkUVTLU6WZQr+L5lGZZLYWyhdzWjW0iGXY7EkwRTjBqvN2EsR81yCTGV/kmg==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "@algolia/client-search": ">= 4.9.1 < 6",
+ "algoliasearch": ">= 4.9.1 < 6"
+ }
+ },
+ "node_modules/@algolia/client-abtesting": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-abtesting/-/client-abtesting-5.18.0.tgz",
+ "integrity": "sha512-DLIrAukjsSrdMNNDx1ZTks72o4RH/1kOn8Wx5zZm8nnqFexG+JzY4SANnCNEjnFQPJTTvC+KpgiNW/CP2lumng==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/client-analytics": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-analytics/-/client-analytics-5.18.0.tgz",
+ "integrity": "sha512-0VpGG2uQW+h2aejxbG8VbnMCQ9ary9/ot7OASXi6OjE0SRkYQ/+pkW+q09+IScif3pmsVVYggmlMPtAsmYWHng==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/client-common": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-common/-/client-common-5.18.0.tgz",
+ "integrity": "sha512-X1WMSC+1ve2qlMsemyTF5bIjwipOT+m99Ng1Tyl36ZjQKTa54oajBKE0BrmM8LD8jGdtukAgkUhFoYOaRbMcmQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/client-insights": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-insights/-/client-insights-5.18.0.tgz",
+ "integrity": "sha512-FAJRNANUOSs/FgYOJ/Njqp+YTe4TMz2GkeZtfsw1TMiA5mVNRS/nnMpxas9771aJz7KTEWvK9GwqPs0K6RMYWg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/client-personalization": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-personalization/-/client-personalization-5.18.0.tgz",
+ "integrity": "sha512-I2dc94Oiwic3SEbrRp8kvTZtYpJjGtg5y5XnqubgnA15AgX59YIY8frKsFG8SOH1n2rIhUClcuDkxYQNXJLg+w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/client-query-suggestions": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-query-suggestions/-/client-query-suggestions-5.18.0.tgz",
+ "integrity": "sha512-x6XKIQgKFTgK/bMasXhghoEjHhmgoP61pFPb9+TaUJ32aKOGc65b12usiGJ9A84yS73UDkXS452NjyP50Knh/g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/client-search": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/client-search/-/client-search-5.18.0.tgz",
+ "integrity": "sha512-qI3LcFsVgtvpsBGR7aNSJYxhsR+Zl46+958ODzg8aCxIcdxiK7QEVLMJMZAR57jGqW0Lg/vrjtuLFDMfSE53qA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/ingestion": {
+ "version": "1.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/ingestion/-/ingestion-1.18.0.tgz",
+ "integrity": "sha512-bGvJg7HnGGm+XWYMDruZXWgMDPVt4yCbBqq8DM6EoaMBK71SYC4WMfIdJaw+ABqttjBhe6aKNRkWf/bbvYOGyw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/monitoring": {
+ "version": "1.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/monitoring/-/monitoring-1.18.0.tgz",
+ "integrity": "sha512-lBssglINIeGIR+8KyzH05NAgAmn1BCrm5D2T6pMtr/8kbTHvvrm1Zvcltc5dKUQEFyyx3J5+MhNc7kfi8LdjVw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/recommend": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/recommend/-/recommend-5.18.0.tgz",
+ "integrity": "sha512-uSnkm0cdAuFwdMp4pGT5vHVQ84T6AYpTZ3I0b3k/M3wg4zXDhl3aCiY8NzokEyRLezz/kHLEEcgb/tTTobOYVw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/requester-browser-xhr": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/requester-browser-xhr/-/requester-browser-xhr-5.18.0.tgz",
+ "integrity": "sha512-1XFjW0C3pV0dS/9zXbV44cKI+QM4ZIz9cpatXpsjRlq6SUCpLID3DZHsXyE6sTb8IhyPaUjk78GEJT8/3hviqg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/requester-fetch": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/requester-fetch/-/requester-fetch-5.18.0.tgz",
+ "integrity": "sha512-0uodeNdAHz1YbzJh6C5xeQ4T6x5WGiUxUq3GOaT/R4njh5t78dq+Rb187elr7KtnjUmETVVuCvmEYaThfTHzNg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@algolia/requester-node-http": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/@algolia/requester-node-http/-/requester-node-http-5.18.0.tgz",
+ "integrity": "sha512-tZCqDrqJ2YE2I5ukCQrYN8oiF6u3JIdCxrtKq+eniuLkjkO78TKRnXrVcKZTmfFJyyDK8q47SfDcHzAA3nHi6w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-common": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz",
+ "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz",
+ "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.26.3",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.3.tgz",
+ "integrity": "sha512-WJ/CvmY8Mea8iDXo6a7RK2wbmJITT5fN3BEkRuFlxVyNx8jOKIIhmC4fSkTcPcf8JyavbBwIe6OpiCOBXt/IcA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.26.3"
+ },
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.26.3",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.3.tgz",
+ "integrity": "sha512-vN5p+1kl59GVKMvTHt55NzzmYVxprfJD+ql7U9NFIfKCBkYE55LYtS+WtPlaYOyzydrKI8Nezd+aZextrd+FMA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.25.9",
+ "@babel/helper-validator-identifier": "^7.25.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@catppuccin/vitepress": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/@catppuccin/vitepress/-/vitepress-0.1.0.tgz",
+ "integrity": "sha512-HJilKL8dzidGWwDBNcGVzDmjHocwhaxQ0tleRf0/Aab7MDCHK63jzoYHifXro6mH+AtK120WHfsHiJl54sSaww==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "typescript": "^5.0.0"
+ }
+ },
+ "node_modules/@docsearch/css": {
+ "version": "3.8.2",
+ "resolved": "https://registry.npmjs.org/@docsearch/css/-/css-3.8.2.tgz",
+ "integrity": "sha512-y05ayQFyUmCXze79+56v/4HpycYF3uFqB78pLPrSV5ZKAlDuIAAJNhaRi8tTdRNXh05yxX/TyNnzD6LwSM89vQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@docsearch/js": {
+ "version": "3.8.2",
+ "resolved": "https://registry.npmjs.org/@docsearch/js/-/js-3.8.2.tgz",
+ "integrity": "sha512-Q5wY66qHn0SwA7Taa0aDbHiJvaFJLOJyHmooQ7y8hlwwQLQ/5WwCcoX0g7ii04Qi2DJlHsd0XXzJ8Ypw9+9YmQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@docsearch/react": "3.8.2",
+ "preact": "^10.0.0"
+ }
+ },
+ "node_modules/@docsearch/react": {
+ "version": "3.8.2",
+ "resolved": "https://registry.npmjs.org/@docsearch/react/-/react-3.8.2.tgz",
+ "integrity": "sha512-xCRrJQlTt8N9GU0DG4ptwHRkfnSnD/YpdeaXe02iKfqs97TkZJv60yE+1eq/tjPcVnTW8dP5qLP7itifFVV5eg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/autocomplete-core": "1.17.7",
+ "@algolia/autocomplete-preset-algolia": "1.17.7",
+ "@docsearch/css": "3.8.2",
+ "algoliasearch": "^5.14.2"
+ },
+ "peerDependencies": {
+ "@types/react": ">= 16.8.0 < 19.0.0",
+ "react": ">= 16.8.0 < 19.0.0",
+ "react-dom": ">= 16.8.0 < 19.0.0",
+ "search-insights": ">= 1 < 3"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ },
+ "react": {
+ "optional": true
+ },
+ "react-dom": {
+ "optional": true
+ },
+ "search-insights": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@esbuild/aix-ppc64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz",
+ "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "aix"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz",
+ "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz",
+ "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz",
+ "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-arm64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz",
+ "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz",
+ "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-arm64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz",
+ "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz",
+ "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz",
+ "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz",
+ "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ia32": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz",
+ "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-loong64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz",
+ "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==",
+ "cpu": [
+ "loong64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-mips64el": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz",
+ "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==",
+ "cpu": [
+ "mips64el"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ppc64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz",
+ "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-riscv64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz",
+ "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-s390x": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz",
+ "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==",
+ "cpu": [
+ "s390x"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz",
+ "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/netbsd-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz",
+ "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "netbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/openbsd-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz",
+ "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "openbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/sunos-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz",
+ "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "sunos"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-arm64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz",
+ "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-ia32": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz",
+ "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-x64": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz",
+ "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@iconify-json/simple-icons": {
+ "version": "1.2.16",
+ "resolved": "https://registry.npmjs.org/@iconify-json/simple-icons/-/simple-icons-1.2.16.tgz",
+ "integrity": "sha512-mnQ0Ih8CDIgOqbi0qz01AJNOeFVuGFRimelg3JmJtD0y5EpZVw+enPPcpcxJKipsRZ/oqhcP3AhYkF1kM7yomg==",
+ "dev": true,
+ "license": "CC0-1.0",
+ "dependencies": {
+ "@iconify/types": "*"
+ }
+ },
+ "node_modules/@iconify/types": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/@iconify/types/-/types-2.0.0.tgz",
+ "integrity": "sha512-+wluvCrRhXrhyOmRDJ3q8mux9JkKy5SJ/v8ol2tu4FVjyYvtEzkc/3pK15ET6RKg4b4w4BmTk1+gsCUhf21Ykg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz",
+ "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@rollup/rollup-android-arm-eabi": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.28.1.tgz",
+ "integrity": "sha512-2aZp8AES04KI2dy3Ss6/MDjXbwBzj+i0GqKtWXgw2/Ma6E4jJvujryO6gJAghIRVz7Vwr9Gtl/8na3nDUKpraQ==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ]
+ },
+ "node_modules/@rollup/rollup-android-arm64": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.28.1.tgz",
+ "integrity": "sha512-EbkK285O+1YMrg57xVA+Dp0tDBRB93/BZKph9XhMjezf6F4TpYjaUSuPt5J0fZXlSag0LmZAsTmdGGqPp4pQFA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ]
+ },
+ "node_modules/@rollup/rollup-darwin-arm64": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.28.1.tgz",
+ "integrity": "sha512-prduvrMKU6NzMq6nxzQw445zXgaDBbMQvmKSJaxpaZ5R1QDM8w+eGxo6Y/jhT/cLoCvnZI42oEqf9KQNYz1fqQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ]
+ },
+ "node_modules/@rollup/rollup-darwin-x64": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.28.1.tgz",
+ "integrity": "sha512-WsvbOunsUk0wccO/TV4o7IKgloJ942hVFK1CLatwv6TJspcCZb9umQkPdvB7FihmdxgaKR5JyxDjWpCOp4uZlQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ]
+ },
+ "node_modules/@rollup/rollup-freebsd-arm64": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.28.1.tgz",
+ "integrity": "sha512-HTDPdY1caUcU4qK23FeeGxCdJF64cKkqajU0iBnTVxS8F7H/7BewvYoG+va1KPSL63kQ1PGNyiwKOfReavzvNA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ]
+ },
+ "node_modules/@rollup/rollup-freebsd-x64": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.28.1.tgz",
+ "integrity": "sha512-m/uYasxkUevcFTeRSM9TeLyPe2QDuqtjkeoTpP9SW0XxUWfcYrGDMkO/m2tTw+4NMAF9P2fU3Mw4ahNvo7QmsQ==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm-gnueabihf": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.28.1.tgz",
+ "integrity": "sha512-QAg11ZIt6mcmzpNE6JZBpKfJaKkqTm1A9+y9O+frdZJEuhQxiugM05gnCWiANHj4RmbgeVJpTdmKRmH/a+0QbA==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm-musleabihf": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.28.1.tgz",
+ "integrity": "sha512-dRP9PEBfolq1dmMcFqbEPSd9VlRuVWEGSmbxVEfiq2cs2jlZAl0YNxFzAQS2OrQmsLBLAATDMb3Z6MFv5vOcXg==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm64-gnu": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.28.1.tgz",
+ "integrity": "sha512-uGr8khxO+CKT4XU8ZUH1TTEUtlktK6Kgtv0+6bIFSeiSlnGJHG1tSFSjm41uQ9sAO/5ULx9mWOz70jYLyv1QkA==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-arm64-musl": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.28.1.tgz",
+ "integrity": "sha512-QF54q8MYGAqMLrX2t7tNpi01nvq5RI59UBNx+3+37zoKX5KViPo/gk2QLhsuqok05sSCRluj0D00LzCwBikb0A==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-loongarch64-gnu": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.28.1.tgz",
+ "integrity": "sha512-vPul4uodvWvLhRco2w0GcyZcdyBfpfDRgNKU+p35AWEbJ/HPs1tOUrkSueVbBS0RQHAf/A+nNtDpvw95PeVKOA==",
+ "cpu": [
+ "loong64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-powerpc64le-gnu": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.28.1.tgz",
+ "integrity": "sha512-pTnTdBuC2+pt1Rmm2SV7JWRqzhYpEILML4PKODqLz+C7Ou2apEV52h19CR7es+u04KlqplggmN9sqZlekg3R1A==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-riscv64-gnu": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.28.1.tgz",
+ "integrity": "sha512-vWXy1Nfg7TPBSuAncfInmAI/WZDd5vOklyLJDdIRKABcZWojNDY0NJwruY2AcnCLnRJKSaBgf/GiJfauu8cQZA==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-s390x-gnu": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.28.1.tgz",
+ "integrity": "sha512-/yqC2Y53oZjb0yz8PVuGOQQNOTwxcizudunl/tFs1aLvObTclTwZ0JhXF2XcPT/zuaymemCDSuuUPXJJyqeDOg==",
+ "cpu": [
+ "s390x"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-x64-gnu": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.28.1.tgz",
+ "integrity": "sha512-fzgeABz7rrAlKYB0y2kSEiURrI0691CSL0+KXwKwhxvj92VULEDQLpBYLHpF49MSiPG4sq5CK3qHMnb9tlCjBw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-linux-x64-musl": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.28.1.tgz",
+ "integrity": "sha512-xQTDVzSGiMlSshpJCtudbWyRfLaNiVPXt1WgdWTwWz9n0U12cI2ZVtWe/Jgwyv/6wjL7b66uu61Vg0POWVfz4g==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ]
+ },
+ "node_modules/@rollup/rollup-win32-arm64-msvc": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.28.1.tgz",
+ "integrity": "sha512-wSXmDRVupJstFP7elGMgv+2HqXelQhuNf+IS4V+nUpNVi/GUiBgDmfwD0UGN3pcAnWsgKG3I52wMOBnk1VHr/A==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ]
+ },
+ "node_modules/@rollup/rollup-win32-ia32-msvc": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.28.1.tgz",
+ "integrity": "sha512-ZkyTJ/9vkgrE/Rk9vhMXhf8l9D+eAhbAVbsGsXKy2ohmJaWg0LPQLnIxRdRp/bKyr8tXuPlXhIoGlEB5XpJnGA==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ]
+ },
+ "node_modules/@rollup/rollup-win32-x64-msvc": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.28.1.tgz",
+ "integrity": "sha512-ZvK2jBafvttJjoIdKm/Q/Bh7IJ1Ose9IBOwpOXcOvW3ikGTQGmKDgxTC6oCAzW6PynbkKP8+um1du81XJHZ0JA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ]
+ },
+ "node_modules/@shikijs/core": {
+ "version": "1.24.3",
+ "resolved": "https://registry.npmjs.org/@shikijs/core/-/core-1.24.3.tgz",
+ "integrity": "sha512-VRcf4GYUIkxIchGM9DrapRcxtgojg4IWKUtX5EtW+4PJiGzF2xQqZSv27PJt+WLc18KT3CNLpNWow9JYV5n+Rg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@shikijs/engine-javascript": "1.24.3",
+ "@shikijs/engine-oniguruma": "1.24.3",
+ "@shikijs/types": "1.24.3",
+ "@shikijs/vscode-textmate": "^9.3.1",
+ "@types/hast": "^3.0.4",
+ "hast-util-to-html": "^9.0.4"
+ }
+ },
+ "node_modules/@shikijs/engine-javascript": {
+ "version": "1.24.3",
+ "resolved": "https://registry.npmjs.org/@shikijs/engine-javascript/-/engine-javascript-1.24.3.tgz",
+ "integrity": "sha512-De8tNLvYjeK6V0Gb47jIH2M+OKkw+lWnSV1j3HVDFMlNIglmVcTMG2fASc29W0zuFbfEEwKjO8Fe4KYSO6Ce3w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@shikijs/types": "1.24.3",
+ "@shikijs/vscode-textmate": "^9.3.1",
+ "oniguruma-to-es": "0.8.0"
+ }
+ },
+ "node_modules/@shikijs/engine-oniguruma": {
+ "version": "1.24.3",
+ "resolved": "https://registry.npmjs.org/@shikijs/engine-oniguruma/-/engine-oniguruma-1.24.3.tgz",
+ "integrity": "sha512-iNnx950gs/5Nk+zrp1LuF+S+L7SKEhn8k9eXgFYPGhVshKppsYwRmW8tpmAMvILIMSDfrgqZ0w+3xWVQB//1Xw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@shikijs/types": "1.24.3",
+ "@shikijs/vscode-textmate": "^9.3.1"
+ }
+ },
+ "node_modules/@shikijs/transformers": {
+ "version": "1.24.3",
+ "resolved": "https://registry.npmjs.org/@shikijs/transformers/-/transformers-1.24.3.tgz",
+ "integrity": "sha512-Zdu+pVZwQkUy/KWIVJFQlSqZGvPySU6oYZ2TsBKp3Ay5m1XzykPSeiaVvAh6LtyaXYDLeCdA3LjZfHyTXFjGTw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "shiki": "1.24.3"
+ }
+ },
+ "node_modules/@shikijs/types": {
+ "version": "1.24.3",
+ "resolved": "https://registry.npmjs.org/@shikijs/types/-/types-1.24.3.tgz",
+ "integrity": "sha512-FPMrJ69MNxhRtldRk69CghvaGlbbN3pKRuvko0zvbfa2dXp4pAngByToqS5OY5jvN8D7LKR4RJE8UvzlCOuViw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@shikijs/vscode-textmate": "^9.3.1",
+ "@types/hast": "^3.0.4"
+ }
+ },
+ "node_modules/@shikijs/vscode-textmate": {
+ "version": "9.3.1",
+ "resolved": "https://registry.npmjs.org/@shikijs/vscode-textmate/-/vscode-textmate-9.3.1.tgz",
+ "integrity": "sha512-79QfK1393x9Ho60QFyLti+QfdJzRQCVLFb97kOIV7Eo9vQU/roINgk7m24uv0a7AUvN//RDH36FLjjK48v0s9g==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/estree": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz",
+ "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/hast": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/@types/hast/-/hast-3.0.4.tgz",
+ "integrity": "sha512-WPs+bbQw5aCj+x6laNGWLH3wviHtoCv/P3+otBhbOhJgG8qtpdAMlTCxLtsTWA7LH1Oh/bFCHsBn0TPS5m30EQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "*"
+ }
+ },
+ "node_modules/@types/linkify-it": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/@types/linkify-it/-/linkify-it-5.0.0.tgz",
+ "integrity": "sha512-sVDA58zAw4eWAffKOaQH5/5j3XeayukzDk+ewSsnv3p4yJEZHCCzMDiZM8e0OUrRvmpGZ85jf4yDHkHsgBNr9Q==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/markdown-it": {
+ "version": "14.1.2",
+ "resolved": "https://registry.npmjs.org/@types/markdown-it/-/markdown-it-14.1.2.tgz",
+ "integrity": "sha512-promo4eFwuiW+TfGxhi+0x3czqTYJkG8qB17ZUJiVF10Xm7NLVRSLUsfRTU/6h1e24VvRnXCx+hG7li58lkzog==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/linkify-it": "^5",
+ "@types/mdurl": "^2"
+ }
+ },
+ "node_modules/@types/mdast": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-4.0.4.tgz",
+ "integrity": "sha512-kGaNbPh1k7AFzgpud/gMdvIm5xuECykRR+JnWKQno9TAXVa6WIVCGTPvYGekIDL4uwCZQSYbUxNBSb1aUo79oA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "*"
+ }
+ },
+ "node_modules/@types/mdurl": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/@types/mdurl/-/mdurl-2.0.0.tgz",
+ "integrity": "sha512-RGdgjQUZba5p6QEFAVx2OGb8rQDL/cPRG7GiedRzMcJ1tYnUANBncjbSB1NRGwbvjcPeikRABz2nshyPk1bhWg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/unist": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/@types/unist/-/unist-3.0.3.tgz",
+ "integrity": "sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/web-bluetooth": {
+ "version": "0.0.20",
+ "resolved": "https://registry.npmjs.org/@types/web-bluetooth/-/web-bluetooth-0.0.20.tgz",
+ "integrity": "sha512-g9gZnnXVq7gM7v3tJCWV/qw7w+KeOlSHAhgF9RytFyifW6AF61hdT2ucrYhPq9hLs5JIryeupHV3qGk95dH9ow==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@ungap/structured-clone": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.1.tgz",
+ "integrity": "sha512-fEzPV3hSkSMltkw152tJKNARhOupqbH96MZWyRjNaYZOMIzbrTeQDG+MTc6Mr2pgzFQzFxAfmhGDNP5QK++2ZA==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/@vitejs/plugin-vue": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/@vitejs/plugin-vue/-/plugin-vue-5.2.1.tgz",
+ "integrity": "sha512-cxh314tzaWwOLqVes2gnnCtvBDcM1UMdn+iFR+UjAn411dPT3tOmqrJjbMd7koZpMAmBM/GqeV4n9ge7JSiJJQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^18.0.0 || >=20.0.0"
+ },
+ "peerDependencies": {
+ "vite": "^5.0.0 || ^6.0.0",
+ "vue": "^3.2.25"
+ }
+ },
+ "node_modules/@vue/compiler-core": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.5.13.tgz",
+ "integrity": "sha512-oOdAkwqUfW1WqpwSYJce06wvt6HljgY3fGeM9NcVA1HaYOij3mZG9Rkysn0OHuyUAGMbEbARIpsG+LPVlBJ5/Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.25.3",
+ "@vue/shared": "3.5.13",
+ "entities": "^4.5.0",
+ "estree-walker": "^2.0.2",
+ "source-map-js": "^1.2.0"
+ }
+ },
+ "node_modules/@vue/compiler-dom": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.5.13.tgz",
+ "integrity": "sha512-ZOJ46sMOKUjO3e94wPdCzQ6P1Lx/vhp2RSvfaab88Ajexs0AHeV0uasYhi99WPaogmBlRHNRuly8xV75cNTMDA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-core": "3.5.13",
+ "@vue/shared": "3.5.13"
+ }
+ },
+ "node_modules/@vue/compiler-sfc": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.5.13.tgz",
+ "integrity": "sha512-6VdaljMpD82w6c2749Zhf5T9u5uLBWKnVue6XWxprDobftnletJ8+oel7sexFfM3qIxNmVE7LSFGTpv6obNyaQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.25.3",
+ "@vue/compiler-core": "3.5.13",
+ "@vue/compiler-dom": "3.5.13",
+ "@vue/compiler-ssr": "3.5.13",
+ "@vue/shared": "3.5.13",
+ "estree-walker": "^2.0.2",
+ "magic-string": "^0.30.11",
+ "postcss": "^8.4.48",
+ "source-map-js": "^1.2.0"
+ }
+ },
+ "node_modules/@vue/compiler-ssr": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.5.13.tgz",
+ "integrity": "sha512-wMH6vrYHxQl/IybKJagqbquvxpWCuVYpoUJfCqFZwa/JY1GdATAQ+TgVtgrwwMZ0D07QhA99rs/EAAWfvG6KpA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-dom": "3.5.13",
+ "@vue/shared": "3.5.13"
+ }
+ },
+ "node_modules/@vue/devtools-api": {
+ "version": "7.6.8",
+ "resolved": "https://registry.npmjs.org/@vue/devtools-api/-/devtools-api-7.6.8.tgz",
+ "integrity": "sha512-ma6dY/sZR36zALVsV1W7eC57c6IJPXsy8SNgZn1PLVWU4z4dPn5TIBmnF4stmdJ4sQcixqKaQ8pwjbMPzEZwiA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/devtools-kit": "^7.6.8"
+ }
+ },
+ "node_modules/@vue/devtools-kit": {
+ "version": "7.6.8",
+ "resolved": "https://registry.npmjs.org/@vue/devtools-kit/-/devtools-kit-7.6.8.tgz",
+ "integrity": "sha512-JhJ8M3sPU+v0P2iZBF2DkdmR9L0dnT5RXJabJqX6o8KtFs3tebdvfoXV2Dm3BFuqeECuMJIfF1aCzSt+WQ4wrw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/devtools-shared": "^7.6.8",
+ "birpc": "^0.2.19",
+ "hookable": "^5.5.3",
+ "mitt": "^3.0.1",
+ "perfect-debounce": "^1.0.0",
+ "speakingurl": "^14.0.1",
+ "superjson": "^2.2.1"
+ }
+ },
+ "node_modules/@vue/devtools-shared": {
+ "version": "7.6.8",
+ "resolved": "https://registry.npmjs.org/@vue/devtools-shared/-/devtools-shared-7.6.8.tgz",
+ "integrity": "sha512-9MBPO5Z3X1nYGFqTJyohl6Gmf/J7UNN1oicHdyzBVZP4jnhZ4c20MgtaHDIzWmHDHCMYVS5bwKxT3jxh7gOOKA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "rfdc": "^1.4.1"
+ }
+ },
+ "node_modules/@vue/reactivity": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/reactivity/-/reactivity-3.5.13.tgz",
+ "integrity": "sha512-NaCwtw8o48B9I6L1zl2p41OHo/2Z4wqYGGIK1Khu5T7yxrn+ATOixn/Udn2m+6kZKB/J7cuT9DbWWhRxqixACg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/shared": "3.5.13"
+ }
+ },
+ "node_modules/@vue/runtime-core": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/runtime-core/-/runtime-core-3.5.13.tgz",
+ "integrity": "sha512-Fj4YRQ3Az0WTZw1sFe+QDb0aXCerigEpw418pw1HBUKFtnQHWzwojaukAs2X/c9DQz4MQ4bsXTGlcpGxU/RCIw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/reactivity": "3.5.13",
+ "@vue/shared": "3.5.13"
+ }
+ },
+ "node_modules/@vue/runtime-dom": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/runtime-dom/-/runtime-dom-3.5.13.tgz",
+ "integrity": "sha512-dLaj94s93NYLqjLiyFzVs9X6dWhTdAlEAciC3Moq7gzAc13VJUdCnjjRurNM6uTLFATRHexHCTu/Xp3eW6yoog==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/reactivity": "3.5.13",
+ "@vue/runtime-core": "3.5.13",
+ "@vue/shared": "3.5.13",
+ "csstype": "^3.1.3"
+ }
+ },
+ "node_modules/@vue/server-renderer": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/server-renderer/-/server-renderer-3.5.13.tgz",
+ "integrity": "sha512-wAi4IRJV/2SAW3htkTlB+dHeRmpTiVIK1OGLWV1yeStVSebSQQOwGwIq0D3ZIoBj2C2qpgz5+vX9iEBkTdk5YA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-ssr": "3.5.13",
+ "@vue/shared": "3.5.13"
+ },
+ "peerDependencies": {
+ "vue": "3.5.13"
+ }
+ },
+ "node_modules/@vue/shared": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.5.13.tgz",
+ "integrity": "sha512-/hnE/qP5ZoGpol0a5mDi45bOd7t3tjYJBjsgCsivow7D48cJeV5l05RD82lPqi7gRiphZM37rnhW1l6ZoCNNnQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@vueuse/core": {
+ "version": "11.3.0",
+ "resolved": "https://registry.npmjs.org/@vueuse/core/-/core-11.3.0.tgz",
+ "integrity": "sha512-7OC4Rl1f9G8IT6rUfi9JrKiXy4bfmHhZ5x2Ceojy0jnd3mHNEvV4JaRygH362ror6/NZ+Nl+n13LPzGiPN8cKA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/web-bluetooth": "^0.0.20",
+ "@vueuse/metadata": "11.3.0",
+ "@vueuse/shared": "11.3.0",
+ "vue-demi": ">=0.14.10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@vueuse/core/node_modules/vue-demi": {
+ "version": "0.14.10",
+ "resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.14.10.tgz",
+ "integrity": "sha512-nMZBOwuzabUO0nLgIcc6rycZEebF6eeUfaiQx9+WSk8e29IbLvPU9feI6tqW4kTo3hvoYAJkMh8n8D0fuISphg==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@vueuse/integrations": {
+ "version": "11.3.0",
+ "resolved": "https://registry.npmjs.org/@vueuse/integrations/-/integrations-11.3.0.tgz",
+ "integrity": "sha512-5fzRl0apQWrDezmobchoiGTkGw238VWESxZHazfhP3RM7pDSiyXy18QbfYkILoYNTd23HPAfQTJpkUc5QbkwTw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vueuse/core": "11.3.0",
+ "@vueuse/shared": "11.3.0",
+ "vue-demi": ">=0.14.10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "async-validator": "^4",
+ "axios": "^1",
+ "change-case": "^5",
+ "drauu": "^0.4",
+ "focus-trap": "^7",
+ "fuse.js": "^7",
+ "idb-keyval": "^6",
+ "jwt-decode": "^4",
+ "nprogress": "^0.2",
+ "qrcode": "^1.5",
+ "sortablejs": "^1",
+ "universal-cookie": "^7"
+ },
+ "peerDependenciesMeta": {
+ "async-validator": {
+ "optional": true
+ },
+ "axios": {
+ "optional": true
+ },
+ "change-case": {
+ "optional": true
+ },
+ "drauu": {
+ "optional": true
+ },
+ "focus-trap": {
+ "optional": true
+ },
+ "fuse.js": {
+ "optional": true
+ },
+ "idb-keyval": {
+ "optional": true
+ },
+ "jwt-decode": {
+ "optional": true
+ },
+ "nprogress": {
+ "optional": true
+ },
+ "qrcode": {
+ "optional": true
+ },
+ "sortablejs": {
+ "optional": true
+ },
+ "universal-cookie": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@vueuse/integrations/node_modules/vue-demi": {
+ "version": "0.14.10",
+ "resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.14.10.tgz",
+ "integrity": "sha512-nMZBOwuzabUO0nLgIcc6rycZEebF6eeUfaiQx9+WSk8e29IbLvPU9feI6tqW4kTo3hvoYAJkMh8n8D0fuISphg==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@vueuse/metadata": {
+ "version": "11.3.0",
+ "resolved": "https://registry.npmjs.org/@vueuse/metadata/-/metadata-11.3.0.tgz",
+ "integrity": "sha512-pwDnDspTqtTo2HwfLw4Rp6yywuuBdYnPYDq+mO38ZYKGebCUQC/nVj/PXSiK9HX5otxLz8Fn7ECPbjiRz2CC3g==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@vueuse/shared": {
+ "version": "11.3.0",
+ "resolved": "https://registry.npmjs.org/@vueuse/shared/-/shared-11.3.0.tgz",
+ "integrity": "sha512-P8gSSWQeucH5821ek2mn/ciCk+MS/zoRKqdQIM3bHq6p7GXDAJLmnRRKmF5F65sAVJIfzQlwR3aDzwCn10s8hA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "vue-demi": ">=0.14.10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/@vueuse/shared/node_modules/vue-demi": {
+ "version": "0.14.10",
+ "resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.14.10.tgz",
+ "integrity": "sha512-nMZBOwuzabUO0nLgIcc6rycZEebF6eeUfaiQx9+WSk8e29IbLvPU9feI6tqW4kTo3hvoYAJkMh8n8D0fuISphg==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "vue-demi-fix": "bin/vue-demi-fix.js",
+ "vue-demi-switch": "bin/vue-demi-switch.js"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ },
+ "peerDependencies": {
+ "@vue/composition-api": "^1.0.0-rc.1",
+ "vue": "^3.0.0-0 || ^2.6.0"
+ },
+ "peerDependenciesMeta": {
+ "@vue/composition-api": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/algoliasearch": {
+ "version": "5.18.0",
+ "resolved": "https://registry.npmjs.org/algoliasearch/-/algoliasearch-5.18.0.tgz",
+ "integrity": "sha512-/tfpK2A4FpS0o+S78o3YSdlqXr0MavJIDlFK3XZrlXLy7vaRXJvW5jYg3v5e/wCaF8y0IpMjkYLhoV6QqfpOgw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@algolia/client-abtesting": "5.18.0",
+ "@algolia/client-analytics": "5.18.0",
+ "@algolia/client-common": "5.18.0",
+ "@algolia/client-insights": "5.18.0",
+ "@algolia/client-personalization": "5.18.0",
+ "@algolia/client-query-suggestions": "5.18.0",
+ "@algolia/client-search": "5.18.0",
+ "@algolia/ingestion": "1.18.0",
+ "@algolia/monitoring": "1.18.0",
+ "@algolia/recommend": "5.18.0",
+ "@algolia/requester-browser-xhr": "5.18.0",
+ "@algolia/requester-fetch": "5.18.0",
+ "@algolia/requester-node-http": "5.18.0"
+ },
+ "engines": {
+ "node": ">= 14.0.0"
+ }
+ },
+ "node_modules/birpc": {
+ "version": "0.2.19",
+ "resolved": "https://registry.npmjs.org/birpc/-/birpc-0.2.19.tgz",
+ "integrity": "sha512-5WeXXAvTmitV1RqJFppT5QtUiz2p1mRSYU000Jkft5ZUCLJIk4uQriYNO50HknxKwM6jd8utNc66K1qGIwwWBQ==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/antfu"
+ }
+ },
+ "node_modules/ccount": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/ccount/-/ccount-2.0.1.tgz",
+ "integrity": "sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/character-entities-html4": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/character-entities-html4/-/character-entities-html4-2.1.0.tgz",
+ "integrity": "sha512-1v7fgQRj6hnSwFpq1Eu0ynr/CDEw0rXo2B61qXrLNdHZmPKgb7fqS1a2JwF0rISo9q77jDI8VMEHoApn8qDoZA==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/character-entities-legacy": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/character-entities-legacy/-/character-entities-legacy-3.0.0.tgz",
+ "integrity": "sha512-RpPp0asT/6ufRm//AJVwpViZbGM/MkjQFxJccQRHmISF/22NBtsHqAWmL+/pmkPWoIUJdWyeVleTl1wydHATVQ==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/comma-separated-tokens": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-2.0.3.tgz",
+ "integrity": "sha512-Fu4hJdvzeylCfQPp9SGWidpzrMs7tTrlu6Vb8XGaRGck8QSNZJJp538Wrb60Lax4fPwR64ViY468OIUTbRlGZg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/copy-anything": {
+ "version": "3.0.5",
+ "resolved": "https://registry.npmjs.org/copy-anything/-/copy-anything-3.0.5.tgz",
+ "integrity": "sha512-yCEafptTtb4bk7GLEQoM8KVJpxAfdBJYaXyzQEgQQQgYrZiDp8SJmGKlYza6CYjEDNstAdNdKA3UuoULlEbS6w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-what": "^4.1.8"
+ },
+ "engines": {
+ "node": ">=12.13"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mesqueeb"
+ }
+ },
+ "node_modules/csstype": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
+ "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/dequal": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz",
+ "integrity": "sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/devlop": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/devlop/-/devlop-1.1.0.tgz",
+ "integrity": "sha512-RWmIqhcFf1lRYBvNmr7qTNuyCt/7/ns2jbpp1+PalgE/rDQcBT0fioSMUpJ93irlUhC5hrg4cYqe6U+0ImW0rA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "dequal": "^2.0.0"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/emoji-regex-xs": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/emoji-regex-xs/-/emoji-regex-xs-1.0.0.tgz",
+ "integrity": "sha512-LRlerrMYoIDrT6jgpeZ2YYl/L8EulRTt5hQcYjy5AInh7HWXKimpqx68aknBFpGL2+/IcogTcaydJEgaTmOpDg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/entities": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
+ "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=0.12"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/esbuild": {
+ "version": "0.21.5",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz",
+ "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "optionalDependencies": {
+ "@esbuild/aix-ppc64": "0.21.5",
+ "@esbuild/android-arm": "0.21.5",
+ "@esbuild/android-arm64": "0.21.5",
+ "@esbuild/android-x64": "0.21.5",
+ "@esbuild/darwin-arm64": "0.21.5",
+ "@esbuild/darwin-x64": "0.21.5",
+ "@esbuild/freebsd-arm64": "0.21.5",
+ "@esbuild/freebsd-x64": "0.21.5",
+ "@esbuild/linux-arm": "0.21.5",
+ "@esbuild/linux-arm64": "0.21.5",
+ "@esbuild/linux-ia32": "0.21.5",
+ "@esbuild/linux-loong64": "0.21.5",
+ "@esbuild/linux-mips64el": "0.21.5",
+ "@esbuild/linux-ppc64": "0.21.5",
+ "@esbuild/linux-riscv64": "0.21.5",
+ "@esbuild/linux-s390x": "0.21.5",
+ "@esbuild/linux-x64": "0.21.5",
+ "@esbuild/netbsd-x64": "0.21.5",
+ "@esbuild/openbsd-x64": "0.21.5",
+ "@esbuild/sunos-x64": "0.21.5",
+ "@esbuild/win32-arm64": "0.21.5",
+ "@esbuild/win32-ia32": "0.21.5",
+ "@esbuild/win32-x64": "0.21.5"
+ }
+ },
+ "node_modules/estree-walker": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
+ "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/focus-trap": {
+ "version": "7.6.2",
+ "resolved": "https://registry.npmjs.org/focus-trap/-/focus-trap-7.6.2.tgz",
+ "integrity": "sha512-9FhUxK1hVju2+AiQIDJ5Dd//9R2n2RAfJ0qfhF4IHGHgcoEUTMpbTeG/zbEuwaiYXfuAH6XE0/aCyxDdRM+W5w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "tabbable": "^6.2.0"
+ }
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
+ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
+ "dev": true,
+ "hasInstallScript": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/hast-util-to-html": {
+ "version": "9.0.4",
+ "resolved": "https://registry.npmjs.org/hast-util-to-html/-/hast-util-to-html-9.0.4.tgz",
+ "integrity": "sha512-wxQzXtdbhiwGAUKrnQJXlOPmHnEehzphwkK7aluUPQ+lEc1xefC8pblMgpp2w5ldBTEfveRIrADcrhGIWrlTDA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/hast": "^3.0.0",
+ "@types/unist": "^3.0.0",
+ "ccount": "^2.0.0",
+ "comma-separated-tokens": "^2.0.0",
+ "hast-util-whitespace": "^3.0.0",
+ "html-void-elements": "^3.0.0",
+ "mdast-util-to-hast": "^13.0.0",
+ "property-information": "^6.0.0",
+ "space-separated-tokens": "^2.0.0",
+ "stringify-entities": "^4.0.0",
+ "zwitch": "^2.0.4"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/hast-util-whitespace": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-3.0.0.tgz",
+ "integrity": "sha512-88JUN06ipLwsnv+dVn+OIYOvAuvBMy/Qoi6O7mQHxdPXpjy+Cd6xRkWwux7DKO+4sYILtLBRIKgsdpS2gQc7qw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/hast": "^3.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/hookable": {
+ "version": "5.5.3",
+ "resolved": "https://registry.npmjs.org/hookable/-/hookable-5.5.3.tgz",
+ "integrity": "sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/html-void-elements": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/html-void-elements/-/html-void-elements-3.0.0.tgz",
+ "integrity": "sha512-bEqo66MRXsUGxWHV5IP0PUiAWwoEjba4VCzg0LjFJBpchPaTfyfCKTG6bc5F8ucKec3q5y6qOdGyYTSBEvhCrg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/is-what": {
+ "version": "4.1.16",
+ "resolved": "https://registry.npmjs.org/is-what/-/is-what-4.1.16.tgz",
+ "integrity": "sha512-ZhMwEosbFJkA0YhFnNDgTM4ZxDRsS6HqTo7qsZM08fehyRYIYa0yHu5R6mgo1n/8MgaPBXiPimPD77baVFYg+A==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=12.13"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mesqueeb"
+ }
+ },
+ "node_modules/magic-string": {
+ "version": "0.30.17",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.17.tgz",
+ "integrity": "sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.5.0"
+ }
+ },
+ "node_modules/mark.js": {
+ "version": "8.11.1",
+ "resolved": "https://registry.npmjs.org/mark.js/-/mark.js-8.11.1.tgz",
+ "integrity": "sha512-1I+1qpDt4idfgLQG+BNWmrqku+7/2bi5nLf4YwF8y8zXvmfiTBY3PV3ZibfrjBueCByROpuBjLLFCajqkgYoLQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/mdast-util-to-hast": {
+ "version": "13.2.0",
+ "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-13.2.0.tgz",
+ "integrity": "sha512-QGYKEuUsYT9ykKBCMOEDLsU5JRObWQusAolFMeko/tYPufNkRffBAQjIE+99jbA87xv6FgmjLtwjh9wBWajwAA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/hast": "^3.0.0",
+ "@types/mdast": "^4.0.0",
+ "@ungap/structured-clone": "^1.0.0",
+ "devlop": "^1.0.0",
+ "micromark-util-sanitize-uri": "^2.0.0",
+ "trim-lines": "^3.0.0",
+ "unist-util-position": "^5.0.0",
+ "unist-util-visit": "^5.0.0",
+ "vfile": "^6.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/micromark-util-character": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/micromark-util-character/-/micromark-util-character-2.1.1.tgz",
+ "integrity": "sha512-wv8tdUTJ3thSFFFJKtpYKOYiGP2+v96Hvk4Tu8KpCAsTMs6yi+nVmGh1syvSCsaxz45J6Jbw+9DD6g97+NV67Q==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "GitHub Sponsors",
+ "url": "https://github.com/sponsors/unifiedjs"
+ },
+ {
+ "type": "OpenCollective",
+ "url": "https://opencollective.com/unified"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "micromark-util-symbol": "^2.0.0",
+ "micromark-util-types": "^2.0.0"
+ }
+ },
+ "node_modules/micromark-util-encode": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/micromark-util-encode/-/micromark-util-encode-2.0.1.tgz",
+ "integrity": "sha512-c3cVx2y4KqUnwopcO9b/SCdo2O67LwJJ/UyqGfbigahfegL9myoEFoDYZgkT7f36T0bLrM9hZTAaAyH+PCAXjw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "GitHub Sponsors",
+ "url": "https://github.com/sponsors/unifiedjs"
+ },
+ {
+ "type": "OpenCollective",
+ "url": "https://opencollective.com/unified"
+ }
+ ],
+ "license": "MIT"
+ },
+ "node_modules/micromark-util-sanitize-uri": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-2.0.1.tgz",
+ "integrity": "sha512-9N9IomZ/YuGGZZmQec1MbgxtlgougxTodVwDzzEouPKo3qFWvymFHWcnDi2vzV1ff6kas9ucW+o3yzJK9YB1AQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "GitHub Sponsors",
+ "url": "https://github.com/sponsors/unifiedjs"
+ },
+ {
+ "type": "OpenCollective",
+ "url": "https://opencollective.com/unified"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "micromark-util-character": "^2.0.0",
+ "micromark-util-encode": "^2.0.0",
+ "micromark-util-symbol": "^2.0.0"
+ }
+ },
+ "node_modules/micromark-util-symbol": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/micromark-util-symbol/-/micromark-util-symbol-2.0.1.tgz",
+ "integrity": "sha512-vs5t8Apaud9N28kgCrRUdEed4UJ+wWNvicHLPxCa9ENlYuAY31M0ETy5y1vA33YoNPDFTghEbnh6efaE8h4x0Q==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "GitHub Sponsors",
+ "url": "https://github.com/sponsors/unifiedjs"
+ },
+ {
+ "type": "OpenCollective",
+ "url": "https://opencollective.com/unified"
+ }
+ ],
+ "license": "MIT"
+ },
+ "node_modules/micromark-util-types": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-2.0.1.tgz",
+ "integrity": "sha512-534m2WhVTddrcKVepwmVEVnUAmtrx9bfIjNoQHRqfnvdaHQiFytEhJoTgpWJvDEXCO5gLTQh3wYC1PgOJA4NSQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "GitHub Sponsors",
+ "url": "https://github.com/sponsors/unifiedjs"
+ },
+ {
+ "type": "OpenCollective",
+ "url": "https://opencollective.com/unified"
+ }
+ ],
+ "license": "MIT"
+ },
+ "node_modules/minisearch": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmjs.org/minisearch/-/minisearch-7.1.1.tgz",
+ "integrity": "sha512-b3YZEYCEH4EdCAtYP7OlDyx7FdPwNzuNwLQ34SfJpM9dlbBZzeXndGavTrC+VCiRWomL21SWfMc6SCKO/U2ZNw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/mitt": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/mitt/-/mitt-3.0.1.tgz",
+ "integrity": "sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.8",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.8.tgz",
+ "integrity": "sha512-WNLf5Sd8oZxOm+TzppcYk8gVOgP+l58xNy58D0nbUnOxOWRWvlcCV4kUF7ltmI6PsrLl/BgKEyS4mqsGChFN0w==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "MIT",
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/oniguruma-to-es": {
+ "version": "0.8.0",
+ "resolved": "https://registry.npmjs.org/oniguruma-to-es/-/oniguruma-to-es-0.8.0.tgz",
+ "integrity": "sha512-rY+/a6b+uCgoYIL9itjY0x99UUDHXmGaw7Jjk5ZvM/3cxDJifyxFr/Zm4tTmF6Tre18gAakJo7AzhKUeMNLgHA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "emoji-regex-xs": "^1.0.0",
+ "regex": "^5.0.2",
+ "regex-recursion": "^5.0.0"
+ }
+ },
+ "node_modules/perfect-debounce": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/perfect-debounce/-/perfect-debounce-1.0.0.tgz",
+ "integrity": "sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/picocolors": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
+ "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/postcss": {
+ "version": "8.4.49",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.49.tgz",
+ "integrity": "sha512-OCVPnIObs4N29kxTjzLfUryOkvZEq+pf8jTF0lg8E7uETuWHA+v7j3c/xJmiqpX450191LlmZfUKkXxkTry7nA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "nanoid": "^3.3.7",
+ "picocolors": "^1.1.1",
+ "source-map-js": "^1.2.1"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/preact": {
+ "version": "10.25.3",
+ "resolved": "https://registry.npmjs.org/preact/-/preact-10.25.3.tgz",
+ "integrity": "sha512-dzQmIFtM970z+fP9ziQ3yG4e3ULIbwZzJ734vaMVUTaKQ2+Ru1Ou/gjshOYVHCcd1rpAelC6ngjvjDXph98unQ==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/preact"
+ }
+ },
+ "node_modules/property-information": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/property-information/-/property-information-6.5.0.tgz",
+ "integrity": "sha512-PgTgs/BlvHxOu8QuEN7wi5A0OmXaBcHpmCSTehcs6Uuu9IkDIEo13Hy7n898RHfrQ49vKCoGeWZSaAK01nwVig==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/regex": {
+ "version": "5.0.2",
+ "resolved": "https://registry.npmjs.org/regex/-/regex-5.0.2.tgz",
+ "integrity": "sha512-/pczGbKIQgfTMRV0XjABvc5RzLqQmwqxLHdQao2RTXPk+pmTXB2P0IaUHYdYyk412YLwUIkaeMd5T+RzVgTqnQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "regex-utilities": "^2.3.0"
+ }
+ },
+ "node_modules/regex-recursion": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/regex-recursion/-/regex-recursion-5.0.0.tgz",
+ "integrity": "sha512-UwyOqeobrCCqTXPcsSqH4gDhOjD5cI/b8kjngWgSZbxYh5yVjAwTjO5+hAuPRNiuR70+5RlWSs+U9PVcVcW9Lw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "regex-utilities": "^2.3.0"
+ }
+ },
+ "node_modules/regex-utilities": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/regex-utilities/-/regex-utilities-2.3.0.tgz",
+ "integrity": "sha512-8VhliFJAWRaUiVvREIiW2NXXTmHs4vMNnSzuJVhscgmGav3g9VDxLrQndI3dZZVVdp0ZO/5v0xmX516/7M9cng==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/rfdc": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.4.1.tgz",
+ "integrity": "sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/rollup": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.28.1.tgz",
+ "integrity": "sha512-61fXYl/qNVinKmGSTHAZ6Yy8I3YIJC/r2m9feHo6SwVAVcLT5MPwOUFe7EuURA/4m0NR8lXG4BBXuo/IZEsjMg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/estree": "1.0.6"
+ },
+ "bin": {
+ "rollup": "dist/bin/rollup"
+ },
+ "engines": {
+ "node": ">=18.0.0",
+ "npm": ">=8.0.0"
+ },
+ "optionalDependencies": {
+ "@rollup/rollup-android-arm-eabi": "4.28.1",
+ "@rollup/rollup-android-arm64": "4.28.1",
+ "@rollup/rollup-darwin-arm64": "4.28.1",
+ "@rollup/rollup-darwin-x64": "4.28.1",
+ "@rollup/rollup-freebsd-arm64": "4.28.1",
+ "@rollup/rollup-freebsd-x64": "4.28.1",
+ "@rollup/rollup-linux-arm-gnueabihf": "4.28.1",
+ "@rollup/rollup-linux-arm-musleabihf": "4.28.1",
+ "@rollup/rollup-linux-arm64-gnu": "4.28.1",
+ "@rollup/rollup-linux-arm64-musl": "4.28.1",
+ "@rollup/rollup-linux-loongarch64-gnu": "4.28.1",
+ "@rollup/rollup-linux-powerpc64le-gnu": "4.28.1",
+ "@rollup/rollup-linux-riscv64-gnu": "4.28.1",
+ "@rollup/rollup-linux-s390x-gnu": "4.28.1",
+ "@rollup/rollup-linux-x64-gnu": "4.28.1",
+ "@rollup/rollup-linux-x64-musl": "4.28.1",
+ "@rollup/rollup-win32-arm64-msvc": "4.28.1",
+ "@rollup/rollup-win32-ia32-msvc": "4.28.1",
+ "@rollup/rollup-win32-x64-msvc": "4.28.1",
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/search-insights": {
+ "version": "2.17.3",
+ "resolved": "https://registry.npmjs.org/search-insights/-/search-insights-2.17.3.tgz",
+ "integrity": "sha512-RQPdCYTa8A68uM2jwxoY842xDhvx3E5LFL1LxvxCNMev4o5mLuokczhzjAgGwUZBAmOKZknArSxLKmXtIi2AxQ==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true
+ },
+ "node_modules/shiki": {
+ "version": "1.24.3",
+ "resolved": "https://registry.npmjs.org/shiki/-/shiki-1.24.3.tgz",
+ "integrity": "sha512-eMeX/ehE2IDKVs71kB4zVcDHjutNcOtm+yIRuR4sA6ThBbdFI0DffGJiyoKCodj0xRGxIoWC3pk/Anmm5mzHmA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@shikijs/core": "1.24.3",
+ "@shikijs/engine-javascript": "1.24.3",
+ "@shikijs/engine-oniguruma": "1.24.3",
+ "@shikijs/types": "1.24.3",
+ "@shikijs/vscode-textmate": "^9.3.1",
+ "@types/hast": "^3.0.4"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
+ "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/space-separated-tokens": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-2.0.2.tgz",
+ "integrity": "sha512-PEGlAwrG8yXGXRjW32fGbg66JAlOAwbObuqVoJpv/mRgoWDQfgH1wDPvtzWyUSNAXBGSk8h755YDbbcEy3SH2Q==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/speakingurl": {
+ "version": "14.0.1",
+ "resolved": "https://registry.npmjs.org/speakingurl/-/speakingurl-14.0.1.tgz",
+ "integrity": "sha512-1POYv7uv2gXoyGFpBCmpDVSNV74IfsWlDW216UPjbWufNf+bSU6GdbDsxdcxtfwb4xlI3yxzOTKClUosxARYrQ==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/stringify-entities": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/stringify-entities/-/stringify-entities-4.0.4.tgz",
+ "integrity": "sha512-IwfBptatlO+QCJUo19AqvrPNqlVMpW9YEL2LIVY+Rpv2qsjCGxaDLNRgeGsQWJhfItebuJhsGSLjaBbNSQ+ieg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "character-entities-html4": "^2.0.0",
+ "character-entities-legacy": "^3.0.0"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/superjson": {
+ "version": "2.2.2",
+ "resolved": "https://registry.npmjs.org/superjson/-/superjson-2.2.2.tgz",
+ "integrity": "sha512-5JRxVqC8I8NuOUjzBbvVJAKNM8qoVuH0O77h4WInc/qC2q5IreqKxYwgkga3PfA22OayK2ikceb/B26dztPl+Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "copy-anything": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=16"
+ }
+ },
+ "node_modules/tabbable": {
+ "version": "6.2.0",
+ "resolved": "https://registry.npmjs.org/tabbable/-/tabbable-6.2.0.tgz",
+ "integrity": "sha512-Cat63mxsVJlzYvN51JmVXIgNoUokrIaT2zLclCXjRd8boZ0004U4KCs/sToJ75C6sdlByWxpYnb5Boif1VSFew==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/trim-lines": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/trim-lines/-/trim-lines-3.0.1.tgz",
+ "integrity": "sha512-kRj8B+YHZCc9kQYdWfJB2/oUl9rA99qbowYYBtr4ui4mZyAQ2JpvVBd/6U2YloATfqBhBTSMhTpgBHtU0Mf3Rg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ },
+ "node_modules/typescript": {
+ "version": "5.7.2",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz",
+ "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "peer": true,
+ "bin": {
+ "tsc": "bin/tsc",
+ "tsserver": "bin/tsserver"
+ },
+ "engines": {
+ "node": ">=14.17"
+ }
+ },
+ "node_modules/unist-util-is": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-6.0.0.tgz",
+ "integrity": "sha512-2qCTHimwdxLfz+YzdGfkqNlH0tLi9xjTnHddPmJwtIG9MGsdbutfTc4P+haPD7l7Cjxf/WZj+we5qfVPvvxfYw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/unist-util-position": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/unist-util-position/-/unist-util-position-5.0.0.tgz",
+ "integrity": "sha512-fucsC7HjXvkB5R3kTCO7kUjRdrS0BJt3M/FPxmHMBOm8JQi2BsHAHFsy27E0EolP8rp0NzXsJ+jNPyDWvOJZPA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/unist-util-stringify-position": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-4.0.0.tgz",
+ "integrity": "sha512-0ASV06AAoKCDkS2+xw5RXJywruurpbC4JZSm7nr7MOt1ojAzvyyaO+UxZf18j8FCF6kmzCZKcAgN/yu2gm2XgQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/unist-util-visit": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-5.0.0.tgz",
+ "integrity": "sha512-MR04uvD+07cwl/yhVuVWAtw+3GOR/knlL55Nd/wAdblk27GCVt3lqpTivy/tkJcZoNPzTwS1Y+KMojlLDhoTzg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0",
+ "unist-util-is": "^6.0.0",
+ "unist-util-visit-parents": "^6.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/unist-util-visit-parents": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-6.0.1.tgz",
+ "integrity": "sha512-L/PqWzfTP9lzzEa6CKs0k2nARxTdZduw3zyh8d2NVBnsyvHjSX4TWse388YrrQKbvI8w20fGjGlhgT96WwKykw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0",
+ "unist-util-is": "^6.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/vfile": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/vfile/-/vfile-6.0.3.tgz",
+ "integrity": "sha512-KzIbH/9tXat2u30jf+smMwFCsno4wHVdNmzFyL+T/L3UGqqk6JKfVqOFOZEpZSHADH1k40ab6NUIXZq422ov3Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0",
+ "vfile-message": "^4.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/vfile-message": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-4.0.2.tgz",
+ "integrity": "sha512-jRDZ1IMLttGj41KcZvlrYAaI3CfqpLpfpf+Mfig13viT6NKvRzWZ+lXz0Y5D60w6uJIBAOGq9mSHf0gktF0duw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/unist": "^3.0.0",
+ "unist-util-stringify-position": "^4.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/unified"
+ }
+ },
+ "node_modules/vite": {
+ "version": "5.4.11",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.11.tgz",
+ "integrity": "sha512-c7jFQRklXua0mTzneGW9QVyxFjUgwcihC4bXEtujIo2ouWCe1Ajt/amn2PCxYnhYfd5k09JX3SB7OYWFKYqj8Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "esbuild": "^0.21.3",
+ "postcss": "^8.4.43",
+ "rollup": "^4.20.0"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^18.0.0 || >=20.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/vitejs/vite?sponsor=1"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.3"
+ },
+ "peerDependencies": {
+ "@types/node": "^18.0.0 || >=20.0.0",
+ "less": "*",
+ "lightningcss": "^1.21.0",
+ "sass": "*",
+ "sass-embedded": "*",
+ "stylus": "*",
+ "sugarss": "*",
+ "terser": "^5.4.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "lightningcss": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "sass-embedded": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/vitepress": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/vitepress/-/vitepress-1.5.0.tgz",
+ "integrity": "sha512-q4Q/G2zjvynvizdB3/bupdYkCJe2umSAMv9Ju4d92E6/NXJ59z70xB0q5p/4lpRyAwflDsbwy1mLV9Q5+nlB+g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@docsearch/css": "^3.6.2",
+ "@docsearch/js": "^3.6.2",
+ "@iconify-json/simple-icons": "^1.2.10",
+ "@shikijs/core": "^1.22.2",
+ "@shikijs/transformers": "^1.22.2",
+ "@shikijs/types": "^1.22.2",
+ "@types/markdown-it": "^14.1.2",
+ "@vitejs/plugin-vue": "^5.1.4",
+ "@vue/devtools-api": "^7.5.4",
+ "@vue/shared": "^3.5.12",
+ "@vueuse/core": "^11.1.0",
+ "@vueuse/integrations": "^11.1.0",
+ "focus-trap": "^7.6.0",
+ "mark.js": "8.11.1",
+ "minisearch": "^7.1.0",
+ "shiki": "^1.22.2",
+ "vite": "^5.4.10",
+ "vue": "^3.5.12"
+ },
+ "bin": {
+ "vitepress": "bin/vitepress.js"
+ },
+ "peerDependencies": {
+ "markdown-it-mathjax3": "^4",
+ "postcss": "^8"
+ },
+ "peerDependenciesMeta": {
+ "markdown-it-mathjax3": {
+ "optional": true
+ },
+ "postcss": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/vitepress-plugin-tabs": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/vitepress-plugin-tabs/-/vitepress-plugin-tabs-0.5.0.tgz",
+ "integrity": "sha512-SIhFWwGsUkTByfc2b279ray/E0Jt8vDTsM1LiHxmCOBAEMmvzIBZSuYYT1DpdDTiS3SuJieBheJkYnwCq/yD9A==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "vitepress": "^1.0.0-rc.27",
+ "vue": "^3.3.8"
+ }
+ },
+ "node_modules/vue": {
+ "version": "3.5.13",
+ "resolved": "https://registry.npmjs.org/vue/-/vue-3.5.13.tgz",
+ "integrity": "sha512-wmeiSMxkZCSc+PM2w2VRsOYAZC8GdipNFRTsLSfodVqI9mbejKeXEGr8SckuLnrQPGe3oJN5c3K0vpoU9q/wCQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@vue/compiler-dom": "3.5.13",
+ "@vue/compiler-sfc": "3.5.13",
+ "@vue/runtime-dom": "3.5.13",
+ "@vue/server-renderer": "3.5.13",
+ "@vue/shared": "3.5.13"
+ },
+ "peerDependencies": {
+ "typescript": "*"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/zwitch": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/zwitch/-/zwitch-2.0.4.tgz",
+ "integrity": "sha512-bXE4cR/kVZhKZX/RjPEflHaKVhUVl85noU3v6b8apfQEc1x4A+zBxjZ4lN8LqGd6WZ3dl98pY4o717VFmoPp+A==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/wooorm"
+ }
+ }
+ }
+}
diff --git a/docs/package.json b/docs/package.json
new file mode 100644
index 00000000..b226c78c
--- /dev/null
+++ b/docs/package.json
@@ -0,0 +1,12 @@
+{
+ "scripts": {
+ "dev": "vitepress dev",
+ "build": "vitepress build",
+ "preview": "vitepress preview"
+ },
+ "devDependencies": {
+ "@catppuccin/vitepress": "^0.1.0",
+ "vitepress": "^1.5.0",
+ "vitepress-plugin-tabs": "^0.5.0"
+ }
+}
diff --git a/lua/blink/cmp/completion/trigger/init.lua b/lua/blink/cmp/completion/trigger/init.lua
index 4320a1da..4e24f4a0 100644
--- a/lua/blink/cmp/completion/trigger/init.lua
+++ b/lua/blink/cmp/completion/trigger/init.lua
@@ -12,7 +12,7 @@
--- @field hide_emitter blink.cmp.EventEmitter<{}>
---
--- @field activate fun()
---- @field is_trigger_character fun(char: string, is_retrigger?: boolean): boolean
+--- @field is_trigger_character fun(char: string, is_show_on_x?: boolean): boolean
--- @field suppress_events_for_callback fun(cb: fun())
--- @field show_if_on_trigger_character fun(opts?: { is_accept?: boolean })
--- @field show fun(opts?: { trigger_character?: string, force?: boolean, send_upstream?: boolean, providers?: string[], prefetch?: boolean })
diff --git a/lua/blink/cmp/config/completion/accept.lua b/lua/blink/cmp/config/completion/accept.lua
index bde3f044..09e5fa1e 100644
--- a/lua/blink/cmp/config/completion/accept.lua
+++ b/lua/blink/cmp/config/completion/accept.lua
@@ -33,7 +33,7 @@ local accept = {
blocked_filetypes = {},
kind_resolution = {
enabled = true,
- blocked_filetypes = { 'typescriptreact', 'javascriptreact', 'vue' },
+ blocked_filetypes = { 'typescriptreact', 'javascriptreact', 'vue', 'rust' },
},
semantic_token_resolution = {
enabled = true,