2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
2020-08-18 14:46:11 -04:00
|
|
|
import QtGraphicalEffects 1.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-05 22:50:22 +02:00
|
|
|
|
|
|
|
import "../../../../shared"
|
|
|
|
import "../helpers/collectiblesData.js" as CollectiblesData
|
|
|
|
import "../popups"
|
|
|
|
import "../panels"
|
|
|
|
import "../stores"
|
2020-05-28 10:54:42 -04:00
|
|
|
|
|
|
|
Item {
|
2020-08-18 14:46:11 -04:00
|
|
|
id: root
|
2020-07-28 14:19:46 -04:00
|
|
|
|
2020-08-20 17:59:07 -04:00
|
|
|
StyledText {
|
|
|
|
id: noCollectiblesText
|
|
|
|
color: Style.current.secondaryText
|
2020-08-26 11:52:26 -04:00
|
|
|
//% "Collectibles will appear here"
|
|
|
|
text: qsTrId("collectibles-will-appear-here")
|
2020-08-20 17:59:07 -04:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
font.pixelSize: 15
|
2020-07-30 16:46:25 -04:00
|
|
|
}
|
|
|
|
|
2020-08-19 11:58:25 -04:00
|
|
|
CollectiblesModal {
|
|
|
|
id: collectiblesModalComponent
|
|
|
|
}
|
|
|
|
|
2020-08-20 17:59:07 -04:00
|
|
|
function checkCollectiblesVisibility() {
|
|
|
|
// Show the collectibles section only if at least one of the sub-items is visible
|
|
|
|
// Sub-items are visible only if they are loading or have more than zero collectible
|
|
|
|
let showCollectibles = false
|
|
|
|
let currentItem
|
|
|
|
for (let i = 0; i < collectiblesRepeater.count; i++) {
|
|
|
|
currentItem = collectiblesRepeater.itemAt(i)
|
|
|
|
if (currentItem && currentItem.active) {
|
|
|
|
showCollectibles = true
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
noCollectiblesText.visible = !showCollectibles
|
|
|
|
collectiblesSection.visible = showCollectibles
|
|
|
|
}
|
2020-08-18 14:46:11 -04:00
|
|
|
|
2020-08-20 17:59:07 -04:00
|
|
|
Column {
|
|
|
|
id: collectiblesSection
|
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
anchors.fill: parent
|
2020-08-19 13:07:07 -04:00
|
|
|
|
2020-08-20 17:59:07 -04:00
|
|
|
Repeater {
|
|
|
|
id: collectiblesRepeater
|
2021-10-05 22:50:22 +02:00
|
|
|
model: RootStore.collectiblesList
|
2020-08-19 13:07:07 -04:00
|
|
|
|
|
|
|
CollectiblesContainer {
|
2020-08-20 17:59:07 -04:00
|
|
|
property var collectibleData: CollectiblesData.collectiblesData[model.collectibleType]
|
2020-08-19 13:07:07 -04:00
|
|
|
|
2020-08-20 17:59:07 -04:00
|
|
|
collectibleName: collectibleData.collectibleName
|
2021-09-28 18:04:06 +03:00
|
|
|
collectibleIconSource: Style.png("collectibles/" + collectibleData.collectibleIconSource)
|
2020-08-19 13:07:07 -04:00
|
|
|
collectiblesModal: collectiblesModalComponent
|
2020-08-20 17:59:07 -04:00
|
|
|
buttonText: collectibleData.buttonText
|
|
|
|
getLink: collectibleData.getLink
|
2020-08-27 10:41:50 -04:00
|
|
|
onActiveChanged: {
|
2020-08-20 17:59:07 -04:00
|
|
|
checkCollectiblesVisibility()
|
2020-08-19 13:07:07 -04:00
|
|
|
}
|
2021-10-05 22:50:22 +02:00
|
|
|
onReloadCollectibles: {
|
|
|
|
RootStore.reloadCollectible(collectibleType)
|
|
|
|
}
|
2020-08-19 11:58:25 -04:00
|
|
|
}
|
2020-08-18 14:46:11 -04:00
|
|
|
}
|
2020-07-28 14:19:46 -04:00
|
|
|
}
|
2020-08-24 16:50:49 -04:00
|
|
|
|
|
|
|
Connections {
|
2021-10-05 22:50:22 +02:00
|
|
|
target: RootStore.collectiblesList
|
2020-08-24 16:50:49 -04:00
|
|
|
onDataChanged: {
|
|
|
|
checkCollectiblesVisibility()
|
|
|
|
}
|
|
|
|
}
|
2020-05-28 10:54:42 -04:00
|
|
|
}
|