1bedb8fe06
As suggested in #268, this adds a behaviour setting for deleting message from message viewer.
68 lines
1.6 KiB
Go
68 lines
1.6 KiB
Go
package msg
|
|
|
|
import (
|
|
"errors"
|
|
"time"
|
|
|
|
"github.com/gdamore/tcell"
|
|
|
|
"git.sr.ht/~sircmpwn/aerc/widgets"
|
|
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
|
)
|
|
|
|
type Delete struct{}
|
|
|
|
func init() {
|
|
register(Delete{})
|
|
}
|
|
|
|
func (Delete) Aliases() []string {
|
|
return []string{"delete", "delete-message"}
|
|
}
|
|
|
|
func (Delete) Complete(aerc *widgets.Aerc, args []string) []string {
|
|
return nil
|
|
}
|
|
|
|
func (Delete) Execute(aerc *widgets.Aerc, args []string) error {
|
|
if len(args) != 1 {
|
|
return errors.New("Usage: :delete")
|
|
}
|
|
|
|
widget := aerc.SelectedTab().(widgets.ProvidesMessage)
|
|
acct := widget.SelectedAccount()
|
|
if acct == nil {
|
|
return errors.New("No account selected")
|
|
}
|
|
store := widget.Store()
|
|
if store == nil {
|
|
return errors.New("Cannot perform action. Messages still loading")
|
|
}
|
|
msg, err := widget.SelectedMessage()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
_, isMsgView := widget.(*widgets.MessageViewer)
|
|
mv, _ := aerc.SelectedTab().(*widgets.MessageViewer)
|
|
store.Next()
|
|
if isMsgView {
|
|
nextMsg := store.Selected()
|
|
if nextMsg == msg || !aerc.Config().Ui.NextMessageOnDelete {
|
|
aerc.RemoveTab(widget)
|
|
acct.Messages().Scroll()
|
|
} else {
|
|
nextMv := widgets.NewMessageViewer(acct, aerc.Config(), store, nextMsg)
|
|
aerc.ReplaceTab(mv, nextMv, nextMsg.Envelope.Subject)
|
|
}
|
|
}
|
|
store.Delete([]uint32{msg.Uid}, func(msg types.WorkerMessage) {
|
|
switch msg := msg.(type) {
|
|
case *types.Done:
|
|
aerc.PushStatus("Messages deleted.", 10*time.Second)
|
|
case *types.Error:
|
|
aerc.PushStatus(" "+msg.Error.Error(), 10*time.Second).
|
|
Color(tcell.ColorDefault, tcell.ColorRed)
|
|
}
|
|
})
|
|
return nil
|
|
}
|