Add EventMediaLoader
Handles loading of URL previews and will handle all matrix media messages types.
This commit is contained in:
parent
8ad13b033d
commit
0db34cc3c8
@ -166,7 +166,7 @@ class Event(ModelItem):
|
|||||||
return []
|
return []
|
||||||
|
|
||||||
if isinstance(self.source, nio.RoomMessageMedia):
|
if isinstance(self.source, nio.RoomMessageMedia):
|
||||||
return [self.thumbnail_url or self.content]
|
return [self.media_url]
|
||||||
|
|
||||||
return [link[2] for link in lxml.html.iterlinks(self.content)]
|
return [link[2] for link in lxml.html.iterlinks(self.content)]
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import QtQuick 2.12
|
import QtQuick 2.12
|
||||||
|
import "../utils.js" as Utils
|
||||||
|
|
||||||
Image {
|
Image {
|
||||||
id: image
|
id: image
|
||||||
@ -12,10 +13,7 @@ Image {
|
|||||||
|
|
||||||
property bool animate: true
|
property bool animate: true
|
||||||
|
|
||||||
readonly property bool animated:
|
readonly property bool animated: Utils.urlExtension(image.source) == "gif"
|
||||||
image.source.toString()
|
|
||||||
.split("/").splice(-1)[0].split("?")[0].toLowerCase()
|
|
||||||
.endsWith(".gif")
|
|
||||||
|
|
||||||
|
|
||||||
Component {
|
Component {
|
||||||
|
@ -148,15 +148,11 @@ Row {
|
|||||||
|
|
||||||
Repeater {
|
Repeater {
|
||||||
id: previewLinksRepeater
|
id: previewLinksRepeater
|
||||||
model: eventDelegate.links
|
model: eventDelegate.currentItem.links
|
||||||
|
|
||||||
HLoader {
|
EventMediaLoader {
|
||||||
Component.onCompleted: {
|
info: eventDelegate.currentItem
|
||||||
setSource(
|
mediaUrl: modelData
|
||||||
"EventImage.qml",
|
|
||||||
{ source: modelData },
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@ Column {
|
|||||||
// Remember timeline goes from newest message at index 0 to oldest
|
// Remember timeline goes from newest message at index 0 to oldest
|
||||||
property var previousItem: eventList.model.get(model.index + 1)
|
property var previousItem: eventList.model.get(model.index + 1)
|
||||||
property var nextItem: eventList.model.get(model.index - 1)
|
property var nextItem: eventList.model.get(model.index - 1)
|
||||||
|
readonly property QtObject currentItem: model
|
||||||
|
|
||||||
property int modelIndex: model.index
|
property int modelIndex: model.index
|
||||||
onModelIndexChanged: {
|
onModelIndexChanged: {
|
||||||
@ -47,8 +48,6 @@ Column {
|
|||||||
readonly property bool unselectableNameLine:
|
readonly property bool unselectableNameLine:
|
||||||
hideNameLine && ! (onRight && ! combine)
|
hideNameLine && ! (onRight && ! combine)
|
||||||
|
|
||||||
readonly property var links: model.links
|
|
||||||
|
|
||||||
|
|
||||||
function json() {
|
function json() {
|
||||||
return JSON.stringify(
|
return JSON.stringify(
|
||||||
|
65
src/qml/Chat/Timeline/EventMediaLoader.qml
Normal file
65
src/qml/Chat/Timeline/EventMediaLoader.qml
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
import QtQuick 2.12
|
||||||
|
import "../../Base"
|
||||||
|
import "../../utils.js" as Utils
|
||||||
|
|
||||||
|
HLoader {
|
||||||
|
id: loader
|
||||||
|
|
||||||
|
|
||||||
|
enum Type { Page, File, Image, Video, Audio }
|
||||||
|
|
||||||
|
property QtObject info
|
||||||
|
property url mediaUrl
|
||||||
|
|
||||||
|
readonly property var imageExtensions: [
|
||||||
|
"bmp", "gif", "jpg", "jpeg", "png", "pbm", "pgm", "ppm", "xbm", "xpm",
|
||||||
|
"tiff", "webp", "svg",
|
||||||
|
]
|
||||||
|
|
||||||
|
readonly property var videoExtensions: [
|
||||||
|
"3gp", "avi", "flv", "m4p", "m4v", "mkv", "mov", "mp4",
|
||||||
|
"mpeg", "mpg", "ogv", "qt", "vob", "webm", "wmv", "yuv",
|
||||||
|
]
|
||||||
|
|
||||||
|
readonly property var audioExtensions: [
|
||||||
|
"pcm", "wav", "raw", "aiff", "flac", "m4a", "tta", "aac", "mp3",
|
||||||
|
"ogg", "oga", "opus",
|
||||||
|
]
|
||||||
|
|
||||||
|
readonly property int type: {
|
||||||
|
let main_type = info.media_mime.split("/")[0].toLowerCase()
|
||||||
|
|
||||||
|
if (main_type === "image") return EventMediaLoader.Type.Image
|
||||||
|
if (main_type === "video") return EventMediaLoader.Type.Video
|
||||||
|
if (main_type === "audio") return EventMediaLoader.Type.Audio
|
||||||
|
|
||||||
|
if (info.event_type === "RoomMessageFile")
|
||||||
|
return EventMediaLoader.Type.File
|
||||||
|
|
||||||
|
let ext = Utils.urlExtension(mediaUrl)
|
||||||
|
|
||||||
|
if (imageExtensions.includes(ext)) return EventMediaLoader.Type.Image
|
||||||
|
if (videoExtensions.includes(ext)) return EventMediaLoader.Type.Video
|
||||||
|
if (audioExtensions.includes(ext)) return EventMediaLoader.Type.Audio
|
||||||
|
|
||||||
|
return EventMediaLoader.Type.Page
|
||||||
|
}
|
||||||
|
|
||||||
|
readonly property url previewUrl: (
|
||||||
|
type === EventMediaLoader.Type.File ||
|
||||||
|
type === EventMediaLoader.Type.Image ?
|
||||||
|
info.thumbnail_url : ""
|
||||||
|
) || mediaUrl
|
||||||
|
|
||||||
|
|
||||||
|
onPreviewUrlChanged: {
|
||||||
|
if (type === EventMediaLoader.Type.Image) {
|
||||||
|
var file = "EventImage.qml"
|
||||||
|
var props = { source: previewUrl }
|
||||||
|
} else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
loader.setSource(file, props)
|
||||||
|
}
|
||||||
|
}
|
@ -250,3 +250,9 @@ function copyToClipboard(text) {
|
|||||||
window.pseudoClipboard.selectAll()
|
window.pseudoClipboard.selectAll()
|
||||||
window.pseudoClipboard.copy()
|
window.pseudoClipboard.copy()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function urlExtension(url) {
|
||||||
|
return url.toString().split("/").splice(-1)[0].split("?")[0].split(".")
|
||||||
|
.splice(-1)[0].toLowerCase()
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user