2020-08-18 16:11:36 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtGraphicalEffects 1.13
|
2020-08-19 17:09:11 -04:00
|
|
|
import QtQml.Models 2.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2022-07-13 15:29:38 +03:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared.panels 1.0
|
2021-10-20 12:21:23 +02:00
|
|
|
|
2022-07-13 15:29:38 +03:00
|
|
|
StatusScrollView {
|
2021-10-05 22:50:22 +02:00
|
|
|
id: collectiblesContent
|
|
|
|
|
2020-08-18 16:11:36 -04:00
|
|
|
readonly property int imageSize: 164
|
2020-08-19 11:58:25 -04:00
|
|
|
property var collectiblesModal
|
|
|
|
property string buttonText: "View in Cryptokitties"
|
|
|
|
property var getLink: function () {}
|
2020-08-20 17:59:07 -04:00
|
|
|
property var collectibles: []
|
2020-08-18 16:11:36 -04:00
|
|
|
|
2021-10-05 22:50:22 +02:00
|
|
|
signal reloadCollectibles(string collectibleType)
|
|
|
|
|
2020-08-24 16:50:49 -04:00
|
|
|
height: visible ? contentLoader.item.height : 0
|
2020-08-18 16:11:36 -04:00
|
|
|
width: parent.width
|
|
|
|
ScrollBar.vertical.policy: ScrollBar.AlwaysOff
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AsNeeded
|
2023-05-31 23:58:23 +03:00
|
|
|
contentWidth: availableWidth
|
2020-08-18 16:11:36 -04:00
|
|
|
|
2020-08-24 16:50:49 -04:00
|
|
|
Loader {
|
|
|
|
id: contentLoader
|
|
|
|
active: true
|
2023-05-31 23:58:23 +03:00
|
|
|
width: collectiblesContent.availableWidth
|
2021-10-05 22:50:22 +02:00
|
|
|
height: collectiblesContent.imageSize
|
2020-08-24 16:50:49 -04:00
|
|
|
sourceComponent: !!error ? errorComponent : collectiblesContentComponent
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: errorComponent
|
2020-08-18 16:11:36 -04:00
|
|
|
|
2020-08-24 16:50:49 -04:00
|
|
|
Item {
|
|
|
|
width: parent.width
|
2021-10-05 22:50:22 +02:00
|
|
|
height: collectiblesContent.imageSize
|
2020-08-18 16:11:36 -04:00
|
|
|
|
2020-08-24 16:50:49 -04:00
|
|
|
Item {
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
height: childrenRect.height
|
|
|
|
width: somethingWentWrongText.width
|
2020-08-18 16:11:36 -04:00
|
|
|
|
2020-08-24 16:50:49 -04:00
|
|
|
StyledText {
|
|
|
|
id: somethingWentWrongText
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Something went wrong")
|
2020-08-24 16:50:49 -04:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
font.pixelSize: 13
|
2020-08-18 16:11:36 -04:00
|
|
|
}
|
2020-08-19 11:58:25 -04:00
|
|
|
|
2021-01-28 12:04:10 +01:00
|
|
|
StatusButton {
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Reload")
|
2020-08-24 16:50:49 -04:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.top: somethingWentWrongText.bottom
|
|
|
|
anchors.topMargin: Style.current.halfPadding
|
2020-08-19 11:58:25 -04:00
|
|
|
onClicked: {
|
2021-12-06 23:10:54 +02:00
|
|
|
reloadCollectibles(collectibleType);
|
2020-08-24 16:50:49 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: collectiblesContentComponent
|
|
|
|
|
|
|
|
Row {
|
|
|
|
id: contentRow
|
|
|
|
bottomPadding: Style.current.padding
|
|
|
|
spacing: Style.current.padding
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
model: collectibles
|
|
|
|
|
2020-08-27 10:41:50 -04:00
|
|
|
Item {
|
2020-08-24 16:50:49 -04:00
|
|
|
width: collectibleImage.width
|
|
|
|
height: collectibleImage.height
|
2020-08-27 10:41:50 -04:00
|
|
|
clip: true
|
2020-08-24 16:50:49 -04:00
|
|
|
|
2020-10-06 15:16:36 +11:00
|
|
|
RoundedImage {
|
2020-08-24 16:50:49 -04:00
|
|
|
id: collectibleImage
|
2021-10-05 22:50:22 +02:00
|
|
|
width: collectiblesContent.imageSize
|
|
|
|
height: collectiblesContent.imageSize
|
2020-10-06 15:16:36 +11:00
|
|
|
border.width: 1
|
|
|
|
border.color: Style.current.border
|
|
|
|
radius: 16
|
2020-08-24 16:50:49 -04:00
|
|
|
source: modelData.image
|
|
|
|
fillMode: Image.PreserveAspectCrop
|
2020-08-27 10:41:50 -04:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2020-08-24 16:50:49 -04:00
|
|
|
onClicked: {
|
|
|
|
collectiblesModal.openModal({
|
|
|
|
name: modelData.name,
|
|
|
|
id: modelData.id,
|
|
|
|
description: modelData.description,
|
2021-10-05 22:50:22 +02:00
|
|
|
buttonText: collectiblesContent.buttonText,
|
|
|
|
link: collectiblesContent.getLink(modelData.id, modelData.externalUrl),
|
2020-08-24 16:50:49 -04:00
|
|
|
image: modelData.image
|
|
|
|
})
|
|
|
|
}
|
2020-08-19 11:58:25 -04:00
|
|
|
}
|
|
|
|
}
|
2020-08-18 16:11:36 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|