aboutsummaryrefslogtreecommitdiffstats
path: root/commands
diff options
context:
space:
mode:
authorKevin Kuehler <kkuehler@brave.com>2019-06-10 22:05:57 -0700
committerDrew DeVault <sir@cmpwn.com>2019-06-11 09:34:48 -0400
commit9746f4858c6b21673a85a19df3ff8b8e076c36d5 (patch)
tree5bcedf8f02847ce2065a1a4ee3cdc3929318d19d /commands
parenta54f4adb8f28855e7a8e5f24072f4d969b3b674d (diff)
downloadaerc-9746f4858c6b21673a85a19df3ff8b8e076c36d5.tar.gz
commands/msgview: Add next/prev commands
Signed-off-by: Kevin Kuehler <kkuehler@brave.com>
Diffstat (limited to 'commands')
-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 7e8541f4..88c4fd4a 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 00000000..0c868397
--- /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
+}