2023-03-10 16:55:50 +01:00
import QtQuick 2.0
import QtQuick . Layouts 1.14
2023-08-01 12:31:50 +02:00
import StatusQ . Controls 0.1
2023-03-10 16:55:50 +01:00
import StatusQ . Core 0.1
import StatusQ . Components 0.1
import StatusQ . Core . Theme 0.1
2023-08-01 12:31:50 +02:00
import StatusQ . Core . Utils 0.1 as StatusQUtils
2023-03-10 16:55:50 +01:00
2023-05-25 16:45:46 +02:00
import SortFilterProxyModel 0.2
2023-03-10 16:55:50 +01:00
import utils 1.0
2023-05-25 16:45:46 +02:00
import shared . controls 1.0
2023-03-10 16:55:50 +01:00
import AppLayouts . Wallet . views . collectibles 1.0
2023-06-27 23:56:45 +02:00
import AppLayouts . Communities . panels 1.0
2023-07-18 19:34:57 +02:00
import AppLayouts . Communities . helpers 1.0
2023-03-10 16:55:50 +01:00
StatusScrollView {
id: root
2023-07-18 19:34:57 +02:00
// User profile props
2023-07-06 14:33:27 +02:00
required property bool isOwner
2023-07-12 16:06:07 +02:00
required property bool isAdmin
2023-07-06 14:33:27 +02:00
2023-07-18 19:34:57 +02:00
// General props
2023-03-10 16:55:50 +01:00
property int viewWidth: 560 // by design
property var model
2023-07-18 19:34:57 +02:00
property string communityName
2023-08-01 12:31:50 +02:00
property bool anyPrivilegedTokenFailed: false
2023-06-27 23:56:45 +02:00
readonly property int count: assetsModel . count + collectiblesModel . count
2023-06-01 12:38:56 +02:00
signal itemClicked ( string tokenKey ,
2023-03-31 14:52:51 +02:00
int chainId ,
string chainName ,
string accountName ,
string accountAddress )
2023-03-10 16:55:50 +01:00
2023-08-01 12:31:50 +02:00
signal mintOwnerTokenClicked ( )
signal retryOwnerTokenClicked ( string tokenKey ,
int chainId ,
string accountName ,
string accountAddress )
2023-07-06 14:33:27 +02:00
2023-06-27 23:56:45 +02:00
padding: 0
2023-03-10 16:55:50 +01:00
QtObject {
id: d
2023-05-25 16:45:46 +02:00
readonly property int delegateAssetsHeight: 64
2023-07-18 19:34:57 +02:00
function getDeployStateInfo ( deployState ) {
2023-06-27 21:36:31 +02:00
if ( deployState === Constants . ContractTransactionStatus . Failed )
2023-05-17 12:00:52 +02:00
return qsTr ( "Minting failed" )
2023-03-10 16:55:50 +01:00
2023-06-27 21:36:31 +02:00
if ( deployState === Constants . ContractTransactionStatus . InProgress )
2023-03-10 16:55:50 +01:00
return qsTr ( "Minting..." )
2023-05-11 19:14:11 +02:00
2023-07-18 19:34:57 +02:00
return ""
}
2023-08-04 18:41:21 +02:00
function getRemainingInfo ( isOwnerToken , isTMasterToken ,
2023-07-18 19:34:57 +02:00
remainingSupply , supply , isInfiniteSupply ) {
// Owner token use case:
if ( isOwnerToken )
return qsTr ( "1 of 1 (you hodl)" )
// TMaster token use case:
2023-08-04 18:41:21 +02:00
if ( isTMasterToken )
2023-07-18 19:34:57 +02:00
return "∞"
// Rest of collectible cases:
2023-06-27 21:36:31 +02:00
if ( isInfiniteSupply )
2023-07-18 19:34:57 +02:00
return qsTr ( "∞ remaining" )
2023-06-27 21:36:31 +02:00
2023-07-18 19:34:57 +02:00
return qsTr ( "%L1 / %L2 remaining" ) . arg ( remainingSupply ) . arg ( supply )
2023-03-10 16:55:50 +01:00
}
}
2023-06-27 23:56:45 +02:00
SortFilterProxyModel {
id: assetsModel
2023-03-10 16:55:50 +01:00
2023-06-27 23:56:45 +02:00
sourceModel: root . model
filters: ValueFilter {
roleName: "tokenType"
value: Constants . TokenType . ERC20
}
}
2023-03-10 16:55:50 +01:00
2023-06-27 23:56:45 +02:00
SortFilterProxyModel {
id: collectiblesModel
2023-03-10 16:55:50 +01:00
2023-06-27 23:56:45 +02:00
sourceModel: root . model
filters: ValueFilter {
roleName: "tokenType"
value: Constants . TokenType . ERC721
}
}
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
Loader {
sourceComponent: root . count === 0 ? introComponent : mainLayoutComponent
}
Component {
id: introComponent
2023-07-06 14:33:27 +02:00
ColumnLayout {
width: root . viewWidth
spacing: 20
IntroPanel {
Layout.fillWidth: true
2023-06-27 23:56:45 +02:00
2023-07-06 14:33:27 +02:00
image: Style . png ( "community/mint2_1" )
title: qsTr ( "Community tokens" )
subtitle: qsTr ( "You can mint custom tokens and import tokens for your community" )
checkersModel: [
qsTr ( "Create remotely destructible soulbound tokens for admin permissions" ) ,
qsTr ( "Reward individual members with custom tokens for their contribution" ) ,
qsTr ( "Mint tokens for use with community and channel permissions" )
]
}
StatusInfoBoxPanel {
2023-07-12 16:06:07 +02:00
readonly property bool isAdminOnly: root . isAdmin && ! root . isOwner
2023-07-06 14:33:27 +02:00
Layout.fillWidth: true
Layout.bottomMargin: 20
title: qsTr ( "Get started" )
2023-07-12 16:06:07 +02:00
text: isAdminOnly ? qsTr ( "Token minting can only be performed by admins that hodl the Community’ s TokenMaster token. If you would like this permission, contact the Community founder (they will need to mint the Community Owner token before they can airdrop this to you)." ) :
qsTr ( "In order to Mint, Import and Airdrop community tokens, you first need to mint your Owner token which will give you permissions to access the token management features for your community." )
2023-07-06 14:33:27 +02:00
buttonText: qsTr ( "Mint Owner token" )
2023-07-12 16:06:07 +02:00
buttonVisible: root . isOwner
2023-07-06 14:33:27 +02:00
horizontalPadding: 16
verticalPadding: 20
onClicked: root . mintOwnerTokenClicked ( )
}
2023-05-25 16:45:46 +02:00
}
2023-06-27 23:56:45 +02:00
}
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
Component {
id: mainLayoutComponent
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
ColumnLayout {
id: mainLayout
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
width: root . viewWidth
spacing: Style . current . halfPadding
StatusBaseText {
Layout.leftMargin: Style . current . padding
text: qsTr ( "Assets" )
font.pixelSize: Theme . primaryTextFontSize
color: Theme . palette . baseColor1
2023-05-25 16:45:46 +02:00
}
2023-06-27 23:56:45 +02:00
StatusListView {
id: assetsList
Layout.fillWidth: true
2023-08-10 14:23:59 +02:00
Layout.preferredHeight: contentHeight
2023-06-27 23:56:45 +02:00
visible: count > 0
model: assetsModel
delegate: StatusListItem {
height: 64
width: mainLayout . width
title: model . name
subTitle: model . symbol
asset.name: model . image ? model.image : ""
asset.isImage: true
components: [
StatusBaseText {
anchors.verticalCenter: parent . verticalCenter
2023-07-18 19:34:57 +02:00
text: d . getDeployStateInfo ( model . deployState )
2023-06-27 23:56:45 +02:00
color: model . deployState === Constants . ContractTransactionStatus . Failed
? Theme.palette.dangerColor1 : Theme . palette . baseColor1
font.pixelSize: 13
} ,
StatusIcon {
anchors.verticalCenter: parent . verticalCenter
icon: "next"
color: Theme . palette . baseColor1
}
]
onClicked: root . itemClicked ( model . contractUniqueKey ,
model . chainId , model . chainName ,
model . accountName , model . address )
}
2023-05-25 16:45:46 +02:00
}
2023-06-27 23:56:45 +02:00
// Empty placeholder when no assets; dashed rounded rectangle
ShapeRectangle {
Layout.alignment: Qt . AlignHCenter
Layout.preferredWidth: parent . width - 4 // The rectangular path is rendered outside
Layout.preferredHeight: 44
visible: assetsList . count === 0
text: qsTr ( "You currently have no minted assets" )
}
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
StatusBaseText {
Layout.leftMargin: Style . current . padding
Layout.topMargin: Style . current . halfPadding
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
text: qsTr ( "Collectibles" )
font.pixelSize: Theme . primaryTextFontSize
color: Theme . palette . baseColor1
}
2023-03-10 16:55:50 +01:00
2023-06-27 23:56:45 +02:00
StatusGridView {
id: collectiblesGrid
2023-03-10 16:55:50 +01:00
2023-06-27 23:56:45 +02:00
Layout.fillWidth: true
Layout.preferredHeight: childrenRect . height
2023-05-25 16:45:46 +02:00
2023-06-27 23:56:45 +02:00
visible: count > 0
model: SortFilterProxyModel {
sourceModel: root . model
filters: ValueFilter {
roleName: "tokenType"
value: Constants . TokenType . ERC721
}
}
cellHeight: 229
cellWidth: 176
leftMargin: 16
delegate: CollectibleView {
height: collectiblesGrid . cellHeight
width: collectiblesGrid . cellWidth
title: model . name ? model.name : "..."
2023-07-18 19:34:57 +02:00
subTitle: deployState === Constants . ContractTransactionStatus . Completed ?
2023-08-04 18:41:21 +02:00
d . getRemainingInfo ( model . privilegesLevel === Constants . TokenPrivilegesLevel . Owner ,
model . privilegesLevel === Constants . TokenPrivilegesLevel . TMaster ,
2023-07-18 19:34:57 +02:00
model . remainingSupply ,
model . supply ,
model . infiniteSupply ) :
d . getDeployStateInfo ( model . deployState )
2023-06-27 23:56:45 +02:00
subTitleColor: model . deployState === Constants . ContractTransactionStatus . Failed
? Theme.palette.dangerColor1 : Theme . palette . baseColor1
fallbackImageUrl: model . image ? model.image : ""
backgroundColor: "transparent"
isLoading: false
2023-07-18 19:34:57 +02:00
navigationIconVisible: false
2023-08-04 18:41:21 +02:00
privilegesLevel: model . privilegesLevel
2023-07-18 19:34:57 +02:00
ornamentColor: model . color
2023-06-27 23:56:45 +02:00
onClicked: root . itemClicked ( model . contractUniqueKey ,
model . chainId , model . chainName ,
model . accountName , model . address )
2023-05-25 16:45:46 +02:00
}
}
2023-06-27 23:56:45 +02:00
// Empty placeholder when no collectibles; dashed rounded rectangle
ShapeRectangle {
Layout.alignment: Qt . AlignHCenter
Layout.preferredWidth: parent . width - 4 // The rectangular path is rendered outside
Layout.preferredHeight: 44
visible: collectiblesGrid . count === 0
text: qsTr ( "You currently have no minted collectibles" )
}
2023-08-01 12:31:50 +02:00
// Retry button, only in case of Owner or TMaster tokens failure
StatusButton {
Layout.preferredWidth: 336
Layout.preferredHeight: 44
Layout.alignment: Qt . AlignLeft
Layout.leftMargin: 24
visible: root . anyPrivilegedTokenFailed
text: qsTr ( "Retry mint" )
onClicked: {
// Get owner token item:
const index = StatusQUtils . ModelUtils . indexOf ( root . model , "name" , PermissionsHelpers . ownerTokenNameTag + root . communityName )
if ( index === - 1 )
return console . warn ( "Trying to get Owner Token item but it's not part of the provided model." )
const token = StatusQUtils . ModelUtils . get ( root . model , index )
root . retryOwnerTokenClicked ( token . contractUniqueKey , token . chainId , token . accountName , token . accountAddress )
}
}
2023-05-25 16:45:46 +02:00
}
2023-03-10 16:55:50 +01:00
}
}