store: keep current message selected

Keep current message selected when clearing or changing filters and when
toggling threads.

Add -s flag to the clear command to also clear the selected message and
set cursor to the top of the message list.

Implements: https://todo.sr.ht/~rjarry/aerc/36
Signed-off-by: Koni Marti <koni.marti@gmail.com>
Acked-by: Robin Jarry <robin@jarry.cc>
This commit is contained in:
Koni Marti 2022-04-16 00:22:20 +02:00 committed by Robin Jarry
parent a34be9eb36
commit cb887a2d9d
4 changed files with 55 additions and 2 deletions
commands

View file

@ -5,6 +5,7 @@ import (
"git.sr.ht/~rjarry/aerc/lib/statusline"
"git.sr.ht/~rjarry/aerc/widgets"
"git.sr.ht/~sircmpwn/getopt"
)
type Clear struct{}
@ -30,6 +31,30 @@ func (Clear) Execute(aerc *widgets.Aerc, args []string) error {
if store == nil {
return errors.New("Cannot perform action. Messages still loading")
}
clearSelected := false
opts, optind, err := getopt.Getopts(args, "s")
if err != nil {
return err
}
for _, opt := range opts {
switch opt.Option {
case 's':
clearSelected = true
}
}
if len(args) != optind {
return errors.New("Usage: clear [-s]")
}
if clearSelected {
defer store.Select(0)
} else {
defer store.Reselect(store.Selected())
}
store.ApplyClear()
acct.SetStatus(statusline.SearchFilterClear())

View file

@ -34,6 +34,7 @@ func (ToggleThreads) Execute(aerc *widgets.Aerc, args []string) error {
if err != nil {
return err
}
defer store.Reselect(store.Selected())
store.SetBuildThreads(!store.BuildThreads())
acct.SetStatus(statusline.Threading(store.BuildThreads()))
acct.Messages().Invalidate()