about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--commands/account/next.go6
-rw-r--r--commands/msgview/next.go36
2 files changed, 40 insertions, 2 deletions
diff --git a/commands/account/next.go b/commands/account/next.go
index 7e8541f..88c4fd4 100644
--- a/commands/account/next.go
+++ b/commands/account/next.go
@@ -48,9 +48,11 @@ func NextPrevMessage(aerc *widgets.Aerc, args []string) error {
 	}
 	for ; n > 0; n-- {
 		if args[0] == "prev-message" || args[0] == "prev" {
-			acct.Messages().Prev()
+			acct.Store().Prev()
+			acct.Messages().Scroll()
 		} else {
-			acct.Messages().Next()
+			acct.Store().Next()
+			acct.Messages().Scroll()
 		}
 	}
 	return nil
diff --git a/commands/msgview/next.go b/commands/msgview/next.go
new file mode 100644
index 0000000..0c86839
--- /dev/null
+++ b/commands/msgview/next.go
@@ -0,0 +1,36 @@
+package msgview
+
+import (
+	"errors"
+
+	"git.sr.ht/~sircmpwn/aerc/widgets"
+)
+
+func init() {
+	register("next", NextPrevMessage)
+	register("next-message", NextPrevMessage)
+	register("prev", NextPrevMessage)
+	register("prev-message", NextPrevMessage)
+}
+
+func NextPrevMessage(aerc *widgets.Aerc, args []string) error {
+	mv, _ := aerc.SelectedTab().(*widgets.MessageViewer)
+	acct := mv.SelectedAccount()
+	store := mv.Store()
+	if acct == nil {
+		return errors.New("No account selected")
+	}
+	if args[0] == "prev-message" || args[0] == "prev" {
+		store.Prev()
+	} else {
+		store.Next()
+	}
+	nextMsg := store.Selected()
+	if nextMsg == nil {
+		aerc.RemoveTab(mv)
+		return nil
+	}
+	nextMv := widgets.NewMessageViewer(acct, aerc.Config(), store, nextMsg)
+	aerc.ReplaceTab(mv, nextMv, nextMsg.Envelope.Subject)
+	return nil
+}