Merge pull request #479 from Jedi18/add_rooms_model_completer
Add rooms completion model
This commit is contained in:
commit
99efe2f06b
@ -326,6 +326,7 @@ set(SRC_FILES
|
|||||||
src/UserInfoWidget.cpp
|
src/UserInfoWidget.cpp
|
||||||
src/UserSettingsPage.cpp
|
src/UserSettingsPage.cpp
|
||||||
src/UsersModel.cpp
|
src/UsersModel.cpp
|
||||||
|
src/RoomsModel.cpp
|
||||||
src/Utils.cpp
|
src/Utils.cpp
|
||||||
src/WebRTCSession.cpp
|
src/WebRTCSession.cpp
|
||||||
src/WelcomePage.cpp
|
src/WelcomePage.cpp
|
||||||
@ -537,6 +538,7 @@ qt5_wrap_cpp(MOC_HEADERS
|
|||||||
src/UserInfoWidget.h
|
src/UserInfoWidget.h
|
||||||
src/UserSettingsPage.h
|
src/UserSettingsPage.h
|
||||||
src/UsersModel.h
|
src/UsersModel.h
|
||||||
|
src/RoomsModel.h
|
||||||
src/WebRTCSession.h
|
src/WebRTCSession.h
|
||||||
src/WelcomePage.h
|
src/WelcomePage.h
|
||||||
src/popups/PopupItem.h
|
src/popups/PopupItem.h
|
||||||
|
@ -154,6 +154,35 @@ Popup {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DelegateChoice {
|
||||||
|
roleValue: "room"
|
||||||
|
|
||||||
|
RowLayout {
|
||||||
|
id: del
|
||||||
|
|
||||||
|
anchors.centerIn: parent
|
||||||
|
|
||||||
|
Avatar {
|
||||||
|
height: 24
|
||||||
|
width: 24
|
||||||
|
url: model.avatarUrl.replace("mxc://", "image://MxcImage/")
|
||||||
|
onClicked: popup.completionClicked(completer.completionAt(model.index))
|
||||||
|
}
|
||||||
|
|
||||||
|
Label {
|
||||||
|
text: model.roomName
|
||||||
|
color: model.index == popup.currentIndex ? colors.highlightedText : colors.text
|
||||||
|
}
|
||||||
|
|
||||||
|
Label {
|
||||||
|
text: "(" + model.roomAlias + ")"
|
||||||
|
color: model.index == popup.currentIndex ? colors.highlightedText : colors.buttonText
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -183,6 +183,9 @@ Rectangle {
|
|||||||
} else if (event.key == Qt.Key_Colon) {
|
} else if (event.key == Qt.Key_Colon) {
|
||||||
messageInput.openCompleter(cursorPosition, "emoji");
|
messageInput.openCompleter(cursorPosition, "emoji");
|
||||||
popup.open();
|
popup.open();
|
||||||
|
} else if (event.key == Qt.Key_NumberSign) {
|
||||||
|
messageInput.openCompleter(cursorPosition, "room");
|
||||||
|
popup.open();
|
||||||
} else if (event.key == Qt.Key_Escape && popup.opened) {
|
} else if (event.key == Qt.Key_Escape && popup.opened) {
|
||||||
completerTriggeredAt = -1;
|
completerTriggeredAt = -1;
|
||||||
popup.completerName = "";
|
popup.completerName = "";
|
||||||
|
69
src/RoomsModel.cpp
Normal file
69
src/RoomsModel.cpp
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
#include "RoomsModel.h"
|
||||||
|
|
||||||
|
#include <QUrl>
|
||||||
|
|
||||||
|
#include "Cache_p.h"
|
||||||
|
#include "CompletionModelRoles.h"
|
||||||
|
|
||||||
|
RoomsModel::RoomsModel(bool showOnlyRoomWithAliases, QObject *parent)
|
||||||
|
: QAbstractListModel(parent)
|
||||||
|
, showOnlyRoomWithAliases_(showOnlyRoomWithAliases)
|
||||||
|
{
|
||||||
|
std::vector<std::string> rooms_ = cache::joinedRooms();
|
||||||
|
roomInfos = cache::getRoomInfo(rooms_);
|
||||||
|
|
||||||
|
for (const auto &r : rooms_) {
|
||||||
|
auto roomAliasesList = cache::client()->getRoomAliases(r);
|
||||||
|
|
||||||
|
if (showOnlyRoomWithAliases_) {
|
||||||
|
if (roomAliasesList && !roomAliasesList->alias.empty()) {
|
||||||
|
roomids.push_back(QString::fromStdString(r));
|
||||||
|
roomAliases.push_back(
|
||||||
|
QString::fromStdString(roomAliasesList->alias));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
roomids.push_back(QString::fromStdString(r));
|
||||||
|
roomAliases.push_back(
|
||||||
|
roomAliasesList ? QString::fromStdString(roomAliasesList->alias) : "");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
QHash<int, QByteArray>
|
||||||
|
RoomsModel::roleNames() const
|
||||||
|
{
|
||||||
|
return {{CompletionModel::CompletionRole, "completionRole"},
|
||||||
|
{CompletionModel::SearchRole, "searchRole"},
|
||||||
|
{CompletionModel::SearchRole2, "searchRole2"},
|
||||||
|
{Roles::RoomAlias, "roomAlias"},
|
||||||
|
{Roles::AvatarUrl, "avatarUrl"},
|
||||||
|
{Roles::RoomID, "roomid"},
|
||||||
|
{Roles::RoomName, "roomName"}};
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant
|
||||||
|
RoomsModel::data(const QModelIndex &index, int role) const
|
||||||
|
{
|
||||||
|
if (hasIndex(index.row(), index.column(), index.parent())) {
|
||||||
|
switch (role) {
|
||||||
|
case CompletionModel::CompletionRole: {
|
||||||
|
QString percentEncoding = QUrl::toPercentEncoding(roomAliases[index.row()]);
|
||||||
|
return QString("[%1](https://matrix.to/#/%2)")
|
||||||
|
.arg(roomAliases[index.row()], percentEncoding);
|
||||||
|
}
|
||||||
|
case CompletionModel::SearchRole:
|
||||||
|
case Qt::DisplayRole:
|
||||||
|
case Roles::RoomAlias:
|
||||||
|
return roomAliases[index.row()];
|
||||||
|
case CompletionModel::SearchRole2:
|
||||||
|
case Roles::RoomName:
|
||||||
|
return QString::fromStdString(roomInfos.at(roomids[index.row()]).name);
|
||||||
|
case Roles::AvatarUrl:
|
||||||
|
return QString::fromStdString(
|
||||||
|
roomInfos.at(roomids[index.row()]).avatar_url);
|
||||||
|
case Roles::RoomID:
|
||||||
|
return roomids[index.row()];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return {};
|
||||||
|
}
|
33
src/RoomsModel.h
Normal file
33
src/RoomsModel.h
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "Cache.h"
|
||||||
|
|
||||||
|
#include <QAbstractListModel>
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
class RoomsModel : public QAbstractListModel
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
enum Roles
|
||||||
|
{
|
||||||
|
AvatarUrl = Qt::UserRole,
|
||||||
|
RoomAlias,
|
||||||
|
RoomID,
|
||||||
|
RoomName,
|
||||||
|
};
|
||||||
|
|
||||||
|
RoomsModel(bool showOnlyRoomWithAliases = false, QObject *parent = nullptr);
|
||||||
|
QHash<int, QByteArray> roleNames() const override;
|
||||||
|
int rowCount(const QModelIndex &parent = QModelIndex()) const override
|
||||||
|
{
|
||||||
|
(void)parent;
|
||||||
|
return (int)roomids.size();
|
||||||
|
}
|
||||||
|
QVariant data(const QModelIndex &index, int role) const override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::vector<QString> roomids;
|
||||||
|
std::vector<QString> roomAliases;
|
||||||
|
std::map<QString, RoomInfo> roomInfos;
|
||||||
|
bool showOnlyRoomWithAliases_;
|
||||||
|
};
|
@ -19,6 +19,7 @@
|
|||||||
#include "MainWindow.h"
|
#include "MainWindow.h"
|
||||||
#include "MatrixClient.h"
|
#include "MatrixClient.h"
|
||||||
#include "Olm.h"
|
#include "Olm.h"
|
||||||
|
#include "RoomsModel.h"
|
||||||
#include "TimelineModel.h"
|
#include "TimelineModel.h"
|
||||||
#include "TimelineViewManager.h"
|
#include "TimelineViewManager.h"
|
||||||
#include "UserSettingsPage.h"
|
#include "UserSettingsPage.h"
|
||||||
@ -186,6 +187,11 @@ InputBar::completerFor(QString completerName)
|
|||||||
auto proxy = new CompletionProxyModel(emojiModel);
|
auto proxy = new CompletionProxyModel(emojiModel);
|
||||||
emojiModel->setParent(proxy);
|
emojiModel->setParent(proxy);
|
||||||
return proxy;
|
return proxy;
|
||||||
|
} else if (completerName == "room") {
|
||||||
|
auto roomModel = new RoomsModel(true);
|
||||||
|
auto proxy = new CompletionProxyModel(roomModel);
|
||||||
|
roomModel->setParent(proxy);
|
||||||
|
return proxy;
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user