2023-09-25 17:03:35 +02:00
import QtQuick 2.15
import QtQuick . Controls 2.15
import QtQml . Models 2.15
import QtQuick . Layouts 1.15
import StatusQ . Core 0.1
import StatusQ . Controls 0.1
import StatusQ . Popups . Dialog 0.1
import StatusQ . Components 0.1
import StatusQ . Core . Theme 0.1
import StatusQ . Core . Utils 0.1
import AppLayouts . Communities . panels 1.0
import utils 1.0
StatusDialog {
id: root
// Community related props:
required property string communityName
required property string communityLogo
required property string communityColor
// Owner token related props:
required property string tokenSymbol
required property string tokenChainName
// Fees calculation props:
property string feeText
property string feeErrorText
property bool isFeeLoading
property string feeLabel: qsTr ( "Update %1 Community smart contract on %2" ) . arg ( root . communityName ) . arg ( root . tokenChainName )
// Account expected roles: address, name, color, emoji, walletType
property var accounts
signal finaliseOwnershipClicked
signal rejectClicked
signal visitCommunityClicked
signal openControlNodeDocClicked ( string link )
QtObject {
id: d
2023-09-28 12:09:47 +02:00
readonly property string controlNodeLink: Constants . statusHelpLinkPrefix + "status-communities/about-the-control-node-in-status-communities/"
2023-09-25 17:03:35 +02:00
readonly property int init: 0
readonly property int finalise: 1
property bool ackCheck: false
// Fees related props:
2024-06-07 15:27:56 +03:00
// TODO: These properties are not used in the current implementation!
// Check if the current fees box in this popup is needed!!
2023-09-25 17:03:35 +02:00
property string accountAddress: ""
property string accountName: ""
}
width: 640 // by design
padding: 0
component CustomText : StatusBaseText {
Layout.fillWidth: true
wrapMode: Text . WrapAtWordBoundaryOrAnywhere
lineHeight: 1.2
}
contentItem: StatusScrollView {
id: scrollView
contentWidth: availableWidth
contentHeight: loader . item . height
2024-10-15 21:26:12 +02:00
padding: Theme . padding
2023-09-25 17:03:35 +02:00
Loader {
id: loader
width: scrollView . availableWidth
sourceComponent: initialPanel
state: d . init
states: [
State {
name: d . init
PropertyChanges { target: loader ; sourceComponent: initialPanel }
PropertyChanges {
target: acceptBtn
text: qsTr ( "Finalise %1 ownership" ) . arg ( root . communityName )
enabled: true
onClicked: loader . state = d . finalise
}
PropertyChanges {
target: rejectBtn
visible: true
onClicked: root . rejectClicked ( )
}
PropertyChanges { target: backButton ; visible: false }
} ,
State {
name: d . finalise
PropertyChanges { target: loader ; sourceComponent: finalisePanel }
PropertyChanges {
target: acceptBtn
text: qsTr ( "Make this device the control node and update smart contract" )
enabled: d . ackCheck && ! root . isFeeLoading && root . feeErrorText === ""
2023-10-23 13:36:33 +02:00
onClicked: root . finaliseOwnershipClicked ( )
2023-09-25 17:03:35 +02:00
}
PropertyChanges { target: rejectBtn ; visible: false }
PropertyChanges {
target: backButton
visible: true
onClicked: loader . state = d . init
}
}
]
}
}
header: StatusDialogHeader {
headline.title: qsTr ( "Finalise %1 ownership" ) . arg ( root . communityName )
actions.closeButton.onClicked: root . close ( )
leftComponent: StatusSmartIdenticon {
asset.name: root . communityLogo
asset.isImage: ! ! asset . name
}
}
footer: StatusDialogFooter {
2024-10-15 21:26:12 +02:00
spacing: Theme . padding
2024-02-08 17:59:53 +01:00
2023-09-25 17:03:35 +02:00
rightButtons: ObjectModel {
StatusFlatButton {
id: rejectBtn
text: qsTr ( "I don't want to be the owner" )
onClicked: {
root . rejectClicked ( )
close ( )
}
}
StatusButton {
id: acceptBtn
}
}
leftButtons: ObjectModel {
2024-02-08 17:59:53 +01:00
StatusBackButton {
id: backButton
Layout.minimumWidth: implicitWidth
}
2023-09-25 17:03:35 +02:00
}
}
Component {
id: initialPanel
ColumnLayout {
2024-10-15 21:26:12 +02:00
spacing: Theme . padding
2023-09-25 17:03:35 +02:00
CustomText {
text: qsTr ( "Congratulations! You have been sent the %1 Community Owner token." ) . arg ( root . communityName )
font.bold: true
}
CustomText {
textFormat: Text . RichText
2023-09-28 12:09:47 +02:00
text: qsTr ( "To finalise your ownership and assume ultimate admin rights for the %1 Community, you need to make your device the Community's <a style=\"color:%3;\" href=\"%2\">control node</a><a style=\"color:%3;text-decoration: none\" href=\"%2\">↗</a>. You will also need to sign a small transaction to update the %1 Community smart contract to make you the official signatory for all Community changes." ) . arg ( root . communityName ) . arg ( d . controlNodeLink ) . arg ( color )
2023-09-25 17:03:35 +02:00
onLinkActivated: root . openControlNodeDocClicked ( link )
}
PrivilegedTokenArtworkPanel {
id: tokenPanel
Layout.alignment: Qt . AlignHCenter
2024-10-15 21:26:12 +02:00
Layout.topMargin: Theme . padding
2023-09-25 17:03:35 +02:00
isOwner: true
artwork: root . communityLogo
color: root . communityColor
size: PrivilegedTokenArtworkPanel . Size . Large
}
Rectangle {
Layout.alignment: Qt . AlignHCenter
Layout.preferredWidth: tokenPanel . width
2024-10-15 21:26:12 +02:00
Layout.preferredHeight: boxContent . implicitHeight + Theme . padding
Layout.bottomMargin: Theme . padding
2023-09-25 17:03:35 +02:00
radius: 8
border.color: Theme . palette . baseColor2
2023-09-28 12:09:47 +02:00
color: "transparent"
2023-09-25 17:03:35 +02:00
ColumnLayout {
id: boxContent
anchors.verticalCenter: parent . verticalCenter
spacing: 2
StatusBaseText {
2024-10-15 21:26:12 +02:00
Layout.leftMargin: Theme . padding
2023-09-25 17:03:35 +02:00
text: qsTr ( "Symbol" )
elide: Text . ElideRight
2024-10-15 21:26:12 +02:00
font.pixelSize: Theme . additionalTextSize
2023-09-25 17:03:35 +02:00
color: Theme . palette . baseColor1
}
StatusBaseText {
2024-10-15 21:26:12 +02:00
Layout.leftMargin: Theme . padding
2023-09-25 17:03:35 +02:00
text: root . tokenSymbol
elide: Text . ElideRight
font.pixelSize: Theme . primaryTextFontSize
color: Theme . palette . directColor1
}
}
}
StatusListItem {
Layout.fillWidth: true
2024-10-15 21:26:12 +02:00
Layout.bottomMargin: Theme . padding
2023-09-25 17:03:35 +02:00
title: root . communityName
border.color: Theme . palette . baseColor2
asset.name: root . communityLogo
asset.isImage: true
asset.isLetterIdenticon: ! asset . name
components: [
RowLayout {
StatusIcon {
icon: "arrow-right"
color: Theme . palette . primaryColor1
}
StatusBaseText {
2024-10-15 21:26:12 +02:00
Layout.rightMargin: Theme . padding
2023-09-25 17:03:35 +02:00
text: qsTr ( "Visit Community" )
2024-10-15 21:26:12 +02:00
font.pixelSize: Theme . additionalTextSize
2023-09-25 17:03:35 +02:00
color: Theme . palette . primaryColor1
}
}
]
onClicked: {
close ( )
root . visitCommunityClicked ( )
}
}
}
}
Component {
id: finalisePanel
ColumnLayout {
2024-10-15 21:26:12 +02:00
spacing: Theme . padding
2023-09-25 17:03:35 +02:00
CustomText {
text: qsTr ( "Finalising your ownership of the %1 Community requires you to:" ) . arg ( root . communityName )
}
CustomText {
text: qsTr ( "1. Make this device the control node for the Community" )
font.bold: true
}
CustomText {
2024-10-15 21:26:12 +02:00
Layout.topMargin: - Theme . halfPadding
2023-09-25 17:03:35 +02:00
text: qsTr ( "It is vital to keep your device online and running Status in order for the Community to operate effectively. Login with this account via another synced desktop device if you think it might be better suited for this purpose." )
}
CustomText {
text: qsTr ( "2. Update the %1 Community smart contract" ) . arg ( root . communityName )
font.bold: true
}
CustomText {
2024-10-15 21:26:12 +02:00
Layout.topMargin: - Theme . halfPadding
2023-09-25 17:03:35 +02:00
text: qsTr ( "This transaction updates the %1 Community smart contract, making you the %1 Community owner." ) . arg ( root . communityName )
}
FeesBox {
2024-06-07 15:27:56 +03:00
id: feesBox
2023-09-25 17:03:35 +02:00
Layout.fillWidth: true
implicitWidth: 0
accountsSelector.model: root . accounts
accountErrorText: root . feeErrorText
accountSelectorText: qsTr ( "Gas fees will be paid from" )
model: QtObject {
id: singleFeeModel
readonly property string title: root . feeLabel
readonly property string feeText: root . isFeeLoading ? "" : root . feeText
readonly property bool error: root . feeErrorText !== ""
}
2024-06-07 15:27:56 +03:00
Binding {
target: d
property: "accountAddress"
value: feesBox . accountsSelector . currentAccountAddress
}
2023-09-25 17:03:35 +02:00
2024-06-07 15:27:56 +03:00
Binding {
target: d
property: "accountName"
value: feesBox . accountsSelector . currentAccount . name
2023-09-25 17:03:35 +02:00
}
}
StatusCheckBox {
2024-10-15 21:26:12 +02:00
Layout.topMargin: - Theme . halfPadding
2023-09-25 17:03:35 +02:00
Layout.fillWidth: true
checked: d . ackCheck
2024-10-15 21:26:12 +02:00
font.pixelSize: Theme . primaryTextFontSize
2023-09-25 17:03:35 +02:00
text: qsTr ( "I acknowledge that I must keep this device online and running Status as much of the time as possible for the %1 Community to operate effectively" ) . arg ( root . communityName )
onCheckStateChanged: d . ackCheck = checked
}
}
}
}