2020-06-17 19:18:31 +00:00
|
|
|
import QtQuick 2.13
|
2020-07-30 05:18:54 +00:00
|
|
|
import QtQuick.Controls 2.13
|
2020-06-25 19:31:30 +00:00
|
|
|
import QtQuick.Dialogs 1.3
|
2021-09-28 15:04:06 +00:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-05 20:50:22 +00:00
|
|
|
|
2021-10-27 11:32:10 +00:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
2021-10-20 10:21:23 +00:00
|
|
|
|
2021-10-27 21:27:49 +00:00
|
|
|
import shared.popups 1.0
|
|
|
|
import shared.controls 1.0
|
2021-10-27 11:32:10 +00:00
|
|
|
|
2021-10-05 20:50:22 +00:00
|
|
|
import "../stores"
|
2020-06-09 19:29:57 +00:00
|
|
|
|
2021-10-14 11:07:19 +00:00
|
|
|
// TODO: replace with StatusModal
|
2020-06-09 19:29:57 +00:00
|
|
|
ModalPopup {
|
|
|
|
id: popup
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "Add a watch-only account"
|
|
|
|
title: qsTrId("add-watch-account")
|
2020-06-09 19:29:57 +00:00
|
|
|
|
|
|
|
property int marginBetweenInputs: 38
|
2020-06-22 17:26:47 +00:00
|
|
|
property string addressError: ""
|
|
|
|
property string accountNameValidationError: ""
|
2020-06-25 19:31:30 +00:00
|
|
|
property bool loading: false
|
2021-10-05 20:50:22 +00:00
|
|
|
|
|
|
|
signal afterAddAccount()
|
2020-06-22 17:26:47 +00:00
|
|
|
|
|
|
|
function validate() {
|
|
|
|
if (addressInput.text === "") {
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "You need to enter an address"
|
|
|
|
addressError = qsTrId("you-need-to-enter-an-address")
|
2020-06-22 17:26:47 +00:00
|
|
|
} else if (!Utils.isAddress(addressInput.text)) {
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "This needs to be a valid address (starting with 0x)"
|
|
|
|
addressError = qsTrId("this-needs-to-be-a-valid-address-(starting-with-0x)")
|
2020-06-22 17:26:47 +00:00
|
|
|
} else {
|
|
|
|
addressError = ""
|
|
|
|
}
|
|
|
|
|
|
|
|
if (accountNameInput.text === "") {
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "You need to enter an account name"
|
|
|
|
accountNameValidationError = qsTrId("you-need-to-enter-an-account-name")
|
2020-06-22 17:26:47 +00:00
|
|
|
} else {
|
|
|
|
accountNameValidationError = ""
|
|
|
|
}
|
|
|
|
|
|
|
|
return addressError === "" && accountNameValidationError === ""
|
|
|
|
}
|
2020-06-09 19:29:57 +00:00
|
|
|
|
|
|
|
onOpened: {
|
2020-12-02 18:51:56 +00:00
|
|
|
addressError = "";
|
|
|
|
accountNameValidationError = "";
|
2020-06-09 19:29:57 +00:00
|
|
|
addressInput.text = "";
|
2020-11-27 15:13:35 +00:00
|
|
|
accountNameInput.text = "";
|
2021-03-16 19:19:48 +00:00
|
|
|
accountColorInput.selectedColor = Style.current.accountColors[Math.floor(Math.random() * Style.current.accountColors.length)]
|
2020-06-09 19:29:57 +00:00
|
|
|
addressInput.forceActiveFocus(Qt.MouseFocusReason)
|
|
|
|
}
|
|
|
|
|
|
|
|
Input {
|
|
|
|
id: addressInput
|
|
|
|
// TODO add QR code reader for the address
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "Enter address..."
|
|
|
|
placeholderText: qsTrId("enter-address...")
|
|
|
|
//% "Account address"
|
|
|
|
label: qsTrId("wallet-key-title")
|
2020-06-22 17:26:47 +00:00
|
|
|
validationError: popup.addressError
|
2020-06-09 19:29:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Input {
|
|
|
|
id: accountNameInput
|
|
|
|
anchors.top: addressInput.bottom
|
|
|
|
anchors.topMargin: marginBetweenInputs
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "Enter an account name..."
|
|
|
|
placeholderText: qsTrId("enter-an-account-name...")
|
|
|
|
//% "Account name"
|
|
|
|
label: qsTrId("account-name")
|
2020-06-22 17:26:47 +00:00
|
|
|
validationError: popup.accountNameValidationError
|
2020-06-09 19:29:57 +00:00
|
|
|
}
|
|
|
|
|
2021-01-20 16:24:21 +00:00
|
|
|
StatusWalletColorSelect {
|
2020-06-09 19:29:57 +00:00
|
|
|
id: accountColorInput
|
|
|
|
anchors.top: accountNameInput.bottom
|
|
|
|
anchors.topMargin: marginBetweenInputs
|
2020-07-30 05:18:54 +00:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2021-10-27 11:32:10 +00:00
|
|
|
model: Theme.palette.accountColors
|
2020-06-09 19:29:57 +00:00
|
|
|
}
|
|
|
|
|
2021-10-27 11:32:10 +00:00
|
|
|
footer: StatusButton {
|
2020-06-09 19:29:57 +00:00
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.right: parent.right
|
2021-01-12 10:58:53 +00:00
|
|
|
text: loading ?
|
2020-07-06 20:39:55 +00:00
|
|
|
//% "Loading..."
|
|
|
|
qsTrId("loading") :
|
2021-02-18 16:36:05 +00:00
|
|
|
//% "Add account"
|
|
|
|
qsTrId("add-account")
|
2020-06-09 19:29:57 +00:00
|
|
|
|
2021-01-12 10:58:53 +00:00
|
|
|
enabled: !loading && addressInput.text !== "" && accountNameInput.text !== ""
|
2020-06-25 19:31:30 +00:00
|
|
|
|
|
|
|
MessageDialog {
|
|
|
|
id: accountError
|
|
|
|
title: "Adding the account failed"
|
|
|
|
icon: StandardIcon.Critical
|
|
|
|
standardButtons: StandardButton.Ok
|
|
|
|
}
|
2020-06-09 19:29:57 +00:00
|
|
|
|
|
|
|
onClicked : {
|
2020-06-25 19:31:30 +00:00
|
|
|
// TODO the loaidng doesn't work because the function freezes th eview. Might need to use threads
|
|
|
|
loading = true
|
2020-06-22 17:26:47 +00:00
|
|
|
if (!validate()) {
|
2020-06-30 20:01:37 +00:00
|
|
|
errorSound.play()
|
2020-06-25 19:31:30 +00:00
|
|
|
return loading = false
|
|
|
|
}
|
|
|
|
|
2021-10-05 20:50:22 +00:00
|
|
|
const error = RootStore.addWatchOnlyAccount(addressInput.text, accountNameInput.text, accountColorInput.selectedColor);
|
2020-06-25 19:31:30 +00:00
|
|
|
loading = false
|
|
|
|
if (error) {
|
2020-06-30 20:01:37 +00:00
|
|
|
errorSound.play()
|
2020-06-25 19:31:30 +00:00
|
|
|
accountError.text = error
|
|
|
|
return accountError.open()
|
2020-06-22 17:26:47 +00:00
|
|
|
}
|
2021-10-05 20:50:22 +00:00
|
|
|
popup.afterAddAccount()
|
2020-06-09 19:29:57 +00:00
|
|
|
popup.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|