aboutsummaryrefslogtreecommitdiff
path: root/ui/commands.go
diff options
context:
space:
mode:
authorTulir Asokan <tulir@maunium.net>2018-05-27 14:54:07 +0300
committerTulir Asokan <tulir@maunium.net>2018-05-27 14:54:07 +0300
commit094a566189a29568a1b7a49510602aecfbcb7bdd (patch)
treeaeb3c8ec18c8376a3c6c54da83b5d177fa728b70 /ui/commands.go
parentb63c451706ab2cec003689e2e8047af737fb1b1c (diff)
Split command system from main view
Diffstat (limited to 'ui/commands.go')
-rw-r--r--ui/commands.go99
1 files changed, 99 insertions, 0 deletions
diff --git a/ui/commands.go b/ui/commands.go
new file mode 100644
index 0000000..38694a5
--- /dev/null
+++ b/ui/commands.go
@@ -0,0 +1,99 @@
+// gomuks - A terminal Matrix client written in Go.
+// Copyright (C) 2018 Tulir Asokan
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+package ui
+
+import (
+ "maunium.net/go/gomuks/debug"
+ "strings"
+)
+
+func cmdMe(cmd *Command) {
+ text := strings.Join(cmd.Args, " ")
+ tempMessage := cmd.Room.NewTempMessage("m.emote", text)
+ go cmd.MainView.sendTempMessage(cmd.Room, tempMessage, text)
+ cmd.UI.Render()
+}
+
+func cmdQuit(cmd *Command) {
+ cmd.Gomuks.Stop()
+}
+
+func cmdClearCache(cmd *Command) {
+ cmd.Config.Clear()
+ cmd.Gomuks.Stop()
+}
+
+func cmdUnknownCommand(cmd *Command) {
+ cmd.Reply("Unknown command \"%s\". Try \"/help\" for help.", cmd.Command)
+}
+
+func cmdHelp(cmd *Command) {
+ cmd.Reply("Known command. Don't try \"/help\" for help.")
+}
+
+func cmdLeave(cmd *Command) {
+ err := cmd.Matrix.LeaveRoom(cmd.Room.MxRoom().ID)
+ debug.Print("Leave room error:", err)
+ if err == nil {
+ cmd.MainView.RemoveRoom(cmd.Room.MxRoom())
+ }
+}
+
+func cmdJoin(cmd *Command) {
+ if len(cmd.Args) == 0 {
+ cmd.Reply("Usage: /join <room>")
+ return
+ }
+ identifer := cmd.Args[0]
+ server := ""
+ if len(cmd.Args) > 1 {
+ server = cmd.Args[1]
+ }
+ room, err := cmd.Matrix.JoinRoom(identifer, server)
+ debug.Print("Join room error:", err)
+ if err == nil {
+ cmd.MainView.AddRoom(room)
+ }
+}
+
+func cmdUIToggle(cmd *Command) {
+ if len(cmd.Args) == 0 {
+ cmd.Reply("Usage: /uitoggle <rooms/users/baremessages>")
+ return
+ }
+ switch cmd.Args[0] {
+ case "rooms":
+ cmd.MainView.hideRoomList = !cmd.MainView.hideRoomList
+ cmd.Config.Preferences.HideRoomList = cmd.MainView.hideRoomList
+ case "users":
+ cmd.MainView.hideUserList = !cmd.MainView.hideUserList
+ cmd.Config.Preferences.HideUserList = cmd.MainView.hideUserList
+ case "baremessages":
+ cmd.MainView.bareMessages = !cmd.MainView.bareMessages
+ cmd.Config.Preferences.BareMessageView = cmd.MainView.bareMessages
+ default:
+ cmd.Reply("Usage: /uitoggle <rooms/users/baremessages>")
+ return
+ }
+ cmd.UI.Render()
+ cmd.UI.Render()
+ go cmd.Matrix.SendPreferencesToMatrix()
+}
+
+func cmdLogout(cmd *Command) {
+ cmd.Matrix.Logout()
+}