2020-09-23 18:18:23 +10:00
|
|
|
import QtQuick 2.3
|
|
|
|
import QtGraphicalEffects 1.13
|
|
|
|
import "../imports"
|
2021-04-26 12:25:01 +02:00
|
|
|
import "./status/core"
|
|
|
|
import "./status"
|
2020-09-23 18:18:23 +10:00
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: root
|
2020-11-30 12:03:52 -05:00
|
|
|
property bool noHover: false
|
2021-02-17 11:31:59 -05:00
|
|
|
property bool noMouseArea: false
|
2020-10-06 15:16:36 +11:00
|
|
|
property alias source: image.source
|
|
|
|
property alias fillMode: image.fillMode
|
2021-01-28 16:13:20 -04:00
|
|
|
property bool showLoadingIndicator: true
|
2020-10-20 10:15:04 -04:00
|
|
|
signal loaded
|
2020-09-23 18:18:23 +10:00
|
|
|
signal clicked
|
|
|
|
color: Style.current.backgroundHover
|
2021-01-28 16:13:20 -04:00
|
|
|
state: showLoadingIndicator ? "loading" : "ready"
|
2020-09-23 18:18:23 +10:00
|
|
|
radius: width / 2
|
|
|
|
states: [
|
|
|
|
State {
|
|
|
|
name: "loading"
|
|
|
|
when: image.status === Image.Loading
|
|
|
|
PropertyChanges {
|
|
|
|
target: loading
|
2020-10-07 14:12:43 -04:00
|
|
|
active: true
|
2020-09-23 18:18:23 +10:00
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: reload
|
|
|
|
visible: false
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: image
|
|
|
|
visible: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "error"
|
|
|
|
when: image.status === Image.Error
|
|
|
|
PropertyChanges {
|
|
|
|
target: loading
|
2020-10-07 14:12:43 -04:00
|
|
|
active: false
|
2020-09-23 18:18:23 +10:00
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: reload
|
|
|
|
visible: true
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: image
|
|
|
|
visible: false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
name: "ready"
|
|
|
|
when: image.status === Image.Ready
|
|
|
|
PropertyChanges {
|
|
|
|
target: root
|
|
|
|
color: Style.current.transparent
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: loading
|
2020-10-07 14:12:43 -04:00
|
|
|
active: false
|
2020-09-23 18:18:23 +10:00
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: reload
|
|
|
|
visible: false
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: image
|
|
|
|
visible: true
|
|
|
|
height: root.height
|
|
|
|
width: root.width
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
2020-12-14 16:50:47 +11:00
|
|
|
Connections {
|
|
|
|
target: chatsModel
|
|
|
|
onOnlineStatusChanged: {
|
|
|
|
if (connected && root.state !== "ready" &&
|
|
|
|
root.visible &&
|
|
|
|
root.source &&
|
|
|
|
root.source.startsWith("http")) {
|
|
|
|
root.reload()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-23 18:18:23 +10:00
|
|
|
function reload() {
|
|
|
|
// From the documentation (https://doc.qt.io/qt-5/qml-qtquick-image.html#sourceSize-prop)
|
|
|
|
// Note: Changing this property dynamically causes the image source to
|
|
|
|
// be reloaded, potentially even from the network, if it is not in the
|
|
|
|
// disk cache.
|
2020-12-14 16:50:47 +11:00
|
|
|
const oldSource = image.source
|
|
|
|
image.cache = false
|
2020-09-23 18:18:23 +10:00
|
|
|
image.sourceSize.width += 1
|
|
|
|
image.sourceSize.width -= 1
|
2020-12-14 16:50:47 +11:00
|
|
|
image.cache = true
|
|
|
|
|
2020-09-23 18:18:23 +10:00
|
|
|
}
|
|
|
|
|
2020-10-07 14:12:43 -04:00
|
|
|
Component {
|
|
|
|
id: loadingIndicator
|
2021-04-26 12:25:01 +02:00
|
|
|
StatusLoadingIndicator {
|
2020-10-07 14:12:43 -04:00
|
|
|
width: 23
|
|
|
|
height: 23
|
2021-04-26 12:25:01 +02:00
|
|
|
color: Style.current.secondaryText
|
2020-10-07 14:12:43 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
2020-09-23 18:18:23 +10:00
|
|
|
id: loading
|
2020-10-07 14:12:43 -04:00
|
|
|
sourceComponent: loadingIndicator
|
2020-09-23 18:18:23 +10:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2020-10-07 14:12:43 -04:00
|
|
|
active: false
|
2020-09-23 18:18:23 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
id: reload
|
|
|
|
source: "../app/img/reload.svg"
|
|
|
|
width: 15.5
|
|
|
|
height: 19.5
|
|
|
|
fillMode: Image.PreserveAspectFit
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
ColorOverlay {
|
|
|
|
anchors.fill: parent
|
|
|
|
source: parent
|
|
|
|
color: Style.current.textColor
|
|
|
|
antialiasing: true
|
|
|
|
}
|
|
|
|
MouseArea {
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
root.reload()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Image {
|
|
|
|
id: image
|
|
|
|
width: 0
|
|
|
|
height: 0
|
|
|
|
sourceSize.width: root.width * 2
|
|
|
|
sourceSize.height: root.height * 2
|
|
|
|
source: root.source
|
|
|
|
horizontalAlignment: Image.AlignHCenter
|
|
|
|
verticalAlignment: Image.AlignVCenter
|
|
|
|
cache: true
|
2020-10-20 10:15:04 -04:00
|
|
|
onStatusChanged: {
|
|
|
|
if (image.status === Image.Ready) {
|
|
|
|
loaded()
|
|
|
|
}
|
|
|
|
}
|
2020-09-23 18:18:23 +10:00
|
|
|
MouseArea {
|
2021-02-17 11:31:59 -05:00
|
|
|
enabled: !noMouseArea
|
2020-11-30 12:03:52 -05:00
|
|
|
cursorShape: noHover ? Qt.ArrowCursor : Qt.PointingHandCursor
|
2020-09-23 18:18:23 +10:00
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
root.clicked()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|