commands/msgview: Add next/prev commands

Signed-off-by: Kevin Kuehler <kkuehler@brave.com>
This commit is contained in:
Kevin Kuehler 2019-06-10 22:05:57 -07:00 committed by Drew DeVault
parent a54f4adb8f
commit 9746f4858c
2 changed files with 40 additions and 2 deletions

View File

@ -48,9 +48,11 @@ func NextPrevMessage(aerc *widgets.Aerc, args []string) error {
} }
for ; n > 0; n-- { for ; n > 0; n-- {
if args[0] == "prev-message" || args[0] == "prev" { if args[0] == "prev-message" || args[0] == "prev" {
acct.Messages().Prev() acct.Store().Prev()
acct.Messages().Scroll()
} else { } else {
acct.Messages().Next() acct.Store().Next()
acct.Messages().Scroll()
} }
} }
return nil return nil

36
commands/msgview/next.go Normal file
View File

@ -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
}