2024-10-15 21:26:12 +02:00
import QtQuick 2.15
import QtQuick . Layouts 1.15
import QtQuick . Controls 2.15
2021-09-28 18:04:06 +03:00
import utils 1.0
2021-10-25 16:33:41 +02:00
2021-10-28 00:27:49 +03:00
import shared . popups 1.0
import shared . status 1.0
2023-09-05 17:27:30 +02:00
import shared . popups . send 1.0
2023-11-28 20:16:18 +01:00
import shared . stores . send 1.0
2021-10-06 11:16:39 +02:00
2024-02-05 17:44:49 +01:00
import StatusQ 0.1
2021-10-06 11:16:39 +02:00
import StatusQ . Core 0.1
import StatusQ . Core . Theme 0.1
2024-02-05 17:44:49 +01:00
import StatusQ . Core . Utils 0.1
2021-10-06 11:16:39 +02:00
import StatusQ . Controls 0.1
import StatusQ . Components 0.1
2020-08-04 18:22:51 -04:00
2024-05-22 11:13:39 +03:00
import AppLayouts . Profile . stores 1.0
2024-02-05 17:44:49 +01:00
2020-08-04 18:22:51 -04:00
Item {
2021-10-06 11:16:39 +02:00
id: root
2020-08-26 17:13:26 -04:00
2024-05-22 11:13:39 +03:00
property EnsUsernamesStore ensUsernamesStore
2022-01-17 09:56:44 +01:00
property string username: ""
2021-12-22 14:41:39 +01:00
2024-11-05 19:51:17 +01:00
required property var assetsModel
2024-05-22 11:13:39 +03:00
signal backBtnClicked ( )
2024-10-03 15:14:27 +02:00
signal registerUsername ( )
2024-02-05 17:44:49 +01:00
2024-11-05 19:51:17 +01:00
QtObject {
id: d
readonly property var sntToken: statusTokenEntry . item
readonly property SumAggregator aggregator: SumAggregator {
model: ! ! d . sntToken && ! ! d . sntToken . balances ? d.sntToken.balances: null
roleName: "balance"
}
property real sntBalance: ! ! sntToken && ! ! sntToken . decimals ? aggregator . value / ( 10 * * sntToken . decimals ) : 0
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2020-08-04 18:22:51 -04:00
id: sectionTitle
2022-04-04 13:26:30 +02:00
text: qsTr ( "ENS usernames" )
2020-08-04 18:22:51 -04:00
anchors.left: parent . left
anchors.leftMargin: 24
anchors.top: parent . top
anchors.topMargin: 24
font.weight: Font . Bold
font.pixelSize: 20
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2024-07-18 16:10:24 -04:00
StatusBetaTag {
anchors.verticalCenter: parent . verticalCenter
anchors.left: parent . right
anchors.leftMargin: 7
}
2020-08-04 18:22:51 -04:00
}
2021-10-06 11:16:39 +02:00
// TODO: Replace with StatusModal
2020-08-26 17:13:26 -04:00
ModalPopup {
id: popup
2022-04-04 13:26:30 +02:00
title: qsTr ( "Terms of name registration" )
2020-08-26 17:13:26 -04:00
2022-07-13 15:29:38 +03:00
StatusScrollView {
2022-07-20 17:54:30 +03:00
id: scroll
2023-05-31 23:58:23 +03:00
anchors.fill: parent
contentWidth: availableWidth
2020-08-26 17:13:26 -04:00
Column {
2024-10-15 21:26:12 +02:00
spacing: Theme . halfPadding
2022-07-20 17:54:30 +03:00
width: scroll . availableWidth
2022-02-09 10:43:23 +01:00
2020-08-26 17:13:26 -04:00
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "Funds are deposited for 1 year. Your SNT will be locked, but not spent." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "After 1 year, you can release the name and get your deposit back, or take no action to keep the name." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "If terms of the contract change — e.g. Status makes contract upgrades — user has the right to release the username regardless of time held." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "The contract controller cannot access your deposited funds. They can only be moved back to the address that sent them." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "Your address(es) will be publicly associated with your ENS name." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "Usernames are created as subdomain nodes of stateofus.eth and are subject to the ENS smart contract terms." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "You authorize the contract to transfer SNT on your behalf. This can only occur when you approve a transaction to authorize the transfer." )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "These terms are guaranteed by the smart contract logic at addresses:" )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
font.weight: Font . Bold
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "%1 (Status UsernameRegistrar)." ) . arg ( root . ensUsernamesStore . getEnsRegisteredAddress ( ) )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
font.family: Theme . monoFont . name
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2024-10-30 09:14:52 +01:00
text: qsTr ( "<a href='%1/%2'>Look up on Etherscan</a>" )
. arg ( root . ensUsernamesStore . getEtherscanAddressLink ( ) )
2022-01-17 09:56:44 +01:00
. arg ( root . ensUsernamesStore . getEnsRegisteredAddress ( ) )
2020-08-26 17:13:26 -04:00
anchors.left: parent . left
anchors.right: parent . right
2021-12-06 23:10:54 +02:00
onLinkActivated: Global . openLink ( link )
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
MouseArea {
anchors.fill: parent
acceptedButtons: Qt . NoButton // we don't want to eat clicks on the Text
cursorShape: parent . hoveredLink ? Qt.PointingHandCursor : Qt . ArrowCursor
}
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "%1 (ENS Registry)." ) . arg ( root . ensUsernamesStore . getEnsRegistry ( ) )
2020-08-26 17:13:26 -04:00
wrapMode: Text . WordWrap
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
font.family: Theme . monoFont . name
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2024-10-30 09:14:52 +01:00
text: qsTr ( "<a href='%1/%2'>Look up on Etherscan</a>" )
. arg ( root . ensUsernamesStore . getEtherscanAddressLink ( ) )
2022-01-17 09:56:44 +01:00
. arg ( root . ensUsernamesStore . getEnsRegistry ( ) )
2020-08-26 17:13:26 -04:00
anchors.left: parent . left
anchors.right: parent . right
2021-12-06 23:10:54 +02:00
onLinkActivated: Global . openLink ( link )
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
MouseArea {
anchors.fill: parent
acceptedButtons: Qt . NoButton // we don't want to eat clicks on the Text
cursorShape: parent . hoveredLink ? Qt.PointingHandCursor : Qt . ArrowCursor
}
}
}
}
}
2022-07-13 15:29:38 +03:00
StatusScrollView {
2020-08-04 18:22:51 -04:00
id: sview
anchors.top: sectionTitle . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . padding
2020-08-04 18:22:51 -04:00
anchors.bottom: startBtn . top
2024-10-15 21:26:12 +02:00
anchors.bottomMargin: Theme . padding
2020-08-04 18:22:51 -04:00
anchors.left: parent . left
anchors.right: parent . right
2023-05-31 23:58:23 +03:00
contentWidth: availableWidth
2020-08-04 18:22:51 -04:00
Item {
id: contentItem
2022-07-20 17:54:30 +03:00
width: sview . availableWidth
2020-08-04 18:22:51 -04:00
2020-08-26 17:13:26 -04:00
Rectangle {
id: circleAt
2020-08-04 18:22:51 -04:00
anchors.top: parent . top
anchors.topMargin: 24
2020-08-26 17:13:26 -04:00
anchors.horizontalCenter: parent . horizontalCenter
width: 60
height: 60
radius: 120
2024-10-15 21:26:12 +02:00
color: Theme . palette . primaryColor1
2020-08-26 17:13:26 -04:00
2021-10-06 11:16:39 +02:00
StatusBaseText {
2020-08-26 17:13:26 -04:00
text: "@"
opacity: 0.7
font.weight: Font . Bold
font.pixelSize: 18
2024-10-15 21:26:12 +02:00
color: Theme . palette . white
2020-08-26 17:13:26 -04:00
anchors.horizontalCenter: parent . horizontalCenter
anchors.verticalCenter: parent . verticalCenter
}
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2020-08-26 17:13:26 -04:00
id: ensUsername
text: username + ".stateofus.eth"
2020-08-04 18:22:51 -04:00
font.weight: Font . Bold
2020-08-26 17:13:26 -04:00
font.pixelSize: 18
anchors.top: circleAt . bottom
anchors.topMargin: 24
2020-08-04 18:22:51 -04:00
anchors.left: parent . left
anchors.right: parent . right
horizontalAlignment: Text . AlignHCenter
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
}
2021-10-06 11:16:39 +02:00
StatusDescriptionListItem {
2020-08-26 17:13:26 -04:00
id: walletAddressLbl
2022-04-04 13:26:30 +02:00
title: qsTr ( "Wallet address" )
2022-01-17 09:56:44 +01:00
subTitle: root . ensUsernamesStore . getWalletDefaultAddress ( )
2021-10-06 11:16:39 +02:00
tooltip.text: qsTr ( "Copied to clipboard!" )
2022-08-11 14:55:08 +03:00
asset.name: "copy"
2021-10-06 11:16:39 +02:00
iconButton.onClicked: {
2024-08-27 16:35:52 +02:00
ClipboardUtils . setText ( subTitle )
2021-10-06 11:16:39 +02:00
tooltip . visible = ! tooltip . visible
}
2020-08-26 17:13:26 -04:00
anchors.top: ensUsername . bottom
anchors.topMargin: 24
}
2021-10-06 11:16:39 +02:00
StatusDescriptionListItem {
2020-08-26 17:13:26 -04:00
id: keyLbl
2022-04-04 13:26:30 +02:00
title: qsTr ( "Key" )
2021-10-06 11:16:39 +02:00
subTitle: {
2022-01-17 09:56:44 +01:00
let pubKey = root . ensUsernamesStore . pubkey ;
2020-08-26 17:13:26 -04:00
return pubKey . substring ( 0 , 20 ) + "..." + pubKey . substring ( pubKey . length - 20 ) ;
}
2021-10-06 11:16:39 +02:00
tooltip.text: qsTr ( "Copied to clipboard!" )
2022-08-11 14:55:08 +03:00
asset.name: "copy"
2021-10-06 11:16:39 +02:00
iconButton.onClicked: {
2024-08-27 16:35:52 +02:00
ClipboardUtils . setText ( subTitle )
2021-10-06 11:16:39 +02:00
tooltip . visible = ! tooltip . visible
}
2020-08-26 17:13:26 -04:00
anchors.top: walletAddressLbl . bottom
anchors.topMargin: 24
}
2020-11-27 15:32:49 -04:00
StatusCheckBox {
2020-08-26 17:13:26 -04:00
id: termsAndConditionsCheckbox
2022-08-09 15:52:17 +02:00
objectName: "ensAgreeTerms"
2020-08-26 17:13:26 -04:00
anchors.top: keyLbl . bottom
2024-10-15 21:26:12 +02:00
anchors.topMargin: Theme . padding
2020-08-26 17:13:26 -04:00
anchors.left: parent . left
anchors.leftMargin: 24
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "Agree to <a href=\"#\">Terms of name registration.</a> I understand that my wallet address will be publicly connected to my username." )
2020-08-26 17:13:26 -04:00
anchors.left: termsAndConditionsCheckbox . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . halfPadding
2020-08-26 17:13:26 -04:00
anchors.right: parent . right
2020-08-04 18:22:51 -04:00
wrapMode: Text . WordWrap
2022-07-21 18:00:49 +02:00
anchors.verticalCenter: termsAndConditionsCheckbox . verticalCenter
2020-08-26 17:13:26 -04:00
onLinkActivated: popup . open ( )
2021-11-01 10:42:00 +01:00
color: Theme . palette . directColor1
2022-07-21 18:00:49 +02:00
TapHandler {
enabled: ! parent . hoveredLink
onSingleTapped: termsAndConditionsCheckbox . toggle ( )
}
2020-08-26 17:13:26 -04:00
MouseArea {
anchors.fill: parent
acceptedButtons: Qt . NoButton // we don't want to eat clicks on the Text
cursorShape: parent . hoveredLink ? Qt.PointingHandCursor : Qt . ArrowCursor
}
2020-08-04 18:22:51 -04:00
}
}
}
2020-09-29 10:51:16 +02:00
StatusButton {
2020-08-26 17:13:26 -04:00
anchors.bottom: parent . bottom
2024-10-15 21:26:12 +02:00
anchors.bottomMargin: Theme . padding
2020-08-26 17:13:26 -04:00
anchors.left: parent . left
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
2022-04-04 13:26:30 +02:00
text: qsTr ( "Back" )
2020-08-26 17:13:26 -04:00
onClicked: backBtnClicked ( )
}
Item {
anchors.top: startBtn . top
anchors.right: startBtn . left
2024-10-15 21:26:12 +02:00
anchors.rightMargin: Theme . padding
2020-08-26 17:13:26 -04:00
width: childrenRect . width
Image {
id: image1
height: 50
2021-07-02 11:55:31 +03:00
width: height
2024-10-15 21:26:12 +02:00
source: Theme . png ( "tokens/SNT" )
2021-07-02 11:55:31 +03:00
sourceSize: Qt . size ( width , height )
2023-04-26 17:33:24 +02:00
cache: false
2020-08-26 17:13:26 -04:00
}
2022-02-09 10:43:23 +01:00
2021-10-06 11:16:39 +02:00
StatusBaseText {
2020-08-26 17:13:26 -04:00
id: ensPriceLbl
2022-04-04 13:26:30 +02:00
text: qsTr ( "10 SNT" )
2020-08-26 17:13:26 -04:00
anchors.left: image1 . right
anchors.leftMargin: 5
anchors.top: image1 . top
2021-10-06 11:16:39 +02:00
color: Theme . palette . directColor1
2020-08-26 17:13:26 -04:00
font.pixelSize: 14
}
2021-10-06 11:16:39 +02:00
StatusBaseText {
2022-04-04 13:26:30 +02:00
text: qsTr ( "Deposit" )
2020-08-26 17:13:26 -04:00
anchors.left: image1 . right
anchors.leftMargin: 5
anchors.topMargin: 5
anchors.top: ensPriceLbl . bottom
2021-11-01 10:42:00 +01:00
color: Theme . palette . baseColor1
2020-08-26 17:13:26 -04:00
font.pixelSize: 14
}
}
2020-09-29 10:51:16 +02:00
StatusButton {
2020-08-04 18:22:51 -04:00
id: startBtn
2022-08-09 15:52:17 +02:00
objectName: "ensStartTransaction"
2020-08-04 18:22:51 -04:00
anchors.bottom: parent . bottom
2024-10-15 21:26:12 +02:00
anchors.bottomMargin: Theme . padding
2020-08-26 17:13:26 -04:00
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.rightMargin: Theme . padding
2024-02-05 17:44:49 +01:00
text: d . sntBalance < 10 ?
2022-04-04 13:26:30 +02:00
qsTr ( "Not enough SNT" ) :
qsTr ( "Register" )
2024-02-05 17:44:49 +01:00
enabled: d . sntBalance >= 10 && termsAndConditionsCheckbox . checked
2024-10-03 15:14:27 +02:00
onClicked: root . registerUsername ( root . username )
2020-08-04 18:22:51 -04:00
}
2024-11-05 19:51:17 +01:00
ModelEntry {
id: statusTokenEntry
sourceModel: root . assetsModel
key: "tokensKey"
value: root . ensUsernamesStore . getStatusTokenKey ( )
}
2020-09-14 14:12:47 +02:00
}