2023-02-01 18:26:59 +01:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
2023-06-23 08:17:04 +02:00
|
|
|
import AppLayouts.Communities.helpers 1.0
|
|
|
|
import AppLayouts.Communities.controls 1.0
|
|
|
|
import AppLayouts.Communities.views 1.0
|
2023-02-01 18:26:59 +01:00
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
Control {
|
|
|
|
id: root
|
|
|
|
|
2023-02-13 11:40:13 +01:00
|
|
|
property var assetsModel
|
|
|
|
property var collectiblesModel
|
|
|
|
|
2023-02-01 18:26:59 +01:00
|
|
|
property var model
|
|
|
|
property string introText
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
// By design values:
|
|
|
|
readonly property int defaultHoldingsSpacing: 8
|
|
|
|
}
|
|
|
|
|
|
|
|
contentItem: ColumnLayout {
|
|
|
|
spacing: root.spacing
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
horizontalAlignment: Text.AlignHCenter
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
text: root.introText
|
|
|
|
textFormat: Text.StyledText
|
|
|
|
}
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
|
|
|
spacing: d.defaultHoldingsSpacing
|
|
|
|
|
|
|
|
Repeater {
|
2023-02-17 14:36:58 +01:00
|
|
|
id: repeater
|
|
|
|
|
2023-02-01 18:26:59 +01:00
|
|
|
model: root.model
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
|
|
|
spacing: d.defaultHoldingsSpacing
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
spacing: 18 // by design
|
|
|
|
|
|
|
|
Repeater {
|
2023-02-13 11:40:13 +01:00
|
|
|
|
|
|
|
model: HoldingsSelectionModel {
|
2023-02-01 18:26:59 +01:00
|
|
|
sourceModel: holdingsListModel
|
2023-02-13 11:40:13 +01:00
|
|
|
|
|
|
|
assetsModel: root.assetsModel
|
|
|
|
collectiblesModel: root.collectiblesModel
|
2023-02-01 18:26:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusListItemTag {
|
|
|
|
enabled: false
|
|
|
|
leftPadding: 2
|
2023-02-13 11:40:13 +01:00
|
|
|
title: model.text
|
2023-02-01 18:26:59 +01:00
|
|
|
asset.name: model.imageSource
|
2023-04-25 13:31:14 +02:00
|
|
|
asset.isImage: true
|
2023-02-01 18:26:59 +01:00
|
|
|
asset.bgColor: "transparent"
|
|
|
|
asset.height: 28
|
|
|
|
asset.width: asset.height
|
2023-03-27 14:51:58 +03:00
|
|
|
asset.bgWidth: asset.height
|
|
|
|
asset.bgHeight: asset.height
|
|
|
|
asset.color: asset.isImage ? "transparent" : titleText.color
|
2023-02-01 18:26:59 +01:00
|
|
|
closeButtonVisible: false
|
|
|
|
titleText.color: model.available ? Theme.palette.primaryColor1 : Theme.palette.dangerColor1
|
2023-07-04 17:11:41 +02:00
|
|
|
bgColor: model.available ? Theme.palette.primaryColor2 : Theme.palette.dangerColor2
|
2023-02-01 18:26:59 +01:00
|
|
|
titleText.font.pixelSize: 15
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
|
|
|
text: qsTr("or")
|
|
|
|
textFormat: Text.StyledText
|
2023-02-17 14:36:58 +01:00
|
|
|
visible: (index !== repeater.count - 1)
|
2023-02-01 18:26:59 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|