Merge pull request #721 from symphorien/hotlist
Implement a binding to go to a room with unread messages
This commit is contained in:
commit
d6eeaa1c04
@ -120,6 +120,11 @@ Page {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Shortcut {
|
||||||
|
sequence: "Alt+A"
|
||||||
|
onActivated: Rooms.nextRoomWithActivity()
|
||||||
|
}
|
||||||
|
|
||||||
Shortcut {
|
Shortcut {
|
||||||
sequence: "Ctrl+Down"
|
sequence: "Ctrl+Down"
|
||||||
onActivated: Rooms.nextRoom()
|
onActivated: Rooms.nextRoom()
|
||||||
|
@ -917,6 +917,52 @@ FilteredRoomlistModel::toggleTag(QString roomid, QString tag, bool on)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
FilteredRoomlistModel::nextRoomWithActivity()
|
||||||
|
{
|
||||||
|
int roomWithMention = -1;
|
||||||
|
int roomWithNotification = -1;
|
||||||
|
int roomWithUnreadMessage = -1;
|
||||||
|
auto r = currentRoom();
|
||||||
|
int currentRoomIdx = r ? roomidToIndex(r->roomId()) : -1;
|
||||||
|
// first look for mentions
|
||||||
|
for (int i = 0; i < (int)roomlistmodel->roomids.size(); i++) {
|
||||||
|
if (i == currentRoomIdx)
|
||||||
|
continue;
|
||||||
|
if (this->data(index(i, 0), RoomlistModel::HasLoudNotification).toBool()) {
|
||||||
|
roomWithMention = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (roomWithNotification == -1 &&
|
||||||
|
this->data(index(i, 0), RoomlistModel::NotificationCount).toInt() > 0) {
|
||||||
|
roomWithNotification = i;
|
||||||
|
// don't break, we must continue looking for rooms with mentions
|
||||||
|
}
|
||||||
|
if (roomWithNotification == -1 && roomWithUnreadMessage == -1 &&
|
||||||
|
this->data(index(i, 0), RoomlistModel::HasUnreadMessages).toBool()) {
|
||||||
|
roomWithUnreadMessage = i;
|
||||||
|
// don't break, we must continue looking for rooms with mentions
|
||||||
|
}
|
||||||
|
}
|
||||||
|
QString targetRoomId = nullptr;
|
||||||
|
if (roomWithMention != -1) {
|
||||||
|
targetRoomId =
|
||||||
|
this->data(index(roomWithMention, 0), RoomlistModel::RoomId).toString();
|
||||||
|
nhlog::ui()->debug("choosing {} for mentions", targetRoomId.toStdString());
|
||||||
|
} else if (roomWithNotification != -1) {
|
||||||
|
targetRoomId =
|
||||||
|
this->data(index(roomWithNotification, 0), RoomlistModel::RoomId).toString();
|
||||||
|
nhlog::ui()->debug("choosing {} for notifications", targetRoomId.toStdString());
|
||||||
|
} else if (roomWithUnreadMessage != -1) {
|
||||||
|
targetRoomId =
|
||||||
|
this->data(index(roomWithUnreadMessage, 0), RoomlistModel::RoomId).toString();
|
||||||
|
nhlog::ui()->debug("choosing {} for unread messages", targetRoomId.toStdString());
|
||||||
|
}
|
||||||
|
if (targetRoomId != nullptr) {
|
||||||
|
setCurrentRoom(targetRoomId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
FilteredRoomlistModel::nextRoom()
|
FilteredRoomlistModel::nextRoom()
|
||||||
{
|
{
|
||||||
|
@ -172,6 +172,7 @@ public slots:
|
|||||||
void setCurrentRoom(QString roomid) { roomlistmodel->setCurrentRoom(std::move(roomid)); }
|
void setCurrentRoom(QString roomid) { roomlistmodel->setCurrentRoom(std::move(roomid)); }
|
||||||
void resetCurrentRoom() { roomlistmodel->resetCurrentRoom(); }
|
void resetCurrentRoom() { roomlistmodel->resetCurrentRoom(); }
|
||||||
|
|
||||||
|
void nextRoomWithActivity();
|
||||||
void nextRoom();
|
void nextRoom();
|
||||||
void previousRoom();
|
void previousRoom();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user