matrixion/qml/delegates/ImageMessage.qml

103 lines
3.2 KiB
QML
Raw Normal View History

2021-03-05 02:35:15 +03:00
// SPDX-FileCopyrightText: 2021 Nheko Contributors
// SPDX-FileCopyrightText: 2022 Nheko Contributors
//
2021-03-05 02:35:15 +03:00
// SPDX-License-Identifier: GPL-3.0-or-later
2021-12-08 03:46:40 +03:00
import QtQuick 2.15
import QtQuick.Window 2.15
2022-03-24 03:35:42 +03:00
import QtQuick.Controls 2.3
import im.nheko
2019-10-06 02:44:02 +03:00
2022-03-24 03:35:42 +03:00
AbstractButton {
required property int type
required property int originalWidth
required property double proportionalHeight
required property string url
required property string blurhash
required property string body
required property string filename
required property bool isReply
2021-08-29 06:20:23 +03:00
required property string eventId
property double divisor: isReply ? 5 : 3
2020-10-08 22:11:21 +03:00
property int tempWidth: originalWidth < 1? 400: originalWidth
implicitWidth: Math.round(tempWidth*Math.min((timelineView.height/divisor)/(tempWidth*proportionalHeight), 1))
2022-04-11 05:18:16 +03:00
width: Math.min(parent?.width ?? implicitWidth,implicitWidth)
height: width*proportionalHeight
2022-03-24 03:35:42 +03:00
hoverEnabled: true
2020-10-08 22:11:21 +03:00
2022-02-14 23:07:03 +03:00
property int metadataWidth
property bool fitsMetadata: (parent.width - width) > metadataWidth+4
2020-10-08 22:11:21 +03:00
Image {
id: blurhash_
2020-10-08 22:11:21 +03:00
anchors.fill: parent
visible: img.status != Image.Ready
2022-04-15 06:53:41 +03:00
source: blurhash ? ("image://blurhash/" + blurhash) : ("image://colorimage/:/icons/icons/ui/image-failed.svg?" + timelineRoot.palette.placeholderText)
2020-10-08 22:11:21 +03:00
asynchronous: true
fillMode: Image.PreserveAspectFit
sourceSize.width: parent.width * Screen.devicePixelRatio
sourceSize.height: parent.height * Screen.devicePixelRatio
2020-10-08 22:11:21 +03:00
}
Image {
id: img
2021-08-29 06:20:23 +03:00
visible: !mxcimage.loaded
2020-10-08 22:11:21 +03:00
anchors.fill: parent
source: url.replace("mxc://", "image://MxcImage/") + "?scale"
2020-10-08 22:11:21 +03:00
asynchronous: true
fillMode: Image.PreserveAspectFit
2020-08-21 22:46:42 +03:00
smooth: true
mipmap: true
2020-10-08 22:11:21 +03:00
sourceSize.width: Math.min(Screen.desktopAvailableWidth, originalWidth < 1 ? Screen.desktopAvailableWidth : originalWidth) * Screen.devicePixelRatio
sourceSize.height: Math.min(Screen.desktopAvailableHeight, (originalWidth < 1 ? Screen.desktopAvailableHeight : originalWidth*proportionalHeight)) * Screen.devicePixelRatio
2021-08-29 06:20:23 +03:00
}
2020-10-08 22:11:21 +03:00
2021-08-29 06:20:23 +03:00
MxcAnimatedImage {
id: mxcimage
2020-10-18 23:30:42 +03:00
2021-08-29 06:20:23 +03:00
visible: loaded
anchors.fill: parent
roomm: room
2022-03-24 03:35:42 +03:00
play: !Settings.animateImagesOnHover || parent.hovered
2021-08-29 06:20:23 +03:00
eventId: parent.eventId
}
2022-03-24 03:35:42 +03:00
onClicked :Settings.openImageExternal ? room.openMedia(eventId) : TimelineManager.openImageOverlay(room, url, eventId);
2020-10-18 23:30:42 +03:00
2021-08-29 06:20:23 +03:00
Item {
id: overlay
2020-10-13 23:24:42 +03:00
2021-08-29 06:20:23 +03:00
anchors.fill: parent
2022-03-24 03:35:42 +03:00
visible: parent.hovered
2020-10-18 23:30:42 +03:00
2021-08-29 06:20:23 +03:00
Rectangle {
id: container
width: parent.width
implicitHeight: imgcaption.implicitHeight
anchors.bottom: overlay.bottom
2022-04-11 05:18:16 +03:00
color: timelineRoot.palette.window
2021-08-29 06:20:23 +03:00
opacity: 0.75
}
Text {
id: imgcaption
2020-10-18 23:30:42 +03:00
2021-08-29 06:20:23 +03:00
anchors.fill: container
elide: Text.ElideMiddle
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
// See this MSC: https://github.com/matrix-org/matrix-doc/pull/2530
text: filename ? filename : body
2022-04-11 05:18:16 +03:00
color: timelineRoot.palette.text
2020-10-13 23:24:42 +03:00
}
2020-10-18 23:30:42 +03:00
2020-10-13 23:24:42 +03:00
}
2020-10-18 23:30:42 +03:00
}