matrixion/resources/qml/delegates/ImageMessage.qml

43 lines
1.3 KiB
QML
Raw Normal View History

import QtQuick 2.6
import im.nheko 1.0
2019-10-06 02:44:02 +03:00
Item {
2020-03-08 16:39:01 +03:00
property double tempWidth: Math.min(parent ? parent.width : undefined, model.data.width < 1 ? parent.width : model.data.width)
property double tempHeight: tempWidth * model.data.proportionalHeight
2019-12-13 04:16:12 +03:00
property double divisor: model.isReply ? 4 : 2
property bool tooHigh: tempHeight > timelineRoot.height / divisor
2019-12-13 04:16:12 +03:00
height: tooHigh ? timelineRoot.height / divisor : tempHeight
width: tooHigh ? (timelineRoot.height / divisor) / model.data.proportionalHeight : tempWidth
Image {
id: blurhash
anchors.fill: parent
visible: img.status != Image.Ready
source: model.data.blurhash ? ("image://blurhash/" + model.data.blurhash) : ("image://colorimage/:/icons/icons/ui/do-not-disturb-rounded-sign@2x.png?"+colors.buttonText)
asynchronous: true
fillMode: Image.PreserveAspectFit
sourceSize.width: parent.width
sourceSize.height: parent.height
}
Image {
2019-09-28 12:07:58 +03:00
id: img
anchors.fill: parent
source: model.data.url.replace("mxc://", "image://MxcImage/")
asynchronous: true
fillMode: Image.PreserveAspectFit
2019-09-28 12:07:58 +03:00
MouseArea {
enabled: model.data.type == MtxEvent.ImageMessage && img.status == Image.Ready
2019-09-28 12:07:58 +03:00
anchors.fill: parent
onClicked: timelineManager.openImageOverlay(model.data.url, model.data.id)
2019-09-28 12:07:58 +03:00
}
}
}