mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-22 20:40:18 +00:00
73b2ec2903
It enables navigation from mint token page to airdrop page selecting a specific collectible to be airdropped. It is now used `symbol` property as the identifier for a collectible but will be needed to update it to `key` once this key property is build in backend by hash(chainId + contractAddress). Closes #10047
116 lines
3.5 KiB
QML
116 lines
3.5 KiB
QML
import QtQuick 2.14
|
|
import QtQuick.Controls 2.14
|
|
import QtQuick.Layouts 1.14
|
|
|
|
import StatusQ.Controls 0.1
|
|
import StatusQ.Core.Utils 0.1
|
|
|
|
import AppLayouts.Chat.layouts 1.0
|
|
import AppLayouts.Chat.views.communities 1.0
|
|
|
|
import utils 1.0
|
|
|
|
SettingsPageLayout {
|
|
id: root
|
|
|
|
// Token models:
|
|
required property var assetsModel
|
|
required property var collectiblesModel
|
|
|
|
property int viewWidth: 560 // by design
|
|
|
|
signal airdropClicked(var airdropTokens, var addresses)
|
|
signal navigateToMintTokenSettings
|
|
|
|
|
|
function navigateBack() {
|
|
stackManager.pop(StackView.Immediate)
|
|
}
|
|
|
|
function selectCollectible(key, amount) {
|
|
d.selectCollectible(key, amount)
|
|
}
|
|
|
|
QtObject {
|
|
id: d
|
|
|
|
readonly property string welcomeViewState: "WELCOME"
|
|
readonly property string newAirdropViewState: "NEW_AIRDROP"
|
|
|
|
readonly property string welcomePageTitle: qsTr("Airdrops")
|
|
readonly property string newAirdropViewPageTitle: qsTr("New airdrop")
|
|
|
|
signal selectCollectible(string key, int amount)
|
|
}
|
|
|
|
content: StackView {
|
|
anchors.fill: parent
|
|
initialItem: welcomeView
|
|
|
|
Component.onCompleted: stackManager.pushInitialState(d.welcomeViewState)
|
|
}
|
|
|
|
state: stackManager.currentState
|
|
states: [
|
|
State {
|
|
name: d.welcomeViewState
|
|
PropertyChanges {target: root; title: d.welcomePageTitle}
|
|
PropertyChanges {target: root; previousPageName: ""}
|
|
PropertyChanges {target: root; headerButtonVisible: true}
|
|
PropertyChanges {target: root; headerButtonText: qsTr("New Airdrop")}
|
|
PropertyChanges {target: root; headerWidth: root.viewWidth}
|
|
},
|
|
State {
|
|
name: d.newAirdropViewState
|
|
PropertyChanges {target: root; title: d.newAirdropViewPageTitle}
|
|
PropertyChanges {target: root; previousPageName: d.welcomePageTitle}
|
|
PropertyChanges {target: root; headerButtonVisible: false}
|
|
PropertyChanges {target: root; headerWidth: 0}
|
|
}
|
|
]
|
|
|
|
onHeaderButtonClicked: stackManager.push(d.newAirdropViewState, newAirdropView, null, StackView.Immediate)
|
|
|
|
StackViewStates {
|
|
id: stackManager
|
|
|
|
stackView: root.contentItem
|
|
}
|
|
|
|
// Mint tokens possible view contents:
|
|
Component {
|
|
id: welcomeView
|
|
|
|
CommunityWelcomeSettingsView {
|
|
viewWidth: root.viewWidth
|
|
image: Style.png("community/airdrops8_1")
|
|
title: qsTr("Airdrop community tokens")
|
|
subtitle: qsTr("You can mint custom tokens and collectibles for your community")
|
|
checkersModel: [
|
|
qsTr("Reward individual members with custom tokens for their contribution"),
|
|
qsTr("Incentivise joining, retention, moderation and desired behaviour"),
|
|
qsTr("Require holding a token or NFT to obtain exclusive membership rights")
|
|
]
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: newAirdropView
|
|
|
|
CommunityNewAirdropView {
|
|
id: view
|
|
|
|
assetsModel: root.assetsModel
|
|
collectiblesModel: root.collectiblesModel
|
|
|
|
onAirdropClicked: {
|
|
root.airdropClicked(airdropTokens, addresses)
|
|
stackManager.clear(d.welcomeViewState, StackView.Immediate)
|
|
}
|
|
onNavigateToMintTokenSettings: root.navigateToMintTokenSettings()
|
|
|
|
Component.onCompleted: d.selectCollectible.connect(view.selectCollectible)
|
|
}
|
|
}
|
|
}
|