Refactor and fix opening file-based content
The relevant fix is checking whether the the event is file-*based* (i.e., image, video, audio, file), not whether it *is* a file
This commit is contained in:
committed by
Tobias Fella
parent
d30fdc67c6
commit
b972703f34
@@ -1214,34 +1214,38 @@ QByteArray NeoChatRoom::getEventJsonSource(const QString &eventId)
|
|||||||
void NeoChatRoom::openEventMediaExternally(const QString &eventId)
|
void NeoChatRoom::openEventMediaExternally(const QString &eventId)
|
||||||
{
|
{
|
||||||
const auto evtIt = findInTimeline(eventId);
|
const auto evtIt = findInTimeline(eventId);
|
||||||
if (evtIt != messageEvents().rend() && is<RoomMessageEvent>(**evtIt)) {
|
if (evtIt == messageEvents().rend()) {
|
||||||
const auto event = evtIt->viewAs<RoomMessageEvent>();
|
return;
|
||||||
if (event->has<EventContent::FileContent>()) {
|
}
|
||||||
const auto transferInfo = cachedFileTransferInfo(event);
|
|
||||||
if (transferInfo.completed()) {
|
// TODO: Also allow stickers here, once that's fixed in libQuotient
|
||||||
|
if (!is<RoomMessageEvent>(**evtIt) || !evtIt->viewAs<RoomMessageEvent>()->has<EventContent::FileContentBase>()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto transferInfo = cachedFileTransferInfo(evtIt->viewAs<RoomEvent>());
|
||||||
|
if (transferInfo.completed()) {
|
||||||
|
UrlHelper helper;
|
||||||
|
helper.openUrl(transferInfo.localPath);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
downloadFile(eventId,
|
||||||
|
QUrl(QStandardPaths::writableLocation(QStandardPaths::CacheLocation) + u'/'
|
||||||
|
+ evtIt->event()->id().replace(u':', u'_').replace(u'/', u'_').replace(u'+', u'_') + fileNameToDownload(eventId)));
|
||||||
|
connect(
|
||||||
|
this,
|
||||||
|
&Room::fileTransferCompleted,
|
||||||
|
this,
|
||||||
|
[this, eventId](QString id, QUrl localFile, FileSourceInfo fileMetadata) {
|
||||||
|
Q_UNUSED(localFile);
|
||||||
|
Q_UNUSED(fileMetadata);
|
||||||
|
if (id == eventId) {
|
||||||
|
auto transferInfo = fileTransferInfo(eventId);
|
||||||
UrlHelper helper;
|
UrlHelper helper;
|
||||||
helper.openUrl(transferInfo.localPath);
|
helper.openUrl(transferInfo.localPath);
|
||||||
} else {
|
|
||||||
downloadFile(eventId,
|
|
||||||
QUrl(QStandardPaths::writableLocation(QStandardPaths::CacheLocation) + u'/'
|
|
||||||
+ event->id().replace(u':', u'_').replace(u'/', u'_').replace(u'+', u'_') + fileNameToDownload(eventId)));
|
|
||||||
connect(
|
|
||||||
this,
|
|
||||||
&Room::fileTransferCompleted,
|
|
||||||
this,
|
|
||||||
[this, eventId](QString id, QUrl localFile, FileSourceInfo fileMetadata) {
|
|
||||||
Q_UNUSED(localFile);
|
|
||||||
Q_UNUSED(fileMetadata);
|
|
||||||
if (id == eventId) {
|
|
||||||
auto transferInfo = fileTransferInfo(eventId);
|
|
||||||
UrlHelper helper;
|
|
||||||
helper.openUrl(transferInfo.localPath);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
static_cast<Qt::ConnectionType>(Qt::SingleShotConnection));
|
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
static_cast<Qt::ConnectionType>(Qt::SingleShotConnection));
|
||||||
}
|
}
|
||||||
|
|
||||||
void NeoChatRoom::copyEventMedia(const QString &eventId)
|
void NeoChatRoom::copyEventMedia(const QString &eventId)
|
||||||
|
|||||||
Reference in New Issue
Block a user