blob: a232c7c380cc84bdb8c918a4e20ec077173c4c32 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Directory Tree</title>
<style>
ul {
list-style-type: none;
}
.directory {
font-weight: bold;
}
</style>
</head>
<body>
<h1>Files Directory Tree</h1>
<div id="directory-tree"></div>
<script>
async function fetchDirectoryTree() {
const response = await fetch('/api/files');
return response.json();
}
function createTreeElement(node) {
const li = document.createElement('li');
li.textContent = node.name;
if (node.isDirectory) {
li.classList.add('directory');
const ul = document.createElement('ul');
node.children.forEach(child => {
ul.appendChild(createTreeElement(child));
});
li.appendChild(ul);
}
return li;
}
async function displayDirectoryTree() {
const tree = await fetchDirectoryTree();
const treeContainer = document.getElementById('directory-tree');
const ul = document.createElement('ul');
tree.forEach(node => {
ul.appendChild(createTreeElement(node));
});
treeContainer.appendChild(ul);
}
displayDirectoryTree();
</script>
</body>
</html>
|