I was able to build out a fairly easy class to generate trees given a filepath:
class FileTree:
def __init__(self, filepath: os.PathLike):
self.filepath = filepath
def render(self) -> dmc.Accordion:
return dmc.Accordion(
self.build_tree(self.filepath, isRoot=True),
multiple=True)
def flatten(self, l):
return [item for sublist in l for item in sublist]
def make_file(self, file_name):
return dmc.Text(
[DashIconify(icon="akar-icons:file"), " ", file_name], style={"paddingTop": '5px'}
)
def make_folder(self, folder_name):
return [DashIconify(icon="akar-icons:folder"), " ", folder_name]
def build_tree(self, path, isRoot=False):
d = []
if os.path.isdir(path):
children = self.flatten([self.build_tree(os.path.join(path, x))
for x in os.listdir(path)])
if isRoot:
d.append(
dmc.AccordionItem(
children=children,
label=self.make_folder(os.path.basename(path)))
)
else:
d.append(
dmc.Accordion(children=[
dmc.AccordionItem(
children=children,
label=self.make_folder(os.path.basename(path)))
],
multiple=True)
)
else:
d.append(self.make_file(os.path.basename(path)))
return d
# Usage
import dash_mantine_components as dmc
import os
from dash import Dash
from dash_iconify import DashIconify
app = Dash()
filepath = 'Users/andrew' # Any filepath here
app.layout = FileTree(filepath).render()
app.run_server()