2020-08-03 16:46:37 -04:00
|
|
|
import QtQuick 2.14
|
2020-05-27 17:28:25 -04:00
|
|
|
import QtQuick.Layouts 1.3
|
2020-08-03 16:46:37 -04:00
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQml.StateMachine 1.14 as DSM
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
|
|
import "../stores"
|
2020-05-27 17:28:25 -04:00
|
|
|
|
|
|
|
Item {
|
2021-12-09 14:28:02 +01:00
|
|
|
id: ensView
|
2020-05-27 17:28:25 -04:00
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
property var store
|
2021-12-09 14:28:02 +01:00
|
|
|
property var messageStore
|
|
|
|
property int profileContentWidth
|
2020-08-03 16:46:37 -04:00
|
|
|
property bool showSearchScreen: false
|
2020-08-04 18:22:51 -04:00
|
|
|
property string addedUsername: ""
|
2020-08-06 15:45:57 -04:00
|
|
|
property string selectedUsername: ""
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2020-08-04 18:22:51 -04:00
|
|
|
signal next(output: string)
|
2020-08-06 15:45:57 -04:00
|
|
|
signal back()
|
2020-08-27 12:06:53 -04:00
|
|
|
signal done(ensUsername: string)
|
2020-08-04 18:22:51 -04:00
|
|
|
signal connect(ensUsername: string)
|
2020-08-27 16:18:14 -04:00
|
|
|
signal changePubKey(ensUsername: string)
|
2020-08-04 18:22:51 -04:00
|
|
|
signal goToWelcome();
|
|
|
|
signal goToList();
|
|
|
|
|
2021-08-09 17:23:44 +02:00
|
|
|
function goToStart(){
|
2021-12-08 23:20:43 +02:00
|
|
|
if(ensView.store.ens.rowCount() > 0 && Global.networkGuarded){
|
2020-08-04 18:22:51 -04:00
|
|
|
goToList();
|
|
|
|
} else {
|
|
|
|
goToWelcome();
|
|
|
|
}
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
|
2021-12-09 14:28:02 +01:00
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
clip: true
|
|
|
|
|
2020-08-03 16:46:37 -04:00
|
|
|
DSM.StateMachine {
|
|
|
|
id: stateMachine
|
|
|
|
initialState: welcomeState
|
|
|
|
running: true
|
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: welcomeState
|
|
|
|
onEntered: loader.sourceComponent = welcome
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: searchState
|
|
|
|
signal: next
|
|
|
|
}
|
2020-08-04 18:22:51 -04:00
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: goToList
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: searchState
|
|
|
|
onEntered: loader.sourceComponent = search
|
2020-08-04 18:22:51 -04:00
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: tAndCState
|
|
|
|
signal: next
|
|
|
|
guard: output === "available"
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: addedState
|
|
|
|
signal: connect
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: goToList
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: welcomeState
|
|
|
|
signal: goToWelcome
|
|
|
|
}
|
2020-08-27 16:18:14 -04:00
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: ensConnectedState
|
|
|
|
signal: done
|
|
|
|
}
|
2020-08-04 18:22:51 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: addedState
|
|
|
|
onEntered: {
|
|
|
|
loader.sourceComponent = added;
|
|
|
|
loader.item.ensUsername = addedUsername;
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: next
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: goToList
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: welcomeState
|
|
|
|
signal: goToWelcome
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: listState
|
|
|
|
onEntered: {
|
|
|
|
loader.sourceComponent = list;
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: searchState
|
|
|
|
signal: next
|
2020-08-06 15:45:57 -04:00
|
|
|
guard: output === "search"
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: detailsState
|
|
|
|
signal: next
|
|
|
|
guard: output === "details"
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: goToList
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: welcomeState
|
|
|
|
signal: goToWelcome
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: detailsState
|
|
|
|
onEntered: {
|
|
|
|
loader.sourceComponent = details;
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: back
|
2020-08-04 18:22:51 -04:00
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: goToList
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: welcomeState
|
|
|
|
signal: goToWelcome
|
|
|
|
}
|
2021-08-09 18:23:52 -04:00
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: ensReleasedState
|
|
|
|
signal: done
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
2020-08-04 18:22:51 -04:00
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: tAndCState
|
|
|
|
onEntered:loader.sourceComponent = termsAndConditions
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: goToList
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: welcomeState
|
|
|
|
signal: goToWelcome
|
|
|
|
}
|
2020-08-26 17:13:26 -04:00
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: back
|
|
|
|
}
|
2020-08-27 12:06:53 -04:00
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: back
|
|
|
|
}
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: ensRegisteredState
|
|
|
|
signal: done
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DSM.State {
|
|
|
|
id: ensRegisteredState
|
|
|
|
onEntered:loader.sourceComponent = ensRegistered
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: next
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
2020-08-27 16:18:14 -04:00
|
|
|
|
2021-08-09 18:23:52 -04:00
|
|
|
DSM.State {
|
|
|
|
id: ensReleasedState
|
|
|
|
onEntered:loader.sourceComponent = ensReleased
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: next
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-27 16:18:14 -04:00
|
|
|
DSM.State {
|
|
|
|
id: ensConnectedState
|
|
|
|
onEntered:loader.sourceComponent = ensConnected
|
|
|
|
DSM.SignalTransition {
|
|
|
|
targetState: listState
|
|
|
|
signal: next
|
|
|
|
}
|
|
|
|
}
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: loader
|
|
|
|
anchors.fill: parent
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: welcome
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsWelcomeView {
|
2021-12-09 14:28:02 +01:00
|
|
|
username: ensView.store.username
|
2020-08-07 12:27:41 -04:00
|
|
|
onStartBtnClicked: next(null)
|
2021-12-09 14:28:02 +01:00
|
|
|
profileContentWidth: ensView.profileContentWidth
|
2020-08-03 16:46:37 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: search
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsSearchView {
|
2021-12-09 14:28:02 +01:00
|
|
|
store: ensView.store
|
|
|
|
profileContentWidth: ensView.profileContentWidth
|
2020-08-07 12:27:41 -04:00
|
|
|
onContinueClicked: {
|
2020-08-04 18:22:51 -04:00
|
|
|
if(output === "connected"){
|
|
|
|
connect(username)
|
|
|
|
} else {
|
2020-08-26 17:13:26 -04:00
|
|
|
selectedUsername = username;
|
2020-08-04 18:22:51 -04:00
|
|
|
next(output);
|
|
|
|
}
|
|
|
|
}
|
2020-08-27 16:18:14 -04:00
|
|
|
onUsernameUpdated: {
|
|
|
|
selectedUsername = username;
|
|
|
|
done(username);
|
|
|
|
}
|
2020-08-04 18:22:51 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: termsAndConditions
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsTermsAndConditionsView {
|
2021-12-09 14:28:02 +01:00
|
|
|
store: ensView.store
|
2020-08-26 17:13:26 -04:00
|
|
|
username: selectedUsername
|
|
|
|
onBackBtnClicked: back();
|
2020-08-27 12:06:53 -04:00
|
|
|
onUsernameRegistered: done(userName);
|
2020-08-04 18:22:51 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: added
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsAddedView {
|
2020-08-07 12:27:41 -04:00
|
|
|
onOkBtnClicked: next(null)
|
2020-08-04 18:22:51 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-27 12:06:53 -04:00
|
|
|
Component {
|
|
|
|
id: ensRegistered
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsRegisteredView {
|
2020-08-27 12:06:53 -04:00
|
|
|
ensUsername: selectedUsername
|
|
|
|
onOkBtnClicked: next(null)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-09 18:23:52 -04:00
|
|
|
Component {
|
|
|
|
id: ensReleased
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsReleasedView {
|
2021-08-09 18:23:52 -04:00
|
|
|
ensUsername: selectedUsername
|
|
|
|
onOkBtnClicked: next(null)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-27 16:18:14 -04:00
|
|
|
Component {
|
|
|
|
id: ensConnected
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsConnectedView {
|
2020-08-27 16:18:14 -04:00
|
|
|
ensUsername: selectedUsername
|
|
|
|
onOkBtnClicked: next(null)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-04 18:22:51 -04:00
|
|
|
Component {
|
|
|
|
id: list
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsListView {
|
2021-12-09 14:28:02 +01:00
|
|
|
store: ensView.store
|
|
|
|
messageStore: ensView.messageStore
|
|
|
|
profileContentWidth: ensView.profileContentWidth
|
2020-08-07 12:27:41 -04:00
|
|
|
onAddBtnClicked: next("search")
|
|
|
|
onSelectEns: {
|
2021-12-09 14:28:02 +01:00
|
|
|
ensView.store.ensDetails(username)
|
2020-08-06 15:45:57 -04:00
|
|
|
selectedUsername = username;
|
|
|
|
next("details")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: details
|
2021-10-06 11:16:39 +02:00
|
|
|
EnsDetailsView {
|
2021-12-09 14:28:02 +01:00
|
|
|
store: ensView.store
|
2020-08-06 15:45:57 -04:00
|
|
|
username: selectedUsername
|
2020-08-07 12:27:41 -04:00
|
|
|
onBackBtnClicked: back();
|
2021-08-09 18:23:52 -04:00
|
|
|
onUsernameReleased: {
|
|
|
|
selectedUsername = username;
|
|
|
|
done(username);
|
|
|
|
}
|
2020-08-04 18:22:51 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
2021-12-09 14:28:02 +01:00
|
|
|
target: ensView
|
2020-08-04 18:22:51 -04:00
|
|
|
onConnect: {
|
|
|
|
addedUsername = ensUsername;
|
|
|
|
}
|
2020-05-27 17:28:25 -04:00
|
|
|
}
|
2020-09-14 13:38:23 -04:00
|
|
|
|
|
|
|
Connections {
|
2021-12-09 14:28:02 +01:00
|
|
|
target: ensView.store.ens
|
2020-09-14 13:38:23 -04:00
|
|
|
onTransactionWasSent: {
|
2020-09-18 08:33:20 +02:00
|
|
|
//% "Transaction pending..."
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.toastMessage.title = qsTrId("ens-transaction-pending")
|
|
|
|
Global.toastMessage.source = Style.svg("loading")
|
|
|
|
Global.toastMessage.iconColor = Style.current.primary
|
|
|
|
Global.toastMessage.iconRotates = true
|
|
|
|
Global.toastMessage.link = `${root.store.etherscanLink}/${txResult}`
|
|
|
|
Global.toastMessage.open()
|
2020-09-14 13:38:23 -04:00
|
|
|
}
|
|
|
|
onTransactionCompleted: {
|
|
|
|
switch(trxType){
|
|
|
|
case "RegisterENS":
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.toastMessage.title = !success ?
|
2020-09-18 08:33:20 +02:00
|
|
|
//% "ENS Registration failed"
|
|
|
|
qsTrId("ens-registration-failed")
|
2020-09-14 15:41:09 -04:00
|
|
|
:
|
2020-09-18 08:33:20 +02:00
|
|
|
//% "ENS Registration completed"
|
|
|
|
qsTrId("ens-registration-completed");
|
2020-09-14 13:38:23 -04:00
|
|
|
break;
|
|
|
|
case "SetPubKey":
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.toastMessage.title = !success ?
|
2020-09-18 08:33:20 +02:00
|
|
|
//% "Updating ENS pubkey failed"
|
|
|
|
qsTrId("updating-ens-pubkey-failed")
|
2020-09-14 15:41:09 -04:00
|
|
|
:
|
2020-09-18 08:33:20 +02:00
|
|
|
//% "Updating ENS pubkey completed"
|
|
|
|
qsTrId("updating-ens-pubkey-completed");
|
2020-09-14 13:38:23 -04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (success) {
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.toastMessage.source = Style.svg("check-circle")
|
|
|
|
Global.toastMessage.iconColor = Style.current.success
|
2020-09-14 13:38:23 -04:00
|
|
|
} else {
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.toastMessage.source = Style.svg("block-icon")
|
|
|
|
Global.toastMessage.iconColor = Style.current.danger
|
2020-09-14 13:38:23 -04:00
|
|
|
}
|
2021-12-08 23:20:43 +02:00
|
|
|
Global.toastMessage.link = `${root.store.etherscanLink}/${txHash}`
|
|
|
|
Global.toastMessage.open()
|
2020-09-14 13:38:23 -04:00
|
|
|
}
|
|
|
|
}
|
2020-05-27 17:28:25 -04:00
|
|
|
}
|
2021-10-06 11:16:39 +02:00
|
|
|
|