aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVille Ranki <ville.ranki@iki.fi>2018-10-18 17:02:38 +0300
committerVille Ranki <ville.ranki@iki.fi>2018-10-18 17:02:38 +0300
commit7417df0f3ca20d6fcc0ef6ecb122dacf2afd741f (patch)
tree3d7b441d3feb00a4590bf994bb43cfed9ca62583
parent68db26bcace31297471641fe95f8882e301f5699 (diff)
Alt-a to jump to next channel with unread messages.
-rw-r--r--ui/room-list.go22
-rw-r--r--ui/tag-room-list.go5
-rw-r--r--ui/view-main.go2
3 files changed, 27 insertions, 2 deletions
diff --git a/ui/room-list.go b/ui/room-list.go
index a7543a9..6b81e60 100644
--- a/ui/room-list.go
+++ b/ui/room-list.go
@@ -21,6 +21,7 @@ import (
"strings"
"math"
+
"maunium.net/go/gomuks/debug"
"maunium.net/go/gomuks/matrix/rooms"
"maunium.net/go/tcell"
@@ -313,6 +314,27 @@ func (list *RoomList) Next() (string, *rooms.Room) {
return list.Last()
}
+// NextWithActivity Returns next room with activity.
+//
+// Sorted by (in priority):
+//
+// - Highlights
+// - Messages
+// - Other traffic (joins, parts, etc)
+//
+// TODO: Sorting. Now just finds first room with new messages.
+func (list *RoomList) NextWithActivity() (string, *rooms.Room) {
+ for tag, trl := range list.items {
+ for _, room := range trl.All() {
+ if room.HasNewMessages() {
+ return tag, room.Room
+ }
+ }
+ }
+ // No room with activity found
+ return "", nil
+}
+
func (list *RoomList) index(tag string, room *rooms.Room) int {
tagIndex := list.IndexTag(tag)
if tagIndex == -1 {
diff --git a/ui/tag-room-list.go b/ui/tag-room-list.go
index 2705c49..60b4350 100644
--- a/ui/tag-room-list.go
+++ b/ui/tag-room-list.go
@@ -18,12 +18,13 @@ package ui
import (
"fmt"
+ "strconv"
+ "strings"
+
"maunium.net/go/gomuks/matrix/rooms"
"maunium.net/go/gomuks/ui/widget"
"maunium.net/go/tcell"
"maunium.net/go/tview"
- "strconv"
- "strings"
)
type OrderedRoom struct {
diff --git a/ui/view-main.go b/ui/view-main.go
index f38043a..8bd0668 100644
--- a/ui/view-main.go
+++ b/ui/view-main.go
@@ -196,6 +196,8 @@ func (view *MainView) KeyEventHandler(roomView *RoomView, key *tcell.EventKey) *
searchModal := NewFuzzySearchModal(view, 42, 12)
view.parent.views.AddPage("fuzzy-search-modal", searchModal, true, true)
view.parent.app.SetFocus(searchModal)
+ case c == 'a':
+ view.SwitchRoom(view.roomList.NextWithActivity())
case c == 'l':
view.ShowBare(roomView)
default: