nheko/src/timeline2/TimelineViewManager.cpp

103 lines
3.4 KiB
C++
Raw Normal View History

2019-08-30 19:29:25 +02:00
#include "TimelineViewManager.h"
2019-08-30 23:20:53 +02:00
#include <QMetaType>
#include <QQmlContext>
#include "Logging.h"
2019-09-07 22:22:07 +02:00
#include "MxcImageProvider.h"
2019-08-30 23:20:53 +02:00
2019-08-30 19:29:25 +02:00
TimelineViewManager::TimelineViewManager(QWidget *parent)
{
qmlRegisterUncreatableMetaObject(qml_mtx_events::staticMetaObject,
"com.github.nheko",
1,
0,
"MtxEvent",
"Can't instantiate enum!");
2019-08-30 19:29:25 +02:00
view = new QQuickView();
container = QWidget::createWindowContainer(view, parent);
container->setMinimumSize(200, 200);
2019-08-31 22:43:31 +02:00
view->rootContext()->setContextProperty("timelineManager", this);
2019-09-07 22:22:07 +02:00
view->engine()->addImageProvider("MxcImage", new MxcImageProvider());
2019-08-30 19:29:25 +02:00
view->setSource(QUrl("qrc:///qml/TimelineView.qml"));
2019-08-30 23:20:53 +02:00
}
void
TimelineViewManager::initialize(const mtx::responses::Rooms &rooms)
{
for (auto it = rooms.join.cbegin(); it != rooms.join.cend(); ++it) {
addRoom(QString::fromStdString(it->first));
2019-08-31 22:43:31 +02:00
models.value(QString::fromStdString(it->first))->addEvents(it->second.timeline);
2019-08-30 23:20:53 +02:00
}
}
void
TimelineViewManager::addRoom(const QString &room_id)
{
if (!models.contains(room_id))
models.insert(room_id, QSharedPointer<TimelineModel>(new TimelineModel(room_id)));
2019-08-30 23:20:53 +02:00
}
void
TimelineViewManager::setHistoryView(const QString &room_id)
{
nhlog::ui()->info("Trying to activate room {}", room_id.toStdString());
auto room = models.find(room_id);
if (room != models.end()) {
2019-09-03 08:23:07 +02:00
timeline_ = room.value().data();
timeline_->fetchHistory();
2019-08-31 22:43:31 +02:00
emit activeTimelineChanged(timeline_);
2019-08-30 23:20:53 +02:00
nhlog::ui()->info("Activated room {}", room_id.toStdString());
}
}
void
TimelineViewManager::initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs)
{
for (const auto &e : msgs) {
addRoom(e.first);
2019-08-31 22:43:31 +02:00
models.value(e.first)->addEvents(e.second);
2019-08-30 23:20:53 +02:00
}
2019-08-30 19:29:25 +02:00
}
void
TimelineViewManager::queueTextMessage(const QString &msg)
{
mtx::events::msg::Text text = {};
text.body = msg.trimmed().toStdString();
text.format = "org.matrix.custom.html";
text.formatted_body = utils::markdownToHtml(msg).toStdString();
if (timeline_)
timeline_->sendMessage(text);
}
void
TimelineViewManager::queueReplyMessage(const QString &reply, const RelatedInfo &related)
{
mtx::events::msg::Text text = {};
QString body;
bool firstLine = true;
for (const auto &line : related.quoted_body.splitRef("\n")) {
if (firstLine) {
firstLine = false;
body = QString("> <%1> %2\n").arg(related.quoted_user).arg(line);
} else {
body = QString("%1\n> %2\n").arg(body).arg(line);
}
}
text.body = QString("%1\n%2").arg(body).arg(reply).toStdString();
text.format = "org.matrix.custom.html";
text.formatted_body =
utils::getFormattedQuoteBody(related, utils::markdownToHtml(reply)).toStdString();
text.relates_to.in_reply_to.event_id = related.related_event;
if (timeline_)
timeline_->sendMessage(text);
}