aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTulir Asokan <tulir@maunium.net>2018-03-15 20:53:04 +0200
committerTulir Asokan <tulir@maunium.net>2018-03-15 20:53:04 +0200
commit2bf057d27cc76fc22f3fee51f17269d23bb4b4e4 (patch)
tree1764691e3854c8839285a341e9dc3003da5f400d
parentbffd4d3d17d9396efefa75c5618319503a2f9dcd (diff)
MY HANDS ARE TYPING WORDS
-rw-r--r--matrix.go6
-rw-r--r--ui.go15
-rw-r--r--view-main.go209
3 files changed, 132 insertions, 98 deletions
diff --git a/matrix.go b/matrix.go
index 7ef4b06..6a75966 100644
--- a/matrix.go
+++ b/matrix.go
@@ -113,7 +113,7 @@ func (c *MatrixContainer) UpdateRoomList() {
c.debug.Print(err)
}
- c.ui.SetRoomList(rooms.JoinedRooms)
+ c.ui.MainView().SetRoomList(rooms.JoinedRooms)
}
func (c *MatrixContainer) Start() {
@@ -147,7 +147,7 @@ func (c *MatrixContainer) Start() {
func (c *MatrixContainer) HandleMessage(evt *gomatrix.Event) {
message, _ := evt.Content["body"].(string)
- c.ui.Append(evt.RoomID, evt.Sender, message)
+ c.ui.MainView().Append(evt.RoomID, evt.Sender, message)
}
func (c *MatrixContainer) HandleTyping(evt *gomatrix.Event) {
@@ -158,7 +158,7 @@ func (c *MatrixContainer) HandleTyping(evt *gomatrix.Event) {
for i, user := range users {
strUsers[i] = user.(string)
}
- c.ui.SetTyping(evt.RoomID, strUsers...)
+ c.ui.MainView().SetTyping(evt.RoomID, strUsers)
}
func (c *MatrixContainer) SendMessage(roomID, message string) {
diff --git a/ui.go b/ui.go
index 272d0ba..7ead0c4 100644
--- a/ui.go
+++ b/ui.go
@@ -35,13 +35,7 @@ type GomuksUI struct {
config *Config
views *tview.Pages
- mainView *tview.Grid
- mainViewRoomList *tview.List
- mainViewRoomView *tview.Pages
- mainViewInput *tview.InputField
- mainViewRooms map[string]*RoomView
- currentRoomIndex int
- roomList []string
+ mainView *MainView
}
func init() {
@@ -71,7 +65,12 @@ func (ui *GomuksUI) SetView(name string) {
}
func (ui *GomuksUI) InitViews() tview.Primitive {
+ ui.mainView = ui.NewMainView()
ui.views.AddPage(ViewLogin, ui.MakeLoginUI(), true, true)
- ui.views.AddPage(ViewMain, ui.MakeMainUI(), true, false)
+ ui.views.AddPage(ViewMain, ui.mainView, true, false)
return ui.views
}
+
+func (ui *GomuksUI) MainView() *MainView {
+ return ui.mainView
+}
diff --git a/view-main.go b/view-main.go
index 148212b..b7a0b27 100644
--- a/view-main.go
+++ b/view-main.go
@@ -24,100 +24,150 @@ import (
"maunium.net/go/tview"
)
-func (ui *GomuksUI) MakeMainUI() tview.Primitive {
- ui.mainView = tview.NewGrid()
- ui.mainView.SetColumns(30, 1, 0).SetRows(0, 1)
-
- ui.mainViewRoomList = tview.NewList().ShowSecondaryText(false)
- ui.mainViewRoomList.SetBorderPadding(0, 0, 1, 0)
- ui.mainView.AddItem(ui.mainViewRoomList, 0, 0, 2, 1, 0, 0, false)
-
- ui.mainView.AddItem(NewBorder(), 0, 1, 2, 1, 0, 0, false)
-
- ui.mainViewRoomView = tview.NewPages()
- ui.mainViewRoomView.SetChangedFunc(ui.Render)
- ui.mainView.AddItem(ui.mainViewRoomView, 0, 2, 1, 1, 0, 0, false)
-
- ui.mainViewInput = tview.NewInputField()
- ui.mainViewInput.SetChangedFunc(func(text string) {
- ui.matrix.SendTyping(ui.currentRoom(), len(text) > 0)
- })
- ui.mainViewInput.SetDoneFunc(func(key tcell.Key) {
- if key == tcell.KeyEnter {
- room, text := ui.currentRoom(), ui.mainViewInput.GetText()
- if len(text) == 0 {
- return
- } else if text[0] == '/' {
- args := strings.SplitN(text, " ", 2)
- command := strings.ToLower(args[0])
- args = args[1:]
- ui.HandleCommand(room, command, args)
- } else {
- ui.matrix.SendMessage(room, text)
- }
- ui.mainViewInput.SetText("")
- }
- })
- ui.mainView.AddItem(ui.mainViewInput, 1, 2, 1, 1, 0, 0, true)
+type MainView struct {
+ *tview.Grid
+
+ roomList *tview.List
+ roomView *tview.Pages
+ rooms map[string]*RoomView
+ input *tview.InputField
+ currentRoomIndex int
+ roomIDs []string
+
+ matrix *MatrixContainer
+ debug DebugPrinter
+ gmx Gomuks
+ config *Config
+ parent *GomuksUI
+}
+
+func (view *MainView) addItem(p tview.Primitive, x, y, w, h int) {
+ view.Grid.AddItem(p, x, y, w, h, 0, 0, false)
+}
+
+func (ui *GomuksUI) NewMainView() *MainView {
+ mainUI := &MainView{
+ Grid: tview.NewGrid(),
+ roomList: tview.NewList(),
+ roomView: tview.NewPages(),
+ rooms: make(map[string]*RoomView),
+ input: tview.NewInputField(),
+
+ matrix: ui.matrix,
+ debug: ui.debug,
+ gmx: ui.gmx,
+ config: ui.config,
+ parent: ui,
+ }
+
+ mainUI.SetColumns(30, 1, 0).SetRows(0, 1)
+
+ mainUI.roomList.
+ ShowSecondaryText(false).
+ SetBorderPadding(0, 0, 1, 0)
- ui.debug.Print(ui.mainViewInput.SetInputCapture(ui.MainUIKeyHandler))
+ mainUI.input.
+ SetDoneFunc(mainUI.InputDone).
+ SetChangedFunc(mainUI.InputChanged).
+ SetInputCapture(mainUI.InputCapture)
- ui.mainViewRooms = make(map[string]*RoomView)
+ mainUI.addItem(mainUI.roomList, 0, 0, 2, 1)
+ mainUI.addItem(NewBorder(), 0, 1, 2, 1)
+ mainUI.addItem(mainUI.roomView, 0, 2, 1, 1)
+ mainUI.AddItem(mainUI.input, 1, 2, 1, 1, 0, 0, true)
- return ui.mainView
+ return mainUI
}
-func (ui *GomuksUI) HandleCommand(room, command string, args []string) {
- ui.debug.Print("Handling command", command, args)
+func (view *MainView) InputChanged(text string) {
+ view.matrix.SendTyping(view.CurrentRoomID(), len(text) > 0)
+}
+
+func (view *MainView) InputDone(key tcell.Key) {
+ if key == tcell.KeyEnter {
+ room, text := view.CurrentRoomID(), view.input.GetText()
+ if len(text) == 0 {
+ return
+ } else if text[0] == '/' {
+ args := strings.SplitN(text, " ", 2)
+ command := strings.ToLower(args[0])
+ args = args[1:]
+ view.HandleCommand(room, command, args)
+ } else {
+ view.matrix.SendMessage(room, text)
+ }
+ view.input.SetText("")
+ }
+}
+
+func (view *MainView) HandleCommand(room, command string, args []string) {
+ view.debug.Print("Handling command", command, args)
switch command {
case "/quit":
- ui.gmx.Stop()
+ view.gmx.Stop()
case "/clearcache":
- ui.config.Session.Rooms = make(map[string]*gomatrix.Room)
- ui.config.Session.NextBatch = ""
- ui.config.Session.FilterID = ""
- ui.config.Session.Save()
- ui.gmx.Stop()
+ view.config.Session.Rooms = make(map[string]*gomatrix.Room)
+ view.config.Session.NextBatch = ""
+ view.config.Session.FilterID = ""
+ view.config.Session.Save()
+ view.gmx.Stop()
case "/part":
case "/leave":
- ui.matrix.client.LeaveRoom(room)
+ view.matrix.client.LeaveRoom(room)
case "/join":
if len(args) == 0 {
- ui.Append(room, "*", "Usage: /join <room>")
+ view.Append(room, "*", "Usage: /join <room>")
+ break
}
mxid := args[0]
server := mxid[strings.Index(mxid, ":")+1:]
- ui.matrix.client.JoinRoom(mxid, server, nil)
+ view.matrix.client.JoinRoom(mxid, server, nil)
}
}
-func (ui *GomuksUI) MainUIKeyHandler(key *tcell.EventKey) *tcell.EventKey {
+func (view *MainView) InputCapture(key *tcell.EventKey) *tcell.EventKey {
if key.Modifiers() == tcell.ModCtrl {
if key.Key() == tcell.KeyDown {
- ui.SwitchRoom(ui.currentRoomIndex + 1)
- ui.mainViewRoomList.SetCurrentItem(ui.currentRoomIndex)
+ view.SwitchRoom(view.currentRoomIndex + 1)
+ view.roomList.SetCurrentItem(view.currentRoomIndex)
} else if key.Key() == tcell.KeyUp {
- ui.SwitchRoom(ui.currentRoomIndex - 1)
- ui.mainViewRoomList.SetCurrentItem(ui.currentRoomIndex)
+ view.SwitchRoom(view.currentRoomIndex - 1)
+ view.roomList.SetCurrentItem(view.currentRoomIndex)
} else {
return key
}
} else if key.Key() == tcell.KeyPgUp || key.Key() == tcell.KeyPgDn {
- ui.mainViewRooms[ui.currentRoom()].InputHandler()(key, nil)
+ view.rooms[view.CurrentRoomID()].InputHandler()(key, nil)
} else {
return key
}
return nil
}
-func (ui *GomuksUI) SetRoomList(rooms []string) {
- ui.roomList = rooms
- ui.mainViewRoomList.Clear()
+func (view *MainView) CurrentRoomID() string {
+ if len(view.roomIDs) == 0 {
+ return ""
+ }
+ return view.roomIDs[view.currentRoomIndex]
+}
+
+func (view *MainView) SwitchRoom(roomIndex int) {
+ if roomIndex < 0 {
+ roomIndex = len(view.roomIDs) - 1
+ }
+ view.currentRoomIndex = roomIndex % len(view.roomIDs)
+ view.roomView.SwitchToPage(view.CurrentRoomID())
+ view.parent.Render()
+}
+
+func (view *MainView) SetRoomList(rooms []string) {
+ view.roomIDs = rooms
+ view.roomList.Clear()
for index, room := range rooms {
localRoomIndex := index
- ui.matrix.UpdateState(room)
- roomStore := ui.matrix.config.Session.LoadRoom(room)
+ view.matrix.UpdateState(room)
+ roomStore := view.matrix.config.Session.LoadRoom(room)
name := room
topic := ""
@@ -128,46 +178,31 @@ func (ui *GomuksUI) SetRoomList(rooms []string) {
users = roomStore.GetMembers()
}
- ui.mainViewRoomList.AddItem(name, "", 0, func() {
- ui.SwitchRoom(localRoomIndex)
+ view.roomList.AddItem(name, "", 0, func() {
+ view.SwitchRoom(localRoomIndex)
})
- if !ui.mainViewRoomView.HasPage(room) {
+ if !view.roomView.HasPage(room) {
roomView := NewRoomView(topic)
roomView.SetUsers(users)
- ui.mainViewRooms[room] = roomView
- ui.mainViewRoomView.AddPage(room, roomView, true, false)
+ view.rooms[room] = roomView
+ view.roomView.AddPage(room, roomView, true, false)
}
}
- ui.SwitchRoom(0)
-}
-
-func (ui *GomuksUI) currentRoom() string {
- if len(ui.roomList) == 0 {
- return ""
- }
- return ui.roomList[ui.currentRoomIndex]
-}
-
-func (ui *GomuksUI) SwitchRoom(roomIndex int) {
- if roomIndex < 0 {
- roomIndex = len(ui.roomList) - 1
- }
- ui.currentRoomIndex = roomIndex % len(ui.roomList)
- ui.mainViewRoomView.SwitchToPage(ui.currentRoom())
+ view.SwitchRoom(0)
}
-func (ui *GomuksUI) SetTyping(room string, users ...string) {
- roomView, ok := ui.mainViewRooms[room]
+func (view *MainView) SetTyping(room string, users []string) {
+ roomView, ok := view.rooms[room]
if ok {
roomView.SetTyping(users)
- ui.Render()
+ view.parent.Render()
}
}
-func (ui *GomuksUI) Append(room, sender, message string) {
- roomView, ok := ui.mainViewRooms[room]
+func (view *MainView) Append(room, sender, message string) {
+ roomView, ok := view.rooms[room]
if ok {
roomView.AddMessage(sender, message)
- ui.Render()
+ view.parent.Render()
}
}