Merge 770e255041
into 3338d39206
This commit is contained in:
commit
6d4a14fe1b
1
init.lua
1
init.lua
|
@ -979,6 +979,7 @@ require('lazy').setup({
|
||||||
-- require 'kickstart.plugins.autopairs',
|
-- require 'kickstart.plugins.autopairs',
|
||||||
-- require 'kickstart.plugins.neo-tree',
|
-- require 'kickstart.plugins.neo-tree',
|
||||||
-- require 'kickstart.plugins.gitsigns', -- adds gitsigns recommend keymaps
|
-- require 'kickstart.plugins.gitsigns', -- adds gitsigns recommend keymaps
|
||||||
|
-- require 'kickstart.plugins.snacks', -- enable snacks picker
|
||||||
|
|
||||||
-- NOTE: The import below can automatically add your own plugins, configuration, etc from `lua/custom/plugins/*.lua`
|
-- NOTE: The import below can automatically add your own plugins, configuration, etc from `lua/custom/plugins/*.lua`
|
||||||
-- This is the easiest way to modularize your config.
|
-- This is the easiest way to modularize your config.
|
||||||
|
|
|
@ -0,0 +1,154 @@
|
||||||
|
-- NOTE: Plugins can specify dependencies.
|
||||||
|
--
|
||||||
|
-- The dependencies are proper plugin specifications as well - anything
|
||||||
|
-- you do for a plugin at the top level, you can do for a dependency.
|
||||||
|
--
|
||||||
|
-- Use the `dependencies` key to specify the dependencies of a particular plugin
|
||||||
|
|
||||||
|
return { -- Fuzzy Finder (files, lsp, etc)
|
||||||
|
'folke/snacks.nvim',
|
||||||
|
priority = 1000,
|
||||||
|
lazy = false,
|
||||||
|
dependencies = {
|
||||||
|
-- Useful for getting pretty icons, but requires a Nerd Font.
|
||||||
|
{ 'nvim-tree/nvim-web-devicons', enabled = vim.g.have_nerd_font },
|
||||||
|
},
|
||||||
|
|
||||||
|
-- snacks.nvim is a plugin that contains a collection of QoL improvements.
|
||||||
|
-- One of those plugins is called snacks-picker
|
||||||
|
-- It is a fuzzy finder, inspired by Telescope, that comes with a lot of different
|
||||||
|
-- things that it can fuzzy find! It's more than just a "file finder", it can search
|
||||||
|
-- many different aspects of Neovim, your workspace, LSP, and more!
|
||||||
|
--
|
||||||
|
-- Two important keymaps to use while in a picker are:
|
||||||
|
-- - Insert mode: <c-/>
|
||||||
|
-- - Normal mode: ?
|
||||||
|
--
|
||||||
|
-- This opens a window that shows you all of the keymaps for the current
|
||||||
|
-- Snacks picker. This is really useful to discover what nacks-picker can
|
||||||
|
-- do as well as how to actually do it!
|
||||||
|
|
||||||
|
-- [[ Configure Snacks Pickers ]]
|
||||||
|
-- See `:help snacks-picker` and `:help snacks-picker-setup`
|
||||||
|
---@type snacks.Config
|
||||||
|
opts = {
|
||||||
|
picker = {},
|
||||||
|
},
|
||||||
|
|
||||||
|
-- See `:help snacks-pickers-sources`
|
||||||
|
keys = {
|
||||||
|
{
|
||||||
|
'<leader>sh',
|
||||||
|
function()
|
||||||
|
Snacks.picker.help()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [H]elp',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>sk',
|
||||||
|
function()
|
||||||
|
Snacks.picker.keymaps()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [K]eymaps',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>sf',
|
||||||
|
function()
|
||||||
|
Snacks.picker.smart()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [F]iles',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>ss',
|
||||||
|
function()
|
||||||
|
Snacks.picker.pickers()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [S]elect Snacks',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>sw',
|
||||||
|
function()
|
||||||
|
Snacks.picker.grep_word()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch current [W]ord',
|
||||||
|
mode = { 'n', 'x' },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>sg',
|
||||||
|
function()
|
||||||
|
Snacks.picker.grep()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch by [G]rep',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>sd',
|
||||||
|
function()
|
||||||
|
Snacks.picker.diagnostics()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [D]iagnostics',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>sr',
|
||||||
|
function()
|
||||||
|
Snacks.picker.resume()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [R]esume',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>s.',
|
||||||
|
function()
|
||||||
|
Snacks.picker.recent()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch Recent Files ("." for repeat)',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader><leader>',
|
||||||
|
function()
|
||||||
|
Snacks.picker.buffers()
|
||||||
|
end,
|
||||||
|
desc = '[ ] Find existing buffers',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>/',
|
||||||
|
function()
|
||||||
|
Snacks.picker.lines {}
|
||||||
|
end,
|
||||||
|
desc = '[/] Fuzzily search in current buffer',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'<leader>s/',
|
||||||
|
function()
|
||||||
|
Snacks.picker.grep_buffers()
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [/] in Open Files',
|
||||||
|
},
|
||||||
|
-- Shortcut for searching your Neovim configuration files
|
||||||
|
{
|
||||||
|
'<leader>sn',
|
||||||
|
function()
|
||||||
|
Snacks.picker.files { cwd = vim.fn.stdpath 'config' }
|
||||||
|
end,
|
||||||
|
desc = '[S]earch [N]eovim files',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
-- This runs on LSP attach per buffer (see main LSP attach function in 'neovim/nvim-lspconfig' config for more info,
|
||||||
|
-- it is better explained there). This is a little bit redundant, but we can switch off pickers for an optional
|
||||||
|
-- picker like this one here more easily when the keymaps are defined in the plugin itself.
|
||||||
|
-- It sets up buffer-local keymaps, autocommands, and other LSP-related settings
|
||||||
|
-- whenever an LSP client attaches to a buffer.
|
||||||
|
config = function()
|
||||||
|
vim.api.nvim_create_autocmd('LspAttach', {
|
||||||
|
group = vim.api.nvim_create_augroup('snacks-lsp-attach', { clear = true }),
|
||||||
|
callback = function(event)
|
||||||
|
vim.keymap.set('n', 'grr', require('snacks').picker.lsp_references, { buffer = event.buf, desc = '[G]oto [R]eferences' })
|
||||||
|
vim.keymap.set('n', 'gri', require('snacks').picker.lsp_implementations, { buffer = event.buf, desc = '[G]oto [I]mplementation' })
|
||||||
|
vim.keymap.set('n', 'grd', require('snacks').picker.lsp_definitions, { buffer = event.buf, desc = '[G]oto [D]efinition' })
|
||||||
|
vim.keymap.set('n', 'grD', vim.lsp.buf.declaration, { buffer = event.buf, desc = '[G]oto [D]eclaration' })
|
||||||
|
vim.keymap.set('n', 'gO', require('snacks').picker.lsp_symbols, { buffer = event.buf, desc = 'Open Document Symbols' })
|
||||||
|
vim.keymap.set('n', 'gW', require('snacks').picker.lsp_workspace_symbols, { buffer = event.buf, desc = 'Open Workspace Symbols' })
|
||||||
|
vim.keymap.set('n', 'grt', require('snacks').picker.lsp_type_definitions, { buffer = event.buf, desc = '[G]oto [T]ype Definition' })
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
}
|
Loading…
Reference in New Issue