* coding style
* outlined git.show_on_open_dirs behavior
* show some icon on opendir even if show_on_open_dir=false
and show all children's status on parent
* fixed renamed icon not showing
* sorted icons
* removed DU from deleted as file will show up in tree
* fixed update_git_status in reloaders not tested
* fixed Api.git.reload()
Tested update_git_status in reloaders.lua
* sort icon only if not git signcolumn
* fixed crashing when root dir isn't git dir
* made git.show_on_dirs doc more concise
* git_statuses -> git_status for consistency
* explorer/common.lua -> explorer/node.lua
* fixed #1784 conflict
* don't order icons
* Revert "don't order icons"
This reverts commit 23f6276ef7.
62 lines
1.9 KiB
Lua
62 lines
1.9 KiB
Lua
local git = require "nvim-tree.git"
|
|
local view = require "nvim-tree.view"
|
|
local renderer = require "nvim-tree.renderer"
|
|
local explorer_module = require "nvim-tree.explorer"
|
|
local core = require "nvim-tree.core"
|
|
local explorer_node = require "nvim-tree.explorer.node"
|
|
|
|
local M = {}
|
|
|
|
local function refresh_nodes(node, projects, unloaded_bufnr)
|
|
local cwd = node.cwd or node.link_to or node.absolute_path
|
|
local project_root = git.get_project_root(cwd)
|
|
explorer_module.reload(node, projects[project_root] or {}, unloaded_bufnr)
|
|
for _, _node in ipairs(node.nodes) do
|
|
if _node.nodes and _node.open then
|
|
refresh_nodes(_node, projects, unloaded_bufnr)
|
|
end
|
|
end
|
|
end
|
|
|
|
function M.reload_node_status(parent_node, projects)
|
|
local project_root = git.get_project_root(parent_node.absolute_path)
|
|
local status = projects[project_root] or {}
|
|
for _, node in ipairs(parent_node.nodes) do
|
|
explorer_node.update_git_status(node, explorer_node.is_git_ignored(parent_node), status)
|
|
if node.nodes and #node.nodes > 0 then
|
|
M.reload_node_status(node, projects)
|
|
end
|
|
end
|
|
end
|
|
|
|
local event_running = false
|
|
---@param _ table unused node passed by action
|
|
---@param unloaded_bufnr number optional bufnr recently unloaded via BufUnload event
|
|
function M.reload_explorer(_, unloaded_bufnr)
|
|
if event_running or not core.get_explorer() or vim.v.exiting ~= vim.NIL then
|
|
return
|
|
end
|
|
event_running = true
|
|
|
|
local projects = git.reload()
|
|
refresh_nodes(core.get_explorer(), projects, unloaded_bufnr)
|
|
if view.is_visible() then
|
|
renderer.draw(unloaded_bufnr)
|
|
end
|
|
event_running = false
|
|
end
|
|
|
|
function M.reload_git()
|
|
if not core.get_explorer() or not git.config.git.enable or event_running then
|
|
return
|
|
end
|
|
event_running = true
|
|
|
|
local projects = git.reload()
|
|
M.reload_node_status(core.get_explorer(), projects)
|
|
renderer.draw()
|
|
event_running = false
|
|
end
|
|
|
|
return M
|