diff options
Diffstat (limited to 'commands')
-rw-r--r-- | commands/account/pipe.go | 3 | ||||
-rw-r--r-- | commands/account/view-message.go | 27 |
2 files changed, 27 insertions, 3 deletions
diff --git a/commands/account/pipe.go b/commands/account/pipe.go index b07a860d..18130eb7 100644 --- a/commands/account/pipe.go +++ b/commands/account/pipe.go @@ -20,9 +20,6 @@ func Pipe(aerc *widgets.Aerc, args []string) error { return errors.New("Usage: :pipe <cmd> [args...]") } acct := aerc.SelectedAccount() - if acct == nil { - return errors.New("No account selected") - } store := acct.Messages().Store() msg := acct.Messages().Selected() store.FetchBodies([]uint32{msg.Uid}, func(reader io.Reader) { diff --git a/commands/account/view-message.go b/commands/account/view-message.go new file mode 100644 index 00000000..bef27407 --- /dev/null +++ b/commands/account/view-message.go @@ -0,0 +1,27 @@ +package account + +import ( + "errors" + + "github.com/mattn/go-runewidth" + + "git.sr.ht/~sircmpwn/aerc2/widgets" +) + +func init() { + register("view-message", ViewMessage) +} + +func ViewMessage(aerc *widgets.Aerc, args []string) error { + if len(args) != 1 { + return errors.New("Usage: view-message") + } + acct := aerc.SelectedAccount() + store := acct.Messages().Store() + msg := acct.Messages().Selected() + viewer := widgets.NewMessageViewer(store, msg) + aerc.NewTab(viewer, runewidth.Truncate( + msg.Envelope.Subject, 32, "…")) + return nil +} + |