155 lines
7.1 KiB
Lua
155 lines
7.1 KiB
Lua
return {
|
||
{ -- Fuzzy Finder (files, lsp, etc)
|
||
'nvim-telescope/telescope.nvim',
|
||
-- By default, Telescope is included and acts as your picker for everything.
|
||
|
||
-- If you would like to switch to a different picker (like snacks, or fzf-lua)
|
||
-- you can disable the Telescope plugin by setting enabled to false and enable
|
||
-- your replacement picker by requiring it explicitly (e.g. 'custom.plugins.snacks')
|
||
|
||
-- Note: If you customize your config for yourself,
|
||
-- it’s best to remove the Telescope plugin config entirely
|
||
-- instead of just disabling it here, to keep your config clean.
|
||
enabled = true,
|
||
event = 'VimEnter',
|
||
dependencies = {
|
||
'nvim-lua/plenary.nvim',
|
||
{ -- If encountering errors, see telescope-fzf-native README for installation instructions
|
||
'nvim-telescope/telescope-fzf-native.nvim',
|
||
|
||
-- `build` is used to run some command when the plugin is installed/updated.
|
||
-- This is only run then, not every time Neovim starts up.
|
||
build = 'make',
|
||
|
||
-- `cond` is a condition used to determine whether this plugin should be
|
||
-- installed and loaded.
|
||
cond = function() return vim.fn.executable 'make' == 1 end,
|
||
},
|
||
{ 'nvim-telescope/telescope-ui-select.nvim' },
|
||
|
||
-- Useful for getting pretty icons, but requires a Nerd Font.
|
||
{ 'nvim-tree/nvim-web-devicons', enabled = vim.g.have_nerd_font },
|
||
},
|
||
config = function()
|
||
-- Two important keymaps to use while in Telescope are:
|
||
-- - Insert mode: <c-/>
|
||
-- - Normal mode: ?
|
||
--
|
||
-- This opens a window that shows you all of the keymaps for the current
|
||
-- Telescope picker. This is really useful to discover what Telescope can
|
||
-- do as well as how to actually do it!
|
||
|
||
require('telescope').setup {
|
||
defaults = {
|
||
file_ignore_patterns = {
|
||
'^.git/',
|
||
'^node_modules/',
|
||
},
|
||
vimgrep_arguments = {
|
||
'rg',
|
||
'--color=never',
|
||
'--no-heading',
|
||
'--with-filename',
|
||
'--line-number',
|
||
'--column',
|
||
'--smart-case',
|
||
'--hidden', -- Busca en archivos ocultos
|
||
'--glob',
|
||
'!.git/', -- Excluye .git pero no .gitlab
|
||
'--glob',
|
||
'!package-lock.json',
|
||
},
|
||
},
|
||
-- show hidden files, does it respect config for whatever command is using?
|
||
pickers = {
|
||
find_files = {
|
||
hidden = true,
|
||
},
|
||
},
|
||
extensions = {
|
||
['ui-select'] = { require('telescope.themes').get_dropdown() },
|
||
},
|
||
}
|
||
|
||
-- Enable Telescope extensions if they are installed
|
||
pcall(require('telescope').load_extension, 'fzf')
|
||
pcall(require('telescope').load_extension, 'ui-select')
|
||
|
||
-- See `:help telescope.builtin`
|
||
local builtin = require 'telescope.builtin'
|
||
vim.keymap.set('n', '<leader>sh', builtin.help_tags, { desc = '[S]earch [H]elp' })
|
||
vim.keymap.set('n', '<leader>sk', builtin.keymaps, { desc = '[S]earch [K]eymaps' })
|
||
vim.keymap.set('n', '<leader>sf', builtin.find_files, { desc = '[S]earch [F]iles' })
|
||
vim.keymap.set('n', '<leader>ss', builtin.builtin, { desc = '[S]earch [S]elect Telescope' })
|
||
vim.keymap.set({ 'n', 'v' }, '<leader>sw', builtin.grep_string, { desc = '[S]earch current [W]ord' })
|
||
vim.keymap.set('n', '<leader>sg', builtin.live_grep, { desc = '[S]earch by [G]rep' })
|
||
vim.keymap.set('n', '<leader>sd', builtin.diagnostics, { desc = '[S]earch [D]iagnostics' })
|
||
vim.keymap.set('n', '<leader>sr', builtin.resume, { desc = '[S]earch [R]esume' })
|
||
vim.keymap.set('n', '<leader>s.', builtin.oldfiles, { desc = '[S]earch Recent Files ("." for repeat)' })
|
||
vim.keymap.set('n', '<leader>sc', builtin.commands, { desc = '[S]earch [C]ommands' })
|
||
vim.keymap.set('n', '<leader><leader>', builtin.buffers, { desc = '[ ] Find existing buffers' })
|
||
|
||
-- 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 allows easily switching between pickers if you prefer using something else!
|
||
vim.api.nvim_create_autocmd('LspAttach', {
|
||
group = vim.api.nvim_create_augroup('telescope-lsp-attach', { clear = true }),
|
||
callback = function(event)
|
||
local buf = event.buf
|
||
|
||
-- Find references for the word under your cursor.
|
||
vim.keymap.set('n', 'grr', builtin.lsp_references, { buffer = buf, desc = '[G]oto [R]eferences' })
|
||
|
||
-- Jump to the implementation of the word under your cursor.
|
||
-- Useful when your language has ways of declaring types without an actual implementation.
|
||
vim.keymap.set('n', 'gri', builtin.lsp_implementations, { buffer = buf, desc = '[G]oto [I]mplementation' })
|
||
|
||
-- Jump to the definition of the word under your cursor.
|
||
-- This is where a variable was first declared, or where a function is defined, etc.
|
||
-- To jump back, press <C-t>.
|
||
vim.keymap.set('n', 'grd', builtin.lsp_definitions, { buffer = buf, desc = '[G]oto [D]efinition' })
|
||
|
||
-- Fuzzy find all the symbols in your current document.
|
||
-- Symbols are things like variables, functions, types, etc.
|
||
vim.keymap.set('n', 'gO', builtin.lsp_document_symbols, { buffer = buf, desc = 'Open Document Symbols' })
|
||
|
||
-- Fuzzy find all the symbols in your current workspace.
|
||
-- Similar to document symbols, except searches over your entire project.
|
||
vim.keymap.set('n', 'gW', builtin.lsp_dynamic_workspace_symbols, { buffer = buf, desc = 'Open Workspace Symbols' })
|
||
|
||
-- Jump to the type of the word under your cursor.
|
||
-- Useful when you're not sure what type a variable is and you want to see
|
||
-- the definition of its *type*, not where it was *defined*.
|
||
vim.keymap.set('n', 'grt', builtin.lsp_type_definitions, { buffer = buf, desc = '[G]oto [T]ype Definition' })
|
||
end,
|
||
})
|
||
|
||
-- Override default behavior and theme when searching
|
||
vim.keymap.set('n', '<leader>/', function()
|
||
-- You can pass additional configuration to Telescope to change the theme, layout, etc.
|
||
builtin.current_buffer_fuzzy_find(require('telescope.themes').get_dropdown {
|
||
winblend = 10,
|
||
previewer = false,
|
||
})
|
||
end, { desc = '[/] Fuzzily search in current buffer' })
|
||
|
||
-- It's also possible to pass additional configuration options.
|
||
-- See `:help telescope.builtin.live_grep()` for information about particular keys
|
||
vim.keymap.set(
|
||
'n',
|
||
'<leader>s/',
|
||
function()
|
||
builtin.live_grep {
|
||
grep_open_files = true,
|
||
prompt_title = 'Live Grep in Open Files',
|
||
}
|
||
end,
|
||
{ desc = '[S]earch [/] in Open Files' }
|
||
)
|
||
|
||
-- Shortcut for searching your Neovim configuration files
|
||
vim.keymap.set('n', '<leader>sn', function() builtin.find_files { cwd = vim.fn.stdpath 'config' } end, { desc = '[S]earch [N]eovim files' })
|
||
end,
|
||
},
|
||
}
|
||
-- vim: ts=2 sts=2 sw=2 et
|