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:
parent
a34be9eb36
commit
cb887a2d9d
4 changed files with 55 additions and 2 deletions
commands
|
@ -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())
|
||||
|
||||
|
|
|
@ -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()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue