Skip to content

Commit

Permalink
WIP: collapse/uncollapse all files in tree
Browse files Browse the repository at this point in the history
Seems like this feature is highly requested jesseduffield#4095 jesseduffield#3554

Did a quick wip pr. I got the core functionality working with files and
had some questions on what can be improved in order to polish it more.
I.e. What keymaps if any to add to these, should the functionality be to
toggle vs collapse and uncollapse separately, and if this should be
added anywhere else (right now it's just for the file tree)

Once I figure this out I can add the tests, documentations and anything
else that's missing. I'm also pretty new to the language so if there's a
way I can structure this better please let me know
  • Loading branch information
mtrajano committed Dec 27, 2024
1 parent ec410b2 commit 4549290
Show file tree
Hide file tree
Showing 3 changed files with 55 additions and 3 deletions.
34 changes: 34 additions & 0 deletions pkg/gui/controllers/files_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,12 @@ func (self *FilesController) GetKeybindings(opts types.KeybindingsOpts) []*types
Description: self.c.Tr.Fetch,
Tooltip: self.c.Tr.FetchTooltip,
},
{
Key: 'z',
Handler: self.collapseAll,
// GetDisabledReason: self.require(self.singleItemSelected()),
Description: "Collapse All directories",
},
}
}

Expand Down Expand Up @@ -478,6 +484,34 @@ func (self *FilesController) enter() error {
return self.EnterFile(types.OnFocusOpts{ClickedWindowName: "", ClickedViewLineIdx: -1})
}

func (self *FilesController) collapseAll() error {
nodes := self.context().GetAllItems()

dirPaths := lo.FilterMap(nodes, func(file *filetree.FileNode, index int) (string, bool) {
return file.Path, !file.IsFile()
})

self.context().FileTreeViewModel.CollapseAll(dirPaths)

self.c.PostRefreshUpdate(self.c.Contexts().Files)

return nil
}

func (self *FilesController) uncollapseAll() error {
files := self.context().GetAllFiles()

filePaths := lo.Map(files, func(file *models.File, index int) string {
return file.GetPath()
})

self.context().FileTreeViewModel.UncollapseAll(filePaths)

self.c.PostRefreshUpdate(self.c.Contexts().Files)

return nil
}

func (self *FilesController) EnterFile(opts types.OnFocusOpts) error {
node := self.context().GetSelected()
if node == nil {
Expand Down
10 changes: 7 additions & 3 deletions pkg/gui/filetree/collapsed_paths.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,10 +29,14 @@ func (self *CollapsedPaths) Collapse(path string) {
self.collapsedPaths.Add(path)
}

func (self *CollapsedPaths) Uncollapse(path string) {
self.collapsedPaths.Remove(path)
}

func (self *CollapsedPaths) ToggleCollapsed(path string) {
if self.collapsedPaths.Includes(path) {
self.collapsedPaths.Remove(path)
if self.IsCollapsed(path) {
self.Uncollapse(path)
} else {
self.collapsedPaths.Add(path)
self.Collapse(path)
}
}
14 changes: 14 additions & 0 deletions pkg/gui/filetree/file_tree.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,8 @@ type IFileTree interface {
GetAllFiles() []*models.File
GetFilter() FileTreeDisplayFilter
GetRoot() *FileNode
CollapseAll(paths []string)
UncollapseAll(paths []string)
}

type FileTree struct {
Expand Down Expand Up @@ -171,6 +173,18 @@ func (self *FileTree) ToggleCollapsed(path string) {
self.collapsedPaths.ToggleCollapsed(path)
}

func (self *FileTree) CollapseAll(paths []string) {
for _, path := range paths {
self.collapsedPaths.Collapse(path)
}
}

func (self *FileTree) UncollapseAll(paths []string) {
for _, path := range paths {
self.collapsedPaths.ExpandToPath(path)
}
}

func (self *FileTree) Tree() *FileNode {
return NewFileNode(self.tree)
}
Expand Down

0 comments on commit 4549290

Please sign in to comment.