Skip to content

Commit

Permalink
sort room list by last received message
Browse files Browse the repository at this point in the history
  • Loading branch information
Sorunome committed Oct 22, 2019
1 parent ab00f52 commit 6e2a4b7
Showing 1 changed file with 80 additions and 33 deletions.
113 changes: 80 additions & 33 deletions source/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
#include <map>
#include <vector>
#include <queue>
#include <bits/stdc++.h>
#include "store.h"

PrintConsole* topScreenConsole;
Expand All @@ -20,9 +21,18 @@ struct Message {
std::string body;
};

std::map<std::string, Matrix::RoomInfo> joinedRooms;
struct ExtendedRoomInfo {
std::string name;
std::string topic;
std::string avatarUrl;
std::string roomId;
u32 lastMsg;
};

std::vector<ExtendedRoomInfo> joinedRooms;
std::map<std::string, std::vector<Message>> messages;
std::map<std::string, std::string> roomNames;
bool sortRooms = false;
bool renderRooms = true;
bool renderRoomDisplay = true;
std::string currentRoom;
Expand All @@ -37,6 +47,13 @@ State state = State::roomPicking;
Matrix::Client* client;
Store store;

std::string getRoomName(ExtendedRoomInfo room) {
if (room.name != "") {
return room.name;
}
return room.roomId;
}

void printMsg(Message msg) {
std::string displayname = msg.sender;
if (roomNames.count(msg.sender) == 0) {
Expand All @@ -49,14 +66,29 @@ void printMsg(Message msg) {
printf_top("<%s> %s\n", displayname.c_str(), msg.body.c_str());
}

int joinedRoomIndex(std::string roomId) {
for (u32 i = 0; i != joinedRooms.size(); i++) {
if (joinedRooms[i].roomId == roomId) {
return i;
}
}
return -1;
}

bool joinedRoomsSortFunc(ExtendedRoomInfo r1, ExtendedRoomInfo r2) {
return r1.lastMsg > r2.lastMsg;
}

void sync_new_event(std::string roomId, json_t* event) {
if (joinedRooms.count(roomId) == 0) {
if (joinedRoomIndex(roomId) == -1) {
// room isn't found, let's fetch it
joinedRooms[roomId] = {
name: roomId,
joinedRooms.push_back({
name: "",
topic: "",
avatarUrl: "",
};
roomId: roomId,
lastMsg: 0,
});
renderRooms = true;
}
json_t* eventType = json_object_get(event, "type");
Expand All @@ -68,6 +100,15 @@ void sync_new_event(std::string roomId, json_t* event) {
if (eventTypeStr != "m.room.message") {
return;
}
json_t* originServerTs = json_object_get(event, "origin_server_ts");
if (!originServerTs) {
return;
}
int ix = joinedRoomIndex(roomId);
if (ix != -1) {
joinedRooms[ix].lastMsg = json_integer_value(originServerTs);
sortRooms = true;
}
json_t* content = json_object_get(event, "content");
if (!content) {
return;
Expand Down Expand Up @@ -104,12 +145,27 @@ void sync_new_event(std::string roomId, json_t* event) {
}

void sync_leave_room(std::string roomId, json_t* event) {
joinedRooms.erase(roomId);
int ix = joinedRoomIndex(roomId);
if (ix != -1) {
joinedRooms.erase(joinedRooms.begin() + ix);
}
renderRooms = true;
}

void sync_room_info(std::string roomId, Matrix::RoomInfo roomInfo) {
joinedRooms[roomId] = roomInfo;
ExtendedRoomInfo extendedRoomInfo = {
name: roomInfo.name,
topic: roomInfo.topic,
avatarUrl: roomInfo.avatarUrl,
roomId: roomId,
lastMsg: 0,
};
int ix = joinedRoomIndex(roomId);
if (ix == -1) {
joinedRooms.push_back(extendedRoomInfo);
} else {
joinedRooms[ix] = extendedRoomInfo;
}
renderRooms = true;
}

Expand Down Expand Up @@ -204,16 +260,13 @@ void roomPicker() {
renderRooms = true;
}
if (kDown & KEY_A) {
int i = 0;
for (auto const& room : joinedRooms) {
auto roomId = room.first;
auto info = room.second;
if (i == roomPickerItem) {
loadRoom(roomId);
return;
}
i++;
}
loadRoom(joinedRooms[roomPickerItem].roomId);
return;
}
if (sortRooms) {
sort(joinedRooms.begin(), joinedRooms.end(), joinedRoomsSortFunc);
renderRooms = true;
sortRooms = false;
}
if (!renderRooms) {
return;
Expand All @@ -222,22 +275,15 @@ void roomPicker() {
printf_bottom("\x1b[2J");
renderRooms = false;
printf_bottom("\x1b[%d;1H>", roomPickerItem - roomPickerTop + 1);
int i = 0;
for (auto const& room : joinedRooms) {
if (i < roomPickerTop) {
i++;
continue;
}
if (i > roomPickerTop + 29) {
for (u8 i = 0; i < 30; i++) {
if (i + roomPickerTop >= joinedRooms.size()) {
break;
}
auto roomId = room.first;
auto info = room.second;
ExtendedRoomInfo room = joinedRooms[i + roomPickerTop];
char name[40];
strncpy(name, info.name.c_str(), 40);
strncpy(name, getRoomName(room).c_str(), 39);
name[39] = '\0';
printf_bottom("\x1b[%d;2H%s", i - roomPickerTop + 1, name);
i++;
printf_bottom("\x1b[%d;2H%s", i + 1, name);
}
}

Expand Down Expand Up @@ -265,12 +311,13 @@ void displayRoom() {
}
printf_bottom("\x1b[2J");
renderRoomDisplay = false;
if (joinedRooms.count(currentRoom) == 0) {
int ix = joinedRoomIndex(currentRoom);
if (ix == -1) {
printf_bottom("Something went really wrong...");
return;
}
auto room = joinedRooms[currentRoom];
printf_bottom("Room name: %s\n", room.name.c_str());
ExtendedRoomInfo room = joinedRooms[ix];
printf_bottom("Room name: %s\n", getRoomName(room).c_str());
printf_bottom("Room topic: %s\n", room.topic.c_str());
printf_bottom("\nPress A to send a message\nPress B to go back\n");
}
Expand All @@ -286,7 +333,7 @@ bool setupAcc() {
printf_top("Logged in as %s\n", userId.c_str());
return true;
}
free(client);
delete client;
client = NULL;
printf_top("Invalid token\n");
}
Expand Down

0 comments on commit 6e2a4b7

Please sign in to comment.