2020-08-06 15:45:57 -04:00
|
|
|
|
import QtQuick 2.14
|
|
|
|
|
import QtQuick.Layouts 1.3
|
|
|
|
|
import QtQuick.Controls 2.14
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
import StatusQ.Core 0.1
|
2021-11-01 10:42:00 +01:00
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2021-10-21 17:07:13 +02:00
|
|
|
|
import StatusQ.Controls 0.1 as StatusQControls
|
2021-10-06 11:16:39 +02:00
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
|
import shared.status 1.0
|
2020-08-06 15:45:57 -04:00
|
|
|
|
|
|
|
|
|
Item {
|
2021-10-06 11:16:39 +02:00
|
|
|
|
id: root
|
|
|
|
|
property var store
|
2022-01-04 13:06:05 +01:00
|
|
|
|
property var contactsStore
|
2020-08-06 15:45:57 -04:00
|
|
|
|
property string username: ""
|
|
|
|
|
property string walletAddress: "-"
|
|
|
|
|
property string key: "-"
|
2021-08-09 18:23:52 -04:00
|
|
|
|
property var expiration: 0
|
2020-08-06 15:45:57 -04:00
|
|
|
|
|
2020-08-07 12:27:41 -04:00
|
|
|
|
signal backBtnClicked();
|
2021-08-09 18:23:52 -04:00
|
|
|
|
signal usernameReleased(username: string);
|
2020-08-07 12:27:41 -04:00
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
StatusBaseText {
|
2020-08-06 15:45:57 -04:00
|
|
|
|
id: sectionTitle
|
|
|
|
|
text: username
|
|
|
|
|
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-06 15:45:57 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: loadingImageComponent
|
2021-04-26 12:25:01 +02:00
|
|
|
|
StatusLoadingIndicator {}
|
2020-08-06 15:45:57 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
|
id: loadingImg
|
|
|
|
|
active: false
|
|
|
|
|
sourceComponent: loadingImageComponent
|
|
|
|
|
anchors.right: parent.right
|
|
|
|
|
anchors.rightMargin: Style.current.padding
|
|
|
|
|
anchors.top: parent.top
|
|
|
|
|
anchors.topMargin: Style.currentPadding
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Connections {
|
2021-10-06 11:16:39 +02:00
|
|
|
|
target: root.store.ens
|
2020-08-06 15:45:57 -04:00
|
|
|
|
onDetailsObtained: {
|
|
|
|
|
if(username != ensName) return;
|
2021-10-06 11:16:39 +02:00
|
|
|
|
walletAddressLbl.subTitle = address;
|
|
|
|
|
keyLbl.subTitle = pubkey.substring(0, 20) + "..." + pubkey.substring(pubkey.length - 20);
|
2020-08-06 15:45:57 -04:00
|
|
|
|
walletAddressLbl.visible = true;
|
|
|
|
|
keyLbl.visible = true;
|
2021-08-09 18:23:52 -04:00
|
|
|
|
releaseBtn.visible = isStatus
|
2021-10-06 11:16:39 +02:00
|
|
|
|
releaseBtn.enabled = (Date.now() / 1000) > expirationTime && expirationTime > 0 && root.store.preferredUsername != username
|
2021-08-09 18:23:52 -04:00
|
|
|
|
expiration = new Date(expirationTime * 1000).getTime()
|
2020-08-06 15:45:57 -04:00
|
|
|
|
}
|
|
|
|
|
onLoading: {
|
|
|
|
|
loadingImg.active = isLoading
|
|
|
|
|
if(!isLoading) return;
|
|
|
|
|
walletAddressLbl.visible = false;
|
|
|
|
|
keyLbl.visible = false;
|
2021-08-09 18:23:52 -04:00
|
|
|
|
releaseBtn.visible = false;
|
|
|
|
|
expiration = 0;
|
2020-08-06 15:45:57 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
|
StatusDescriptionListItem {
|
2020-08-06 15:45:57 -04:00
|
|
|
|
id: walletAddressLbl
|
2021-10-06 11:16:39 +02:00
|
|
|
|
title: qsTr("Wallet address")
|
2020-08-06 15:45:57 -04:00
|
|
|
|
visible: false
|
|
|
|
|
anchors.top: sectionTitle.bottom
|
|
|
|
|
anchors.topMargin: 24
|
2021-10-06 11:16:39 +02:00
|
|
|
|
icon.name: "copy"
|
|
|
|
|
tooltip.text: qsTr("Copied to clipboard!")
|
|
|
|
|
iconButton.onClicked: {
|
|
|
|
|
root.store.copyToClipboard(subTitle)
|
|
|
|
|
tooltip.visible = !tooltip.visible
|
|
|
|
|
}
|
2020-08-06 15:45:57 -04:00
|
|
|
|
}
|
2021-10-06 11:16:39 +02:00
|
|
|
|
StatusDescriptionListItem {
|
2020-08-06 15:45:57 -04:00
|
|
|
|
id: keyLbl
|
2021-10-06 11:16:39 +02:00
|
|
|
|
title: qsTr("Key")
|
2020-08-06 15:45:57 -04:00
|
|
|
|
visible: false
|
|
|
|
|
anchors.top: walletAddressLbl.bottom
|
|
|
|
|
anchors.topMargin: 24
|
2021-10-06 11:16:39 +02:00
|
|
|
|
icon.name: "copy"
|
|
|
|
|
tooltip.text: qsTr("Copied to clipboard!")
|
|
|
|
|
iconButton.onClicked: {
|
|
|
|
|
root.store.copyToClipboard(subTitle)
|
|
|
|
|
tooltip.visible = !tooltip.visible
|
|
|
|
|
}
|
2020-08-06 15:45:57 -04:00
|
|
|
|
}
|
|
|
|
|
|
2021-08-09 18:23:52 -04:00
|
|
|
|
Component {
|
|
|
|
|
id: transactionDialogComponent
|
|
|
|
|
StatusETHTransactionModal {
|
2022-01-04 13:06:05 +01:00
|
|
|
|
contactsStore: root.contactsStore
|
2021-08-09 18:23:52 -04:00
|
|
|
|
onOpened: {
|
2021-10-06 11:16:39 +02:00
|
|
|
|
root.store.getGasPricePredictions()
|
2021-08-09 18:23:52 -04:00
|
|
|
|
}
|
|
|
|
|
title: qsTr("Connect username with your pubkey")
|
|
|
|
|
onClosed: {
|
|
|
|
|
destroy()
|
|
|
|
|
}
|
|
|
|
|
estimateGasFunction: function(selectedAccount) {
|
|
|
|
|
if (username === "" || !selectedAccount) return 100000;
|
2021-10-06 11:16:39 +02:00
|
|
|
|
return root.store.releaseEnsEstimate(Utils.removeStatusEns(username), selectedAccount.address)
|
2021-08-09 18:23:52 -04:00
|
|
|
|
}
|
|
|
|
|
onSendTransaction: function(selectedAddress, gasLimit, gasPrice, password) {
|
2021-10-06 11:16:39 +02:00
|
|
|
|
return root.store.releaseEns(username,
|
|
|
|
|
selectedAddress,
|
|
|
|
|
gasLimit,
|
|
|
|
|
gasPrice,
|
|
|
|
|
password)
|
2021-08-09 18:23:52 -04:00
|
|
|
|
}
|
|
|
|
|
onSuccess: function(){
|
|
|
|
|
usernameReleased(username);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
width: 475
|
|
|
|
|
height: 500
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-10-21 17:07:13 +02:00
|
|
|
|
StatusQControls.StatusButton {
|
2021-08-09 18:23:52 -04:00
|
|
|
|
id: releaseBtn
|
|
|
|
|
visible: false
|
|
|
|
|
enabled: false
|
|
|
|
|
anchors.top: keyLbl.bottom
|
|
|
|
|
anchors.topMargin: 24
|
|
|
|
|
anchors.left: parent.left
|
|
|
|
|
anchors.leftMargin: 24
|
|
|
|
|
text: qsTrId("Release username")
|
|
|
|
|
onClicked: {
|
2021-12-07 22:33:12 +02:00
|
|
|
|
Global.openPopup(transactionDialogComponent)
|
2021-08-09 18:23:52 -04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Text {
|
|
|
|
|
visible: releaseBtn.visible && !releaseBtn.enabled
|
|
|
|
|
anchors.top: releaseBtn.bottom
|
|
|
|
|
anchors.topMargin: 2
|
|
|
|
|
anchors.left: parent.left
|
|
|
|
|
anchors.leftMargin: 24
|
2021-08-10 13:40:10 -04:00
|
|
|
|
text: qsTr("Username locked. You won’t be able to release it until %1").arg(Utils.formatShortDateStr(new Date(expiration).toDateString()))
|
2021-08-09 18:23:52 -04:00
|
|
|
|
color: Style.current.darkGrey
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2021-10-21 17:07:13 +02:00
|
|
|
|
StatusQControls.StatusButton {
|
2020-08-06 15:45:57 -04:00
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
|
anchors.bottomMargin: Style.current.padding
|
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2020-08-26 11:52:26 -04:00
|
|
|
|
//% "Back"
|
2021-01-28 12:04:10 +01:00
|
|
|
|
text: qsTrId("back")
|
2020-08-07 12:27:41 -04:00
|
|
|
|
onClicked: backBtnClicked()
|
2020-08-06 15:45:57 -04:00
|
|
|
|
}
|
2020-09-14 14:12:47 +02:00
|
|
|
|
}
|