aerc/commands/account/next.go
Jeffas 15b72df1da Rework msglist scrolling
This changes the scrolling to be done on the draw, when the height is
updated, ensuring that the selected item is kept on screen during
resizing.

Also, this ensures that messages will fill the screen when resizing the
window, for instance, shrinking and then growing drags down more
messages if possible.

This is a transplant of the dirlist scrolling logic.
2020-06-09 21:52:10 +02:00

82 lines
1.6 KiB
Go

package account
import (
"errors"
"fmt"
"strconv"
"strings"
"git.sr.ht/~sircmpwn/aerc/widgets"
)
type NextPrevMsg struct{}
func init() {
register(NextPrevMsg{})
}
func (NextPrevMsg) Aliases() []string {
return []string{"next", "next-message", "prev", "prev-message"}
}
func (NextPrevMsg) Complete(aerc *widgets.Aerc, args []string) []string {
return nil
}
func (NextPrevMsg) Execute(aerc *widgets.Aerc, args []string) error {
n, pct, err := ParseNextPrevMessage(args)
if err != nil {
return err
}
acct := aerc.SelectedAccount()
if acct == nil {
return errors.New("No account selected")
}
return ExecuteNextPrevMessage(args, acct, pct, n)
}
func ParseNextPrevMessage(args []string) (int, bool, error) {
if len(args) > 2 {
return 0, false, nextPrevMessageUsage(args[0])
}
var (
n int = 1
err error
pct bool
)
if len(args) > 1 {
if strings.HasSuffix(args[1], "%") {
pct = true
args[1] = args[1][:len(args[1])-1]
}
n, err = strconv.Atoi(args[1])
if err != nil {
return 0, false, nextPrevMessageUsage(args[0])
}
}
return n, pct, nil
}
func ExecuteNextPrevMessage(args []string, acct *widgets.AccountView, pct bool, n int) error {
if pct {
n = int(float64(acct.Messages().Height()) * (float64(n) / 100.0))
}
if args[0] == "prev-message" || args[0] == "prev" {
store := acct.Store()
if store != nil {
store.NextPrev(-n)
acct.Messages().Invalidate()
}
} else {
store := acct.Store()
if store != nil {
store.NextPrev(n)
acct.Messages().Invalidate()
}
}
return nil
}
func nextPrevMessageUsage(cmd string) error {
return fmt.Errorf("Usage: %s [<n>[%%]]", cmd)
}