-
-
Notifications
You must be signed in to change notification settings - Fork 578
TreeView
rivo edited this page May 28, 2021
·
3 revisions
A navigable tree view for hierarchically structured data, with expand/collapse functionality. The following example is a simple file system explorer:
Code:
package main
import (
"io/ioutil"
"path/filepath"
"github.com/gdamore/tcell/v2"
"github.com/rivo/tview"
)
// Show a navigable tree view of the current directory.
func main() {
rootDir := "."
root := tview.NewTreeNode(rootDir).
SetColor(tcell.ColorRed)
tree := tview.NewTreeView().
SetRoot(root).
SetCurrentNode(root)
// A helper function which adds the files and directories of the given path
// to the given target node.
add := func(target *tview.TreeNode, path string) {
files, err := ioutil.ReadDir(path)
if err != nil {
panic(err)
}
for _, file := range files {
node := tview.NewTreeNode(file.Name()).
SetReference(filepath.Join(path, file.Name())).
SetSelectable(file.IsDir())
if file.IsDir() {
node.SetColor(tcell.ColorGreen)
}
target.AddChild(node)
}
}
// Add the current directory to the root node.
add(root, rootDir)
// If a directory was selected, open it.
tree.SetSelectedFunc(func(node *tview.TreeNode) {
reference := node.GetReference()
if reference == nil {
return // Selecting the root node does nothing.
}
children := node.GetChildren()
if len(children) == 0 {
// Load and show files in this directory.
path := reference.(string)
add(node, path)
} else {
// Collapse if visible, expand if collapsed.
node.SetExpanded(!node.IsExpanded())
}
})
if err := tview.NewApplication().SetRoot(tree, true).Run(); err != nil {
panic(err)
}
}