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
|
|
|
|
2024-07-12 11:46:43 +02:00
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1 as StatusQControls
|
2021-10-06 11:16:39 +02:00
|
|
|
import StatusQ.Core 0.1
|
2024-07-12 11:46:43 +02:00
|
|
|
import StatusQ.Core.Backpressure 0.1
|
2021-10-06 11:16:39 +02:00
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.status 1.0
|
|
|
|
import shared.controls 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
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2024-05-22 11:13:39 +03:00
|
|
|
import AppLayouts.Profile.stores 1.0
|
|
|
|
|
2020-08-03 16:46:37 -04:00
|
|
|
Item {
|
2021-10-06 11:16:39 +02:00
|
|
|
id: root
|
|
|
|
|
2024-05-22 11:13:39 +03:00
|
|
|
property EnsUsernamesStore ensUsernamesStore
|
2021-12-09 14:28:02 +01:00
|
|
|
property int profileContentWidth
|
2020-08-04 18:22:51 -04:00
|
|
|
|
2024-10-03 15:14:27 +02:00
|
|
|
signal connectUsername(string username)
|
2020-08-07 12:27:41 -04:00
|
|
|
signal continueClicked(string output, string username)
|
2020-08-04 18:22:51 -04:00
|
|
|
|
2020-08-03 16:46:37 -04:00
|
|
|
property string validationMessage: ""
|
|
|
|
property bool valid: false
|
|
|
|
property bool isStatus: true
|
2020-08-05 15:50:55 -04:00
|
|
|
property bool loading: false
|
2020-08-04 18:22:51 -04:00
|
|
|
property string ensStatus: ""
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
property var validateENS: Backpressure.debounce(root, 500, function (ensName, isStatus){
|
2022-01-17 09:56:44 +01:00
|
|
|
root.ensUsernamesStore.checkEnsUsernameAvailability(ensName, isStatus)
|
2020-08-03 16:46:37 -04:00
|
|
|
});
|
|
|
|
|
2020-08-05 15:50:55 -04:00
|
|
|
function validate(ensUsername) {
|
2020-08-03 16:46:37 -04:00
|
|
|
validationMessage = "";
|
|
|
|
valid = false;
|
2020-08-04 18:22:51 -04:00
|
|
|
ensStatus = "";
|
2020-08-05 15:50:55 -04:00
|
|
|
if (ensUsername.length < 4) {
|
2022-04-04 13:26:30 +02:00
|
|
|
validationMessage = qsTr("At least 4 characters. Latin letters, numbers, and lowercase only.");
|
2020-08-05 15:50:55 -04:00
|
|
|
} else if(isStatus && !ensUsername.match(/^[a-z0-9]+$/)){
|
2022-04-04 13:26:30 +02:00
|
|
|
validationMessage = qsTr("Letters and numbers only.");
|
2020-08-05 15:50:55 -04:00
|
|
|
} else if(!isStatus && !ensUsername.endsWith(".eth")){
|
2022-04-04 13:26:30 +02:00
|
|
|
validationMessage = qsTr("Type the entire username including the custom domain like username.domain.eth")
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
return validationMessage === "";
|
|
|
|
}
|
|
|
|
|
2020-08-05 15:50:55 -04:00
|
|
|
function onKeyReleased(ensUsername){
|
|
|
|
if (!validate(ensUsername)) {
|
2020-08-03 16:46:37 -04:00
|
|
|
return;
|
|
|
|
}
|
2020-08-05 15:50:55 -04:00
|
|
|
loading = true;
|
|
|
|
Qt.callLater(validateENS, ensUsername, isStatus)
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
Item {
|
|
|
|
id: ensContainer
|
2020-08-03 16:46:37 -04:00
|
|
|
anchors.top: parent.top
|
2021-12-09 14:28:02 +01:00
|
|
|
width: profileContentWidth
|
2020-08-03 16:46:37 -04:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
Rectangle {
|
|
|
|
id: circleAt
|
2021-03-25 04:17:33 +02:00
|
|
|
anchors.top: parent.top
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.bigPadding*2
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
width: 60
|
|
|
|
height: 60
|
|
|
|
radius: 120
|
2021-10-06 11:16:39 +02:00
|
|
|
color: Theme.palette.primaryColor1
|
2021-03-23 18:34:52 +02:00
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
visible: ensStatus === Constants.ens_taken
|
|
|
|
fillMode: Image.PreserveAspectFit
|
2024-10-15 21:26:12 +02:00
|
|
|
source: Theme.svg("block-icon-white")
|
2021-03-23 18:34:52 +02:00
|
|
|
width: 20
|
|
|
|
height: 20
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
}
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
StatusBaseText {
|
2021-03-23 18:34:52 +02:00
|
|
|
visible: ensStatus !== Constants.ens_taken
|
|
|
|
text: {
|
2022-02-09 10:43:23 +01:00
|
|
|
if((ensStatus === Constants.ens_available ||
|
|
|
|
ensStatus === Constants.ens_connected ||
|
2021-03-23 18:34:52 +02:00
|
|
|
ensStatus === Constants.ens_connected_dkey)) {
|
|
|
|
return "✓"
|
|
|
|
} else {
|
|
|
|
return "@"
|
|
|
|
}
|
2020-08-05 15:50:55 -04:00
|
|
|
}
|
2021-03-23 18:34:52 +02:00
|
|
|
opacity: 0.7
|
|
|
|
font.weight: Font.Bold
|
|
|
|
font.pixelSize: 18
|
2021-10-06 11:16:39 +02:00
|
|
|
color: Theme.palette.indirectColor1
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2020-08-05 15:50:55 -04:00
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
Input {
|
|
|
|
id: ensUsername
|
2022-08-09 15:52:17 +02:00
|
|
|
textField.objectName: "ensUsernameInput"
|
2021-03-23 18:34:52 +02:00
|
|
|
placeholderText: !isStatus ? "vitalik94.domain.eth" : "vitalik94"
|
2022-07-25 16:22:09 +03:00
|
|
|
anchors.left: parent.left
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.top: circleAt.bottom
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.bigPadding
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.right: btnContinue.left
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.rightMargin: Theme.bigPadding
|
2021-03-23 18:34:52 +02:00
|
|
|
Keys.onReleased: {
|
|
|
|
onKeyReleased(ensUsername.text);
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
Connections {
|
2022-01-17 09:56:44 +01:00
|
|
|
target: root.ensUsernamesStore.ensUsernamesModule
|
2023-01-18 11:25:36 +02:00
|
|
|
function onUsernameAvailabilityChecked(availabilityStatus: string) {
|
2021-03-23 18:34:52 +02:00
|
|
|
if(!validate(ensUsername.text)) return;
|
|
|
|
valid = false;
|
|
|
|
loading = false;
|
2022-01-17 09:56:44 +01:00
|
|
|
ensStatus = availabilityStatus;
|
|
|
|
switch(availabilityStatus){
|
2021-03-25 04:17:33 +02:00
|
|
|
case "available":
|
|
|
|
case "owned":
|
|
|
|
case "connected":
|
|
|
|
case "connected-different-key":
|
2021-03-23 18:34:52 +02:00
|
|
|
valid = true;
|
2022-01-17 09:56:44 +01:00
|
|
|
validationMessage = Constants.ensState[availabilityStatus]
|
2021-03-23 18:34:52 +02:00
|
|
|
break;
|
2021-03-25 04:17:33 +02:00
|
|
|
case "taken":
|
|
|
|
validationMessage = Constants.ensState[!isStatus ? 'taken-custom' : 'taken']
|
2021-03-23 18:34:52 +02:00
|
|
|
break;
|
2021-03-25 04:17:33 +02:00
|
|
|
case "already-connected":
|
2022-01-17 09:56:44 +01:00
|
|
|
validationMessage = Constants.ensState[availabilityStatus]
|
2021-03-23 18:34:52 +02:00
|
|
|
break;
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-25 21:37:44 +02:00
|
|
|
StatusQControls.StatusRoundButton {
|
2021-03-23 18:34:52 +02:00
|
|
|
id: btnContinue
|
2021-10-25 21:37:44 +02:00
|
|
|
width: 40
|
|
|
|
height: 40
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.top: circleAt.bottom
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.bigPadding
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.right: parent.right
|
2021-10-25 21:37:44 +02:00
|
|
|
type: StatusQControls.StatusRoundButton.Type.Secondary
|
2022-08-09 15:52:17 +02:00
|
|
|
objectName: "ensNextButton"
|
2021-03-23 18:34:52 +02:00
|
|
|
icon.name: "arrow-right"
|
|
|
|
visible: valid
|
|
|
|
onClicked: {
|
2020-08-03 16:46:37 -04:00
|
|
|
if(!valid) return;
|
2020-08-04 18:22:51 -04:00
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
if(ensStatus === Constants.ens_connected){
|
2022-01-17 09:56:44 +01:00
|
|
|
root.ensUsernamesStore.ensConnectOwnedUsername(ensUsername.text, isStatus);
|
2020-08-07 12:27:41 -04:00
|
|
|
continueClicked(ensStatus, ensUsername.text)
|
2020-08-04 18:22:51 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
if(ensStatus === Constants.ens_available){
|
2020-08-07 12:27:41 -04:00
|
|
|
continueClicked(ensStatus, ensUsername.text);
|
2020-08-04 18:22:51 -04:00
|
|
|
return;
|
|
|
|
}
|
2020-08-27 16:18:14 -04:00
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
if(ensStatus === Constants.ens_connected_dkey || ensStatus === Constants.ens_owned){
|
2024-10-03 15:14:27 +02:00
|
|
|
root.connectUsername(ensUsername.text)
|
2020-08-27 16:18:14 -04:00
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
Rectangle {
|
|
|
|
id: ensTypeRect
|
|
|
|
anchors.top: ensUsername.bottom
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.bigPadding
|
2021-03-23 18:34:52 +02:00
|
|
|
border.width: 1
|
2024-10-15 21:26:12 +02:00
|
|
|
border.color: Theme.palette.border
|
|
|
|
color: Theme.palette.background
|
2021-03-23 18:34:52 +02:00
|
|
|
radius: 50
|
|
|
|
height: 30
|
|
|
|
width: 350
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
Item {
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.top: parent.top
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.halfPadding
|
|
|
|
anchors.leftMargin: Theme.padding
|
2021-03-23 18:34:52 +02:00
|
|
|
height: 20
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
StatusBaseText {
|
2022-02-09 10:43:23 +01:00
|
|
|
text: !isStatus ?
|
2022-04-04 13:26:30 +02:00
|
|
|
qsTr("Custom domain")
|
2021-03-23 18:34:52 +02:00
|
|
|
:
|
|
|
|
".stateofus.eth"
|
|
|
|
font.weight: Font.Bold
|
|
|
|
font.pixelSize: 12
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.leftMargin: Theme.padding
|
2021-10-06 11:16:39 +02:00
|
|
|
color: Theme.palette.directColor1
|
2021-03-23 18:34:52 +02:00
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
StatusBaseText {
|
2022-02-09 10:43:23 +01:00
|
|
|
text: !isStatus ?
|
2022-04-04 13:26:30 +02:00
|
|
|
qsTr("I want a stateofus.eth domain")
|
2021-03-23 18:34:52 +02:00
|
|
|
:
|
2022-04-04 13:26:30 +02:00
|
|
|
qsTr("I own a name on another domain")
|
2021-03-23 18:34:52 +02:00
|
|
|
font.pixelSize: 12
|
2021-10-06 11:16:39 +02:00
|
|
|
color: Theme.palette.primaryColor1
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.right: parent.right
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.rightMargin: Theme.padding
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-03-23 18:34:52 +02:00
|
|
|
MouseArea {
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked : {
|
|
|
|
isStatus = !isStatus;
|
|
|
|
let ensUser = ensUsername.text;
|
|
|
|
if(validate(ensUser))
|
|
|
|
validateENS(ensUser, isStatus)
|
|
|
|
}
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
StatusBaseText {
|
2021-03-23 18:34:52 +02:00
|
|
|
id: validationResult
|
|
|
|
text: validationMessage
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2021-04-08 11:44:58 -04:00
|
|
|
width: parent.width
|
2021-03-23 18:34:52 +02:00
|
|
|
anchors.top: ensTypeRect.bottom
|
2021-04-08 11:44:58 -04:00
|
|
|
wrapMode: Text.WordWrap
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.bigPadding
|
2021-11-01 10:42:00 +01:00
|
|
|
color: Theme.palette.directColor1
|
2021-03-23 18:34:52 +02:00
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
2020-09-14 14:12:47 +02:00
|
|
|
}
|
2021-10-06 11:16:39 +02:00
|
|
|
|