From 55040ca442447691bab44d3e741a6cf7b730826a Mon Sep 17 00:00:00 2001 From: bekaboo <18127878294@qq.com> Date: Wed, 24 Jan 2024 17:20:28 +0800 Subject: [PATCH] feat(api): improve fuzzy-find api and doc * Add new fuzzy-find api `fuzzy_find_next()` and `fuzzy_find_prev()` * Extend `fuzzy_find_navigate()` to accept integer as `direction` * Add missing docs for fuzzy-find api functions --- README.md | 8 +++-- doc/dropbar.txt | 29 +++++++++++++++++ lua/dropbar/api.lua | 78 ++++++++++++++++++++++++++------------------- 3 files changed, 80 insertions(+), 35 deletions(-) diff --git a/README.md b/README.md index 16e22353..a45f2ffb 100644 --- a/README.md +++ b/README.md @@ -1573,8 +1573,12 @@ used to interact with the winbar or the drop-down menu: clickable component is selected, respectively. - If it is a `function`, it receives the `dropbar_menu_entry_t` as an argument and should return the `dropbar_symbol_t` that is to be clicked. -- `fuzzy_find_navigate(direction: "up" | "down")` - - Select the previous/next entry in the menu while fuzzy finding +- `fuzzy_find_navigate(direction: 'up'|'down'|integer)` + - Navigate to the nth previous/next entry while fuzzy finding +- `fuzzy_find_prev()` + - Navigate to the previous entry while fuzzy finding +- `fuzzy_find_next()` + - Navigate to the next entry while fuzzy finding ### Utility Functions diff --git a/doc/dropbar.txt b/doc/dropbar.txt index b517e4b8..a3cc7e01 100644 --- a/doc/dropbar.txt +++ b/doc/dropbar.txt @@ -970,6 +970,35 @@ api.pick([{idx}]) *dropbar-api-pick()* Parameters: ~ • {idx} (integer?): The index of the component to pick +api.fuzzy_find_toggle([{opts}]) *dropbar-api-fuzzy_find_toggle* + + Toggle fuzzy finding in current dropbar menu + + Parameters: ~ + • {opts} (table?): fuzzy find options, ignored if closing fuzzy + find + +api.fuzzy_find_navigate({direction}) *api.fuzzy_find_navigate* + + Navigate to the nth entry above/below in the menu while fuzzy finding + + Parameters: ~ + • {direction} ("up"|"down"|integer): + + - "up": navigate one entry upwards + - "down": navigate one entry downwards + - positive integer: navigate to the {direction}-th next entry + - negative integer: navigate to the {direction}-th previous + entry + +api.fuzzy_find_prev() *api.fuzzy_find_prev* + + Navigate to the previous entry in the menu while fuzzy finding + +api.fuzzy_find_next() *api.fuzzy_find_next* + + Navigate to the next entry in the menu while fuzzy finding + ------------------------------------------------------------------------------ UTILITY FUNCTIONS *dropbar-configuration-utility-functions* diff --git a/lua/dropbar/api.lua b/lua/dropbar/api.lua index 6cfb443e..fefc7fdf 100644 --- a/lua/dropbar/api.lua +++ b/lua/dropbar/api.lua @@ -1,9 +1,13 @@ +local utils = require('dropbar.utils') +local M = {} + +---@diagnostic disable ---Get the dropbar ---@param buf? integer ---@param win integer ---@return dropbar_t? ---@deprecated -local function get_dropbar(buf, win) +function M.get_dropbar(buf, win) buf = buf or vim.api.nvim_win_get_buf(win) if rawget(_G.dropbar.bars, buf) then return rawget(_G.dropbar.bars[buf], win) @@ -13,8 +17,8 @@ end ---Get current dropbar ---@return dropbar_t? ---@deprecated -local function get_current_dropbar() - return get_dropbar( +function M.get_current_dropbar() + return M.get_dropbar( vim.api.nvim_get_current_buf(), vim.api.nvim_get_current_win() ) @@ -24,25 +28,27 @@ end ---@param win integer ---@return dropbar_menu_t? ---@deprecated -local function get_dropbar_menu(win) +function M.get_dropbar_menu(win) return _G.dropbar.menus[win] end ---Get current dropbar menu ---@return dropbar_menu_t? ---@deprecated -local function get_current_dropbar_menu() - return get_dropbar_menu(vim.api.nvim_get_current_win()) +function M.get_current_dropbar_menu() + return M.get_dropbar_menu(vim.api.nvim_get_current_win()) end +---@diagnostic enable ---Goto the start of context ---If `count` is 0, goto the start of current context, or the start at ---prev context if cursor is already at the start of current context; ---If `count` is positive, goto the start of `count` prev context ---@param count integer? default vim.v.count -local function goto_context_start(count) +---@return nil +function M.goto_context_start(count) count = count or vim.v.count - local bar = get_current_dropbar() + local bar = utils.bar.get_current() if not bar or not bar.components or vim.tbl_isempty(bar.components) then return end @@ -70,8 +76,9 @@ local function goto_context_start(count) end ---Open the menu of current context to select the next context -local function select_next_context() - local bar = get_current_dropbar() +---@return nil +function M.select_next_context() + local bar = utils.bar.get_current() if not bar or not bar.components or vim.tbl_isempty(bar.components) then return end @@ -82,8 +89,9 @@ end ---Pick a component from current dropbar ---@param idx integer? -local function pick(idx) - local bar = get_current_dropbar() +---@return nil +function M.pick(idx) + local bar = utils.bar.get_current() if bar then bar:pick(idx) end @@ -91,8 +99,9 @@ end ---Toggle fuzzy finding in current dropbar menu ---@param opts table? fuzzy find options, ignored if closing fuzzy find -local function fuzzy_find_toggle(opts) - local menu = get_current_dropbar_menu() +---@return nil +function M.fuzzy_find_toggle(opts) + local menu = utils.menu.get_current() if not menu then return end @@ -110,34 +119,37 @@ end ---`0` or `-1` is supplied, in which case the *first* or *last* clickable component ---is selected, respectively. If it is a `function`, it receives the `dropbar_menu_entry_t` ---as an argument and should return the `dropbar_symbol_t` that is to be clicked. ----@param component? number|dropbar_symbol_t|fun(entry: dropbar_menu_entry_t):dropbar_symbol_t? -local function fuzzy_find_click(component) - local menu = get_current_dropbar_menu() +---@param component? integer|dropbar_symbol_t|fun(entry: dropbar_menu_entry_t):dropbar_symbol_t? +---@return nil +function M.fuzzy_find_click(component) + local menu = utils.menu.get_current() if not menu or not menu.fzf_state then return end menu:fuzzy_find_click_on_entry(component) end ----Select the previous/next entry in the menu while fuzzy finding ----@param direction "up" | "down" -local function fuzzy_find_navigate(direction) - local menu = get_current_dropbar_menu() +---Navigate to the nth entry above/below in the menu while fuzzy finding +---@param direction 'up'|'down'|integer +---@return nil +function M.fuzzy_find_navigate(direction) + local menu = utils.menu.get_current() if not menu or not menu.fzf_state then return end menu:fuzzy_find_navigate(direction) end -return { - get_dropbar = get_dropbar, - get_current_dropbar = get_current_dropbar, - get_dropbar_menu = get_dropbar_menu, - get_current_dropbar_menu = get_current_dropbar_menu, - goto_context_start = goto_context_start, - select_next_context = select_next_context, - pick = pick, - fuzzy_find_toggle = fuzzy_find_toggle, - fuzzy_find_click = fuzzy_find_click, - fuzzy_find_navigate = fuzzy_find_navigate, -} +---Navigate to the previous entry in the menu while fuzzy finding +---@return nil +function M.fuzzy_find_prev() + M.fuzzy_find_navigate(-1) +end + +---Navigate to the next entry in the menu while fuzzy finding +---@return nil +function M.fuzzy_find_next() + M.fuzzy_find_navigate(1) +end + +return M