2019-09-08 12:44:46 +02:00
|
|
|
import QtQuick 2.6
|
|
|
|
|
2019-11-30 01:43:39 +01:00
|
|
|
import im.nheko 1.0
|
2019-10-06 01:44:02 +02:00
|
|
|
|
2019-09-08 12:44:46 +02:00
|
|
|
Item {
|
2020-03-08 14:39:01 +01:00
|
|
|
property double tempWidth: Math.min(parent ? parent.width : undefined, model.data.width < 1 ? parent.width : model.data.width)
|
2020-01-11 14:07:51 +01:00
|
|
|
property double tempHeight: tempWidth * model.data.proportionalHeight
|
2019-12-13 02:16:12 +01:00
|
|
|
|
2020-05-13 01:09:40 +02:00
|
|
|
property double divisor: model.isReply ? 4 : 2
|
|
|
|
property bool tooHigh: tempHeight > timelineRoot.height / divisor
|
2019-12-13 02:16:12 +01:00
|
|
|
|
2020-05-13 01:09:40 +02:00
|
|
|
height: tooHigh ? timelineRoot.height / divisor : tempHeight
|
|
|
|
width: tooHigh ? (timelineRoot.height / divisor) / model.data.proportionalHeight : tempWidth
|
2019-09-08 12:44:46 +02:00
|
|
|
|
2020-03-01 19:55:43 +01:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2019-09-08 12:44:46 +02:00
|
|
|
Image {
|
2019-09-28 11:07:58 +02:00
|
|
|
id: img
|
2019-09-08 12:44:46 +02:00
|
|
|
anchors.fill: parent
|
|
|
|
|
2020-01-11 14:07:51 +01:00
|
|
|
source: model.data.url.replace("mxc://", "image://MxcImage/")
|
2019-09-08 12:44:46 +02:00
|
|
|
asynchronous: true
|
|
|
|
fillMode: Image.PreserveAspectFit
|
2019-09-28 11:07:58 +02:00
|
|
|
|
|
|
|
MouseArea {
|
2020-04-21 20:55:28 +02:00
|
|
|
enabled: model.data.type == MtxEvent.ImageMessage && img.status == Image.Ready
|
2019-09-28 11:07:58 +02:00
|
|
|
anchors.fill: parent
|
2020-01-11 14:07:51 +01:00
|
|
|
onClicked: timelineManager.openImageOverlay(model.data.url, model.data.id)
|
2019-09-28 11:07:58 +02:00
|
|
|
}
|
2019-09-08 12:44:46 +02:00
|
|
|
}
|
|
|
|
}
|