|
@@ -40,99 +40,107 @@ func NewMessageInput(app *App) *MessageInput {
|
|
|
func (mi *MessageInput) onInputCapture(e *tcell.EventKey) *tcell.EventKey {
|
|
func (mi *MessageInput) onInputCapture(e *tcell.EventKey) *tcell.EventKey {
|
|
|
switch e.Name() {
|
|
switch e.Name() {
|
|
|
case "Enter":
|
|
case "Enter":
|
|
|
- if mi.app.ChannelsTree.SelectedChannel == nil {
|
|
|
|
|
- return nil
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- t := strings.TrimSpace(mi.app.MessageInputField.GetText())
|
|
|
|
|
- if t == "" {
|
|
|
|
|
- return nil
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- ms, err := mi.app.State.Messages(mi.app.ChannelsTree.SelectedChannel.ID, mi.app.Config.MessagesLimit)
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return nil
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ return mi.sendMessage()
|
|
|
|
|
+ case "Ctrl+V":
|
|
|
|
|
+ return mi.pasteFromClipboard()
|
|
|
|
|
+ case "Esc":
|
|
|
|
|
+ mi.
|
|
|
|
|
+ SetText("").
|
|
|
|
|
+ SetTitle("")
|
|
|
|
|
+ mi.app.SetFocus(mi.app.MainFlex)
|
|
|
|
|
|
|
|
- if len(mi.app.MessagesPanel.GetHighlights()) != 0 {
|
|
|
|
|
- mID, err := discord.ParseSnowflake(mi.app.MessagesPanel.GetHighlights()[0])
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return nil
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ mi.app.MessagesPanel.SelectedMessage = -1
|
|
|
|
|
+ mi.app.MessagesPanel.Highlight()
|
|
|
|
|
+ return nil
|
|
|
|
|
+ case mi.app.Config.Keys.OpenExternalEditor:
|
|
|
|
|
+ return mi.openExternalEditor()
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- _, m := findMessageByID(ms, discord.MessageID(mID))
|
|
|
|
|
- d := api.SendMessageData{
|
|
|
|
|
- Content: t,
|
|
|
|
|
- Reference: m.Reference,
|
|
|
|
|
- AllowedMentions: &api.AllowedMentions{RepliedUser: option.False},
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ return e
|
|
|
|
|
+}
|
|
|
|
|
|
|
|
- // If the title of the message InputField widget has "[@]" as a prefix, send the message as a reply and mention the replied user.
|
|
|
|
|
- if strings.HasPrefix(mi.app.MessageInputField.GetTitle(), "[@]") {
|
|
|
|
|
- d.AllowedMentions.RepliedUser = option.True
|
|
|
|
|
- }
|
|
|
|
|
|
|
+func (mi *MessageInput) sendMessage() *tcell.EventKey {
|
|
|
|
|
+ if mi.app.ChannelsTree.SelectedChannel == nil {
|
|
|
|
|
+ return nil
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- go mi.app.State.SendMessageComplex(m.ChannelID, d)
|
|
|
|
|
|
|
+ t := strings.TrimSpace(mi.GetText())
|
|
|
|
|
+ if t == "" {
|
|
|
|
|
+ return nil
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- mi.app.MessagesPanel.SelectedMessage = -1
|
|
|
|
|
- mi.app.MessagesPanel.Highlight()
|
|
|
|
|
|
|
+ ms, err := mi.app.State.Messages(mi.app.ChannelsTree.SelectedChannel.ID, mi.app.Config.MessagesLimit)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return nil
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- mi.app.MessageInputField.SetTitle("")
|
|
|
|
|
- } else {
|
|
|
|
|
- go mi.app.State.SendMessage(mi.app.ChannelsTree.SelectedChannel.ID, t)
|
|
|
|
|
|
|
+ if len(mi.app.MessagesPanel.GetHighlights()) != 0 {
|
|
|
|
|
+ mID, err := discord.ParseSnowflake(mi.app.MessagesPanel.GetHighlights()[0])
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- mi.app.MessageInputField.SetText("")
|
|
|
|
|
|
|
+ _, m := findMessageByID(ms, discord.MessageID(mID))
|
|
|
|
|
+ d := api.SendMessageData{
|
|
|
|
|
+ Content: t,
|
|
|
|
|
+ Reference: m.Reference,
|
|
|
|
|
+ AllowedMentions: &api.AllowedMentions{RepliedUser: option.False},
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- return nil
|
|
|
|
|
- case "Ctrl+V":
|
|
|
|
|
- text, _ := clipboard.ReadAll()
|
|
|
|
|
- text = mi.app.MessageInputField.GetText() + text
|
|
|
|
|
- mi.app.MessageInputField.SetText(text)
|
|
|
|
|
|
|
+ // If the title of the message InputField widget has "[@]" as a prefix, send the message as a reply and mention the replied user.
|
|
|
|
|
+ if strings.HasPrefix(mi.GetTitle(), "[@]") {
|
|
|
|
|
+ d.AllowedMentions.RepliedUser = option.True
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- return nil
|
|
|
|
|
- case "Esc":
|
|
|
|
|
- mi.app.MessageInputField.
|
|
|
|
|
- SetText("").
|
|
|
|
|
- SetTitle("")
|
|
|
|
|
- mi.app.SetFocus(mi.app.MainFlex)
|
|
|
|
|
|
|
+ go mi.app.State.SendMessageComplex(m.ChannelID, d)
|
|
|
|
|
|
|
|
mi.app.MessagesPanel.SelectedMessage = -1
|
|
mi.app.MessagesPanel.SelectedMessage = -1
|
|
|
mi.app.MessagesPanel.Highlight()
|
|
mi.app.MessagesPanel.Highlight()
|
|
|
|
|
|
|
|
- return nil
|
|
|
|
|
- case mi.app.Config.Keys.OpenExternalEditor:
|
|
|
|
|
- e := os.Getenv("EDITOR")
|
|
|
|
|
- if e == "" {
|
|
|
|
|
- return nil
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ mi.SetTitle("")
|
|
|
|
|
+ } else {
|
|
|
|
|
+ go mi.app.State.SendMessage(mi.app.ChannelsTree.SelectedChannel.ID, t)
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- f, err := os.CreateTemp(os.TempDir(), "discordo-*.md")
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return nil
|
|
|
|
|
- }
|
|
|
|
|
- defer os.Remove(f.Name())
|
|
|
|
|
|
|
+ mi.SetText("")
|
|
|
|
|
+ return nil
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func (mi *MessageInput) pasteFromClipboard() *tcell.EventKey {
|
|
|
|
|
+ text, _ := clipboard.ReadAll()
|
|
|
|
|
+ text = mi.GetText() + text
|
|
|
|
|
+ mi.SetText(text)
|
|
|
|
|
+ return nil
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func (mi *MessageInput) openExternalEditor() *tcell.EventKey {
|
|
|
|
|
+ e := os.Getenv("EDITOR")
|
|
|
|
|
+ if e == "" {
|
|
|
|
|
+ return nil
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- cmd := exec.Command(e, f.Name())
|
|
|
|
|
- cmd.Stdin = os.Stdin
|
|
|
|
|
- cmd.Stdout = os.Stdout
|
|
|
|
|
|
|
+ f, err := os.CreateTemp(os.TempDir(), "discordo-*.md")
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return nil
|
|
|
|
|
+ }
|
|
|
|
|
+ defer os.Remove(f.Name())
|
|
|
|
|
|
|
|
- mi.app.Suspend(func() {
|
|
|
|
|
- err = cmd.Run()
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return
|
|
|
|
|
- }
|
|
|
|
|
- })
|
|
|
|
|
|
|
+ cmd := exec.Command(e, f.Name())
|
|
|
|
|
+ cmd.Stdin = os.Stdin
|
|
|
|
|
+ cmd.Stdout = os.Stdout
|
|
|
|
|
|
|
|
- b, err := io.ReadAll(f)
|
|
|
|
|
|
|
+ mi.app.Suspend(func() {
|
|
|
|
|
+ err = cmd.Run()
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
- return nil
|
|
|
|
|
|
|
+ return
|
|
|
}
|
|
}
|
|
|
|
|
+ })
|
|
|
|
|
|
|
|
- mi.app.MessageInputField.SetText(string(b))
|
|
|
|
|
-
|
|
|
|
|
|
|
+ b, err := io.ReadAll(f)
|
|
|
|
|
+ if err != nil {
|
|
|
return nil
|
|
return nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- return e
|
|
|
|
|
|
|
+ mi.SetText(string(b))
|
|
|
|
|
+ return nil
|
|
|
}
|
|
}
|