2020-08-04 18:22:51 -04:00
import QtQuick 2.14
import QtQuick . Layouts 1.3
import QtQuick . Controls 2.14
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-02-05 17:44:49 +01:00
import AppLayouts . Wallet . stores 1.0
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
2022-01-17 09:56:44 +01:00
property var ensUsernamesStore
property var contactsStore
2023-11-28 20:16:18 +01:00
required property TransactionStore transactionStore
2024-02-05 17:44:49 +01:00
property WalletAssetsStore walletAssetsStore
2022-01-17 09:56:44 +01:00
property string username: ""
2021-12-22 14:41:39 +01:00
2020-08-26 17:13:26 -04:00
signal backBtnClicked ( ) ;
2020-08-27 12:06:53 -04:00
signal usernameRegistered ( userName: string ) ;
2020-08-26 17:13:26 -04:00
2024-02-05 17:44:49 +01:00
QtObject {
id: d
readonly property var sntToken: ModelUtils . getByKey ( root . walletAssetsStore . groupedAccountAssetsModel , "tokensKey" , root . ensUsernamesStore . getStatusTokenKey ( ) )
readonly property SumAggregator aggregator: SumAggregator {
model: ! ! d . sntToken && ! ! d . sntToken . balances ? d.sntToken.balances: nil
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
2020-08-04 18:22:51 -04:00
}
2020-11-03 21:29:56 +11:00
Loader {
2020-08-27 12:06:53 -04:00
id: transactionDialog
2020-11-03 21:29:56 +11:00
function open ( ) {
this . active = true
this . item . open ( )
}
function closed ( ) {
this . active = false // kill an opened instance
}
2022-10-17 12:17:25 +02:00
sourceComponent: SendModal {
id: buyEnsModal
interactive: false
2023-11-28 20:16:18 +01:00
store: root . transactionStore
2023-09-20 18:07:09 +02:00
preSelectedSendType: Constants . SendType . ENSRegister
2022-10-17 12:17:25 +02:00
preSelectedRecipient: root . ensUsernamesStore . getEnsRegisteredAddress ( )
preDefinedAmountToSend: LocaleUtils . numberToLocaleString ( 10 )
2024-02-05 17:44:49 +01:00
preSelectedHoldingID: ! ! d . sntToken && ! ! d . sntToken . symbol ? d.sntToken.symbol: ""
2023-11-07 23:45:47 +01:00
preSelectedHoldingType: Constants . TokenType . ERC20
2022-10-17 12:17:25 +02:00
sendTransaction: function ( ) {
2023-08-15 20:21:51 +02:00
if ( bestRoutes . count === 1 ) {
let path = bestRoutes . firstItem ( )
2022-10-17 12:17:25 +02:00
let eip1559Enabled = path . gasFees . eip1559Enabled
2022-11-30 13:59:21 +01:00
let maxFeePerGas = path . gasFees . maxFeePerGasM
2022-10-17 12:17:25 +02:00
root . ensUsernamesStore . authenticateAndRegisterEns (
2023-01-11 19:10:13 +03:00
root . ensUsernamesStore . chainId ,
2022-10-17 12:17:25 +02:00
username ,
2023-09-20 18:07:09 +02:00
store . selectedSenderAccount . address ,
2022-10-17 12:17:25 +02:00
path . gasAmount ,
eip1559Enabled ? "" : path . gasFees . gasPrice ,
eip1559Enabled ? path.gasFees.maxPriorityFeePerGas : "" ,
eip1559Enabled ? maxFeePerGas: path . gasFees . gasPrice ,
eip1559Enabled ,
)
}
2021-07-27 10:04:05 -04:00
}
2022-10-17 12:17:25 +02:00
Connections {
target: root . ensUsernamesStore . ensUsernamesModule
2023-08-15 20:21:51 +02:00
function onTransactionWasSent ( chainId: int , txHash: string , error: string ) {
if ( ! ! error ) {
if ( error . includes ( Constants . walletSection . cancelledMessage ) ) {
2022-10-17 12:17:25 +02:00
return
}
2023-08-15 20:21:51 +02:00
buyEnsModal . sendingError . text = error
2022-10-17 12:17:25 +02:00
return buyEnsModal . sendingError . open ( )
}
2022-12-08 16:56:02 +01:00
usernameRegistered ( username )
2023-08-15 20:21:51 +02:00
let url = "%1/%2" . arg ( buyEnsModal . store . getEtherscanLink ( chainId ) ) . arg ( txHash )
2022-12-08 16:56:02 +01:00
Global . displayToastMessage ( qsTr ( "Transaction pending..." ) ,
qsTr ( "View on etherscan" ) ,
"" ,
true ,
Constants . ephemeralNotificationType . normal ,
url )
2022-10-17 12:17:25 +02:00
}
2020-11-03 21:29:56 +11:00
}
}
2020-08-27 12:06:53 -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 {
spacing: Style . current . 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
2022-09-15 17:23:51 +02:00
font.family: Style . current . 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 {
2022-04-04 13:26:30 +02:00
text: qsTr ( "<a href='%1%2'>Look up on Etherscan</a>" )
2022-01-17 09:56:44 +01:00
. arg ( root . ensUsernamesStore . getEtherscanLink ( ) )
. 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
2022-09-15 17:23:51 +02:00
font.family: Style . current . 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 {
2022-04-04 13:26:30 +02:00
text: qsTr ( "<a href='%1%2'>Look up on Etherscan</a>" )
2022-01-17 09:56:44 +01:00
. arg ( root . ensUsernamesStore . getEtherscanLink ( ) )
. 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
anchors.topMargin: Style . current . padding
anchors.bottom: startBtn . top
anchors.bottomMargin: Style . current . padding
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
color: Style . current . blue
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
color: Style . current . white
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: {
2022-01-17 09:56:44 +01:00
root . ensUsernamesStore . copyToClipboard ( 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: {
2022-01-17 09:56:44 +01:00
root . ensUsernamesStore . copyToClipboard ( root . ensUsernamesStore . pubkey )
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
anchors.topMargin: Style . current . padding
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
2022-07-21 18:00:49 +02:00
anchors.leftMargin: Style . current . 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
anchors.bottomMargin: Style . current . padding
anchors.left: parent . left
anchors.leftMargin: Style . current . 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
anchors.rightMargin: Style . current . padding
width: childrenRect . width
Image {
id: image1
height: 50
2021-07-02 11:55:31 +03:00
width: height
2022-01-17 09:56:44 +01:00
source: Style . 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
anchors.bottomMargin: Style . current . padding
2020-08-26 17:13:26 -04:00
anchors.right: parent . right
anchors.rightMargin: Style . current . 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
2022-04-21 12:50:01 +02:00
onClicked: transactionDialog . open ( )
2020-08-04 18:22:51 -04:00
}
2020-09-14 14:12:47 +02:00
}