about summary refs log tree commit diff stats
path: root/widgets
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2019-03-14 22:34:34 -0400
committerDrew DeVault <sir@cmpwn.com>2019-03-14 22:34:34 -0400
commit62946ff6c5712bebf7f07a83fc077d40db0e73a8 (patch)
treed135e824abb0faf5d2a0baa70a0ae6b9bb8b5ebc /widgets
parentde364846ccaba3b93c383add3846443048f1c2c9 (diff)
downloadaerc-62946ff6c5712bebf7f07a83fc077d40db0e73a8.tar.gz
Implement :cd command
Diffstat (limited to 'widgets')
-rw-r--r--widgets/account.go5
-rw-r--r--widgets/directories.go18
2 files changed, 21 insertions, 2 deletions
diff --git a/widgets/account.go b/widgets/account.go
index 5747f4b..d22b1c6 100644
--- a/widgets/account.go
+++ b/widgets/account.go
@@ -90,6 +90,10 @@ func NewAccountView(conf *config.AccountConfig,
 	return acct
 }
 
+func (acct *AccountView) Name() string {
+	return acct.conf.Name
+}
+
 func (acct *AccountView) Children() []ui.Drawable {
 	return acct.grid.Children()
 }
@@ -173,6 +177,7 @@ func (acct *AccountView) onMessage(msg types.WorkerMessage) {
 	case *types.Done:
 		switch msg.InResponseTo().(type) {
 		case *types.OpenDirectory:
+			acct.msglist.SetStore(nil)
 			acct.worker.PostAction(&types.FetchDirectoryContents{},
 				func(msg types.WorkerMessage) {
 					store := acct.msgStores[acct.dirlist.selected]
diff --git a/widgets/directories.go b/widgets/directories.go
index ae31d29..d66ae1f 100644
--- a/widgets/directories.go
+++ b/widgets/directories.go
@@ -16,6 +16,7 @@ type DirectoryList struct {
 	dirs         []string
 	logger       *log.Logger
 	onInvalidate func(d ui.Drawable)
+	selecting    string
 	selected     string
 	spinner      *Spinner
 	worker       *types.Worker
@@ -58,11 +59,24 @@ func (dirlist *DirectoryList) UpdateList(done func(dirs []string)) {
 }
 
 func (dirlist *DirectoryList) Select(name string) {
-	dirlist.selected = name
-	dirlist.worker.PostAction(&types.OpenDirectory{Directory: name}, nil)
+	dirlist.selecting = name
+	dirlist.worker.PostAction(&types.OpenDirectory{Directory: name},
+		func(msg types.WorkerMessage) {
+			switch msg.(type) {
+			case *types.Error:
+				dirlist.selecting = ""
+			default:
+				dirlist.selected = dirlist.selecting
+			}
+			dirlist.Invalidate()
+		})
 	dirlist.Invalidate()
 }
 
+func (dirlist *DirectoryList) Selected() string {
+	return dirlist.selected
+}
+
 func (dirlist *DirectoryList) OnInvalidate(onInvalidate func(d ui.Drawable)) {
 	dirlist.onInvalidate = onInvalidate
 }