mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-09 22:06:25 +00:00
80 lines
2.4 KiB
QML
80 lines
2.4 KiB
QML
import QtQuick 2.13
|
|
import QtGraphicalEffects 1.13
|
|
|
|
import utils 1.0
|
|
|
|
import "../../../../shared"
|
|
import "../../../../shared/panels"
|
|
import "../helpers/collectiblesData.js" as CollectiblesData
|
|
import "../popups"
|
|
import "../panels"
|
|
import "../stores"
|
|
|
|
Item {
|
|
id: root
|
|
|
|
StyledText {
|
|
id: noCollectiblesText
|
|
color: Style.current.secondaryText
|
|
//% "Collectibles will appear here"
|
|
text: qsTrId("collectibles-will-appear-here")
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
font.pixelSize: 15
|
|
}
|
|
|
|
CollectiblesModal {
|
|
id: collectiblesModalComponent
|
|
}
|
|
|
|
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
|
|
}
|
|
|
|
Column {
|
|
id: collectiblesSection
|
|
spacing: Style.current.halfPadding
|
|
anchors.fill: parent
|
|
|
|
Repeater {
|
|
id: collectiblesRepeater
|
|
model: RootStore.collectiblesList
|
|
|
|
CollectiblesContainer {
|
|
property var collectibleData: CollectiblesData.collectiblesData[model.collectibleType]
|
|
|
|
collectibleName: collectibleData.collectibleName
|
|
collectibleIconSource: Style.png("collectibles/" + collectibleData.collectibleIconSource)
|
|
collectiblesModal: collectiblesModalComponent
|
|
buttonText: collectibleData.buttonText
|
|
getLink: collectibleData.getLink
|
|
onActiveChanged: {
|
|
checkCollectiblesVisibility()
|
|
}
|
|
onReloadCollectibles: {
|
|
RootStore.reloadCollectible(collectibleType)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: RootStore.collectiblesList
|
|
onDataChanged: {
|
|
checkCollectiblesVisibility()
|
|
}
|
|
}
|
|
}
|