* Add `webdev_colors_folder` option * Check if `M.devicons` exists * Refactor `get_folder_icon` * Add configuration options for both files and folders * web_devicons.*.enabled -> enable * silent migration: renderer.icons.webdev_colors -> renderer.icons.web_devicons.file.color * silent migration: renderer.icons.webdev_colors -> renderer.icons.web_devicons.file.color --------- Co-authored-by: Alexander Courtis <alex@courtis.org>
This commit is contained in:
@@ -362,7 +362,16 @@ applying configuration.
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
icons = {
|
icons = {
|
||||||
webdev_colors = true,
|
web_devicons = {
|
||||||
|
file = {
|
||||||
|
enable = true,
|
||||||
|
color = true,
|
||||||
|
},
|
||||||
|
folder = {
|
||||||
|
enable = false,
|
||||||
|
color = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
git_placement = "before",
|
git_placement = "before",
|
||||||
modified_placement = "after",
|
modified_placement = "after",
|
||||||
padding = " ",
|
padding = " ",
|
||||||
@@ -970,8 +979,31 @@ UI rendering setup
|
|||||||
*nvim-tree.renderer.icons*
|
*nvim-tree.renderer.icons*
|
||||||
Configuration options for icons.
|
Configuration options for icons.
|
||||||
|
|
||||||
*nvim-tree.renderer.icons.webdev_colors*
|
*nvim-tree.renderer.icons.web_devicons*
|
||||||
Use the webdev icon colors, otherwise `NvimTreeFileIcon`.
|
Configure optional plugin `"nvim-tree/nvim-web-devicons"`
|
||||||
|
|
||||||
|
*nvim-tree.renderer.icons.web_devicons.file*
|
||||||
|
File icons.
|
||||||
|
|
||||||
|
*nvim-tree.renderer.icons.web_devicons.file.enable*
|
||||||
|
Show icons on files.
|
||||||
|
Overrides |nvim-tree.renderer.icons.glyphs.default|
|
||||||
|
Type: `boolean`, Default: `true`
|
||||||
|
|
||||||
|
*nvim-tree.renderer.icons.web_devicons.file.color*
|
||||||
|
Use icon colors for files.
|
||||||
|
Type: `boolean`, Default: `true`
|
||||||
|
|
||||||
|
*nvim-tree.renderer.icons.web_devicons.folder*
|
||||||
|
Folder icons.
|
||||||
|
|
||||||
|
*nvim-tree.renderer.icons.web_devicons.folder.enable*
|
||||||
|
Show icons on folders.
|
||||||
|
Overrides |nvim-tree.renderer.icons.glyphs.folder|
|
||||||
|
Type: `boolean`, Default: `false`
|
||||||
|
|
||||||
|
*nvim-tree.renderer.icons.web_devicons.folder.color*
|
||||||
|
Use icon colors for folders.
|
||||||
Type: `boolean`, Default: `true`
|
Type: `boolean`, Default: `true`
|
||||||
|
|
||||||
*nvim-tree.renderer.icons.git_placement*
|
*nvim-tree.renderer.icons.git_placement*
|
||||||
@@ -999,7 +1031,7 @@ UI rendering setup
|
|||||||
Configuration options for showing icon types.
|
Configuration options for showing icon types.
|
||||||
|
|
||||||
*nvim-tree.renderer.icons.show.file*
|
*nvim-tree.renderer.icons.show.file*
|
||||||
Show an icon before the file name. `nvim-web-devicons` will be used if available.
|
Show an icon before the file name.
|
||||||
Type: `boolean`, Default: `true`
|
Type: `boolean`, Default: `true`
|
||||||
|
|
||||||
*nvim-tree.renderer.icons.show.folder*
|
*nvim-tree.renderer.icons.show.folder*
|
||||||
@@ -1027,7 +1059,8 @@ UI rendering setup
|
|||||||
to appear in the signcolumn.
|
to appear in the signcolumn.
|
||||||
|
|
||||||
*nvim-tree.renderer.icons.glyphs.default*
|
*nvim-tree.renderer.icons.glyphs.default*
|
||||||
Glyph for files. Will be overridden by `nvim-web-devicons` if available.
|
Glyph for files.
|
||||||
|
Overridden by |nvim-tree.renderer.icons.web_devicons| if available.
|
||||||
Type: `string`, Default: `""`
|
Type: `string`, Default: `""`
|
||||||
|
|
||||||
*nvim-tree.renderer.icons.glyphs.symlink*
|
*nvim-tree.renderer.icons.glyphs.symlink*
|
||||||
@@ -1040,6 +1073,7 @@ UI rendering setup
|
|||||||
|
|
||||||
*nvim-tree.renderer.icons.glyphs.folder*
|
*nvim-tree.renderer.icons.glyphs.folder*
|
||||||
Glyphs for directories.
|
Glyphs for directories.
|
||||||
|
Overridden by |nvim-tree.renderer.icons.web_devicons| if available.
|
||||||
Type: `table`, Default:
|
Type: `table`, Default:
|
||||||
`{`
|
`{`
|
||||||
`arrow_closed = "",`
|
`arrow_closed = "",`
|
||||||
|
|||||||
@@ -426,7 +426,16 @@ local DEFAULT_OPTS = { -- BEGIN_DEFAULT_OPTS
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
icons = {
|
icons = {
|
||||||
webdev_colors = true,
|
web_devicons = {
|
||||||
|
file = {
|
||||||
|
enable = true,
|
||||||
|
color = true,
|
||||||
|
},
|
||||||
|
folder = {
|
||||||
|
enable = false,
|
||||||
|
color = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
git_placement = "before",
|
git_placement = "before",
|
||||||
modified_placement = "after",
|
modified_placement = "after",
|
||||||
padding = " ",
|
padding = " ",
|
||||||
|
|||||||
@@ -38,6 +38,17 @@ local function refactored(opts)
|
|||||||
|
|
||||||
-- 2023/07/16
|
-- 2023/07/16
|
||||||
utils.move_missing_val(opts, "git", "ignore", opts, "filters", "git_ignored", true)
|
utils.move_missing_val(opts, "git", "ignore", opts, "filters", "git_ignored", true)
|
||||||
|
|
||||||
|
-- 2023/08/26
|
||||||
|
utils.move_missing_val(
|
||||||
|
opts,
|
||||||
|
"renderer.icons",
|
||||||
|
"webdev_colors",
|
||||||
|
opts,
|
||||||
|
"renderer.icons.web_devicons.file",
|
||||||
|
"color",
|
||||||
|
true
|
||||||
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function deprecated(opts)
|
local function deprecated(opts)
|
||||||
|
|||||||
@@ -130,11 +130,10 @@ end
|
|||||||
---@return HighlightedString icon, HighlightedString name
|
---@return HighlightedString icon, HighlightedString name
|
||||||
function Builder:_build_folder(node)
|
function Builder:_build_folder(node)
|
||||||
local has_children = #node.nodes ~= 0 or node.has_children
|
local has_children = #node.nodes ~= 0 or node.has_children
|
||||||
local icon = icons.get_folder_icon(node.open, node.link_to ~= nil, has_children)
|
local icon, icon_hl = icons.get_folder_icon(node, has_children)
|
||||||
local foldername = get_folder_name(node) .. self.trailing_slash
|
local foldername = get_folder_name(node) .. self.trailing_slash
|
||||||
|
|
||||||
local icon_hl
|
if #icon > 0 and icon_hl == nil then
|
||||||
if #icon > 0 then
|
|
||||||
if node.open then
|
if node.open then
|
||||||
icon_hl = "NvimTreeOpenedFolderIcon"
|
icon_hl = "NvimTreeOpenedFolderIcon"
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -9,13 +9,14 @@ local function empty()
|
|||||||
return ""
|
return ""
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_folder_icon(open, is_symlink, has_children)
|
local function get_folder_icon_default(node, has_children)
|
||||||
|
local is_symlink = node.links_to ~= nil
|
||||||
local n
|
local n
|
||||||
if is_symlink and open then
|
if is_symlink and node.open then
|
||||||
n = M.config.glyphs.folder.symlink_open
|
n = M.config.glyphs.folder.symlink_open
|
||||||
elseif is_symlink then
|
elseif is_symlink then
|
||||||
n = M.config.glyphs.folder.symlink
|
n = M.config.glyphs.folder.symlink
|
||||||
elseif open then
|
elseif node.open then
|
||||||
if has_children then
|
if has_children then
|
||||||
n = M.config.glyphs.folder.open
|
n = M.config.glyphs.folder.open
|
||||||
else
|
else
|
||||||
@@ -28,7 +29,19 @@ local function get_folder_icon(open, is_symlink, has_children)
|
|||||||
n = M.config.glyphs.folder.empty
|
n = M.config.glyphs.folder.empty
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return n
|
return n, nil
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_folder_icon_webdev(node, has_children)
|
||||||
|
local icon, hl_group = M.devicons.get_icon(node.name, node.extension)
|
||||||
|
if not M.config.web_devicons.folder.color then
|
||||||
|
hl_group = nil
|
||||||
|
end
|
||||||
|
if icon ~= nil then
|
||||||
|
return icon, hl_group
|
||||||
|
else
|
||||||
|
return get_folder_icon_default(node, has_children)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_file_icon_default()
|
local function get_file_icon_default()
|
||||||
@@ -43,7 +56,7 @@ end
|
|||||||
|
|
||||||
local function get_file_icon_webdev(fname, extension)
|
local function get_file_icon_webdev(fname, extension)
|
||||||
local icon, hl_group = M.devicons.get_icon(fname, extension)
|
local icon, hl_group = M.devicons.get_icon(fname, extension)
|
||||||
if not M.config.webdev_colors then
|
if not M.config.web_devicons.file.color then
|
||||||
hl_group = "NvimTreeFileIcon"
|
hl_group = "NvimTreeFileIcon"
|
||||||
end
|
end
|
||||||
if icon and hl_group ~= "DevIconDefault" then
|
if icon and hl_group ~= "DevIconDefault" then
|
||||||
@@ -58,7 +71,7 @@ end
|
|||||||
|
|
||||||
local function config_file_icon()
|
local function config_file_icon()
|
||||||
if M.config.show.file then
|
if M.config.show.file then
|
||||||
if M.devicons then
|
if M.devicons and M.config.web_devicons.file.enable then
|
||||||
M.get_file_icon = get_file_icon_webdev
|
M.get_file_icon = get_file_icon_webdev
|
||||||
else
|
else
|
||||||
M.get_file_icon = get_file_icon_default
|
M.get_file_icon = get_file_icon_default
|
||||||
@@ -70,7 +83,11 @@ end
|
|||||||
|
|
||||||
local function config_folder_icon()
|
local function config_folder_icon()
|
||||||
if M.config.show.folder then
|
if M.config.show.folder then
|
||||||
M.get_folder_icon = get_folder_icon
|
if M.devicons and M.config.web_devicons.folder.enable then
|
||||||
|
M.get_folder_icon = get_folder_icon_webdev
|
||||||
|
else
|
||||||
|
M.get_folder_icon = get_folder_icon_default
|
||||||
|
end
|
||||||
else
|
else
|
||||||
M.get_folder_icon = empty
|
M.get_folder_icon = empty
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user