2020-11-16 13:32:56 +01:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Window 2.2
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import QtGraphicalEffects 1.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
2020-11-16 13:32:56 +01:00
|
|
|
|
|
|
|
Popup {
|
|
|
|
id: root
|
2021-08-16 11:11:43 +02:00
|
|
|
|
2022-08-12 12:20:23 +03:00
|
|
|
signal clicked(var mouse)
|
2021-08-16 11:11:43 +02:00
|
|
|
property string imageSource: messageImage.source
|
2022-02-01 14:10:24 +01:00
|
|
|
property var contextMenu
|
2021-08-16 11:11:43 +02:00
|
|
|
|
2020-11-16 13:32:56 +01:00
|
|
|
modal: true
|
|
|
|
Overlay.modal: Rectangle {
|
|
|
|
color: "#40000000"
|
|
|
|
}
|
|
|
|
parent: Overlay.overlay
|
|
|
|
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutside
|
|
|
|
x: Math.round(((parent ? parent.width : 0) - width) / 2)
|
|
|
|
y: Math.round(((parent ? parent.height : 0) - height) / 2)
|
|
|
|
background: Rectangle {
|
|
|
|
color: "transparent"
|
|
|
|
}
|
|
|
|
padding: 0
|
|
|
|
|
|
|
|
function setPopupData(image) {
|
2020-11-17 14:43:52 -05:00
|
|
|
messageImage.source = image.source;
|
2021-12-08 23:20:43 +02:00
|
|
|
const maxHeight = Global.applicationWindow.height - 80
|
|
|
|
const maxWidth = Global.applicationWindow.width - 80
|
2020-11-16 13:32:56 +01:00
|
|
|
|
|
|
|
|
2020-11-17 14:43:52 -05:00
|
|
|
if (image.sourceSize.width >= maxWidth || image.sourceSize.height >= maxHeight) {
|
2020-11-16 13:32:56 +01:00
|
|
|
this.width = maxWidth
|
|
|
|
this.height = maxHeight
|
|
|
|
} else {
|
2020-11-17 14:43:52 -05:00
|
|
|
this.width = image.sourceSize.width
|
|
|
|
this.height = image.sourceSize.height
|
2020-11-16 13:32:56 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function openPopup(image) {
|
|
|
|
setPopupData(image);
|
|
|
|
root.open();
|
|
|
|
}
|
|
|
|
|
2022-05-17 00:44:34 +03:00
|
|
|
contentItem: AnimatedImage {
|
2020-11-16 13:32:56 +01:00
|
|
|
id: messageImage
|
|
|
|
asynchronous: true
|
|
|
|
fillMode: Image.PreserveAspectFit
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
mipmap: true
|
|
|
|
smooth: false
|
2020-12-15 16:16:49 -04:00
|
|
|
|
2022-05-17 00:44:34 +03:00
|
|
|
onStatusChanged: playing = (status == AnimatedImage.Ready)
|
2020-12-15 16:16:49 -04:00
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
2021-08-16 11:11:43 +02:00
|
|
|
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
|
|
|
onClicked: {
|
2022-08-12 12:20:23 +03:00
|
|
|
root.clicked(mouse)
|
2021-08-16 11:11:43 +02:00
|
|
|
}
|
2020-12-15 16:16:49 -04:00
|
|
|
}
|
2020-11-16 13:32:56 +01:00
|
|
|
}
|
|
|
|
}
|