* feat(#2948): add UserDecorator, proof of concept * feat(#2948): add UserDecorator, proof of concept * feat(#2948): add UserDecorator, proof of concept * feat(#2948): add UserDecorator * feat(#2948): add UserDecorator * feat(#2948): add UserDecorator * feat(#2948): add Decorator node icon override * feat(#2948): add nvim_tree.api.* node classes * feat(#2948): extract _meta following nvim pattern * feat(#2948): extract _meta following nvim pattern * feat(#2948): add decorator registry and order * feat(#2948): add decorator registry and order * feat(#2948): tidy * feat(#2948): document API * feat(#2948): document API * feat(#2948): document API * feat(#2948): pass api nodes to user decorators * feat(#2948): document API * feat(#2948): use renderer.decorators to define order and register * feat(#2948): tidy decorator args and complete documentation * feat(#2948): decorator classes specified by prefix rather than suffix * feat(#2948): improve doc * feat(#2948): improve doc * feat(#2948): improve doc * feat(#2948): additional user decorator safety * feat(#2948): create nvim_tree.api.decorator.UserDecorator class in API, add :extend * feat(#2948): improve doc
55 lines
1.5 KiB
Lua
55 lines
1.5 KiB
Lua
local Decorator = require("nvim-tree.renderer.decorator")
|
|
local DirectoryNode = require("nvim-tree.node.directory")
|
|
|
|
---@class (exact) HiddenDecorator: Decorator
|
|
---@field private explorer Explorer
|
|
---@field private icon HighlightedString?
|
|
local HiddenDecorator = Decorator:extend()
|
|
|
|
---@class HiddenDecorator
|
|
---@overload fun(args: DecoratorArgs): HiddenDecorator
|
|
|
|
---@protected
|
|
---@param args DecoratorArgs
|
|
function HiddenDecorator:new(args)
|
|
self.explorer = args.explorer
|
|
|
|
self.enabled = true
|
|
self.highlight_range = self.explorer.opts.renderer.highlight_hidden or "none"
|
|
self.icon_placement = self.explorer.opts.renderer.icons.hidden_placement or "none"
|
|
|
|
if self.explorer.opts.renderer.icons.show.hidden then
|
|
self.icon = {
|
|
str = self.explorer.opts.renderer.icons.glyphs.hidden,
|
|
hl = { "NvimTreeHiddenIcon" },
|
|
}
|
|
self:define_sign(self.icon)
|
|
end
|
|
end
|
|
|
|
---Hidden icon: renderer.icons.show.hidden and node starts with `.` (dotfile).
|
|
---@param node Node
|
|
---@return HighlightedString[]? icons
|
|
function HiddenDecorator:icons(node)
|
|
if node:is_dotfile() then
|
|
return { self.icon }
|
|
end
|
|
end
|
|
|
|
---Hidden highlight: renderer.highlight_hidden and node starts with `.` (dotfile).
|
|
---@param node Node
|
|
---@return string? highlight_group
|
|
function HiddenDecorator:highlight_group(node)
|
|
if self.highlight_range == "none" or not node:is_dotfile() then
|
|
return nil
|
|
end
|
|
|
|
if node:is(DirectoryNode) then
|
|
return "NvimTreeHiddenFolderHL"
|
|
else
|
|
return "NvimTreeHiddenFileHL"
|
|
end
|
|
end
|
|
|
|
return HiddenDecorator
|