* fix(#3143): ensure open.no_window_picker respects window_picker.exclude * fix(#3143): doc --------- Co-authored-by: Alexander Courtis <alex@courtis.org>
This commit is contained in:
parent
1c733e8c19
commit
05d8172ebf
@ -1523,7 +1523,8 @@ Configuration options for opening a file from nvim-tree.
|
|||||||
|
|
||||||
*nvim-tree.actions.open_file.window_picker.enable*
|
*nvim-tree.actions.open_file.window_picker.enable*
|
||||||
Enable the feature. If the feature is not enabled, files will open in
|
Enable the feature. If the feature is not enabled, files will open in
|
||||||
window from which you last opened the tree.
|
window from which you last opened the tree, obeying
|
||||||
|
|nvim-tree.actions.open_file.window_picker.exclude|
|
||||||
Type: `boolean`, Default: `true`
|
Type: `boolean`, Default: `true`
|
||||||
|
|
||||||
*nvim-tree.actions.open_file.window_picker.picker*
|
*nvim-tree.actions.open_file.window_picker.picker*
|
||||||
@ -1542,9 +1543,10 @@ Configuration options for opening a file from nvim-tree.
|
|||||||
Type: `string`, Default: `"ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"`
|
Type: `string`, Default: `"ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"`
|
||||||
|
|
||||||
*nvim-tree.actions.open_file.window_picker.exclude*
|
*nvim-tree.actions.open_file.window_picker.exclude*
|
||||||
Table of buffer option names mapped to a list of option values that
|
Table of buffer option names mapped to a list of option values.
|
||||||
indicates to the picker that the buffer's window should not be
|
Windows containing matching buffers will not be:
|
||||||
selectable.
|
- available when using a window picker
|
||||||
|
- selected when not using a window picker
|
||||||
Type: `table`, Default: >lua
|
Type: `table`, Default: >lua
|
||||||
{
|
{
|
||||||
filetype = {
|
filetype = {
|
||||||
|
|||||||
@ -43,17 +43,6 @@ local function usable_win_ids()
|
|||||||
end, win_ids)
|
end, win_ids)
|
||||||
end
|
end
|
||||||
|
|
||||||
---Find the first window in the tab that is not NvimTree.
|
|
||||||
---@return integer -1 if none available
|
|
||||||
local function first_win_id()
|
|
||||||
local selectable = usable_win_ids()
|
|
||||||
if #selectable > 0 then
|
|
||||||
return selectable[1]
|
|
||||||
else
|
|
||||||
return -1
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
---Get user to pick a window in the tab that is not NvimTree.
|
---Get user to pick a window in the tab that is not NvimTree.
|
||||||
---@return integer|nil -- If a valid window was picked, return its id. If an
|
---@return integer|nil -- If a valid window was picked, return its id. If an
|
||||||
--- invalid window was picked / user canceled, return nil. If there are
|
--- invalid window was picked / user canceled, return nil. If there are
|
||||||
@ -246,9 +235,14 @@ local function get_target_winid(mode)
|
|||||||
local target_winid
|
local target_winid
|
||||||
if not M.window_picker.enable or string.find(mode, "no_picker") then
|
if not M.window_picker.enable or string.find(mode, "no_picker") then
|
||||||
target_winid = lib.target_winid
|
target_winid = lib.target_winid
|
||||||
-- first available window
|
local usable_wins = usable_win_ids()
|
||||||
if not vim.tbl_contains(vim.api.nvim_tabpage_list_wins(0), target_winid) then
|
-- first available usable window
|
||||||
target_winid = first_win_id()
|
if not vim.tbl_contains(usable_wins, target_winid) then
|
||||||
|
if #usable_wins > 0 then
|
||||||
|
target_winid = usable_wins[1]
|
||||||
|
else
|
||||||
|
target_winid = -1
|
||||||
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
-- pick a window
|
-- pick a window
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user