2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
2021-12-06 23:10:54 +02:00
|
|
|
import QtQuick.Dialogs 1.3
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-05 22:50:22 +02:00
|
|
|
|
2021-10-20 12:21:23 +02:00
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared.popups 1.0
|
|
|
|
import shared.controls 1.0
|
2021-10-05 22:50:22 +02:00
|
|
|
import "../stores"
|
2020-06-11 15:52:54 -04:00
|
|
|
|
2021-10-14 13:07:19 +02:00
|
|
|
// TODO: replace with StatusModal
|
2020-06-11 15:52:54 -04:00
|
|
|
ModalPopup {
|
|
|
|
id: popup
|
|
|
|
|
2020-10-30 15:22:54 -04:00
|
|
|
property bool editable: true
|
2020-06-11 15:52:54 -04:00
|
|
|
property int marginBetweenInputs: 35
|
2020-11-02 12:46:04 -04:00
|
|
|
property string validationError: ""
|
2020-06-11 15:52:54 -04:00
|
|
|
|
2020-10-30 15:22:54 -04:00
|
|
|
title: editable ?
|
|
|
|
//% "Add custom token"
|
|
|
|
qsTrId("add-custom-token")
|
|
|
|
: nameInput.text
|
|
|
|
|
|
|
|
height: editable ? 450 : 380
|
|
|
|
|
2020-06-11 15:52:54 -04:00
|
|
|
onOpened: {
|
2020-11-02 14:18:13 -04:00
|
|
|
addressInput.forceActiveFocus(Qt.MouseFocusReason)
|
|
|
|
}
|
|
|
|
|
|
|
|
function openEditable(){
|
2020-10-30 15:22:54 -04:00
|
|
|
addressInput.text = "";
|
|
|
|
nameInput.text = "";
|
|
|
|
symbolInput.text = "";
|
|
|
|
decimalsInput.text = "";
|
2020-11-02 14:18:13 -04:00
|
|
|
editable = true;
|
|
|
|
open();
|
2020-06-11 15:52:54 -04:00
|
|
|
}
|
|
|
|
|
2020-11-02 14:18:13 -04:00
|
|
|
function openWithData(address, name, symbol, decimals){
|
2020-10-30 15:22:54 -04:00
|
|
|
addressInput.text = address;
|
|
|
|
nameInput.text = name;
|
|
|
|
symbolInput.text = symbol;
|
|
|
|
decimalsInput.text = decimals;
|
|
|
|
editable = false;
|
2020-11-02 14:18:13 -04:00
|
|
|
open();
|
2020-10-30 15:22:54 -04:00
|
|
|
}
|
|
|
|
|
2020-11-02 12:46:04 -04:00
|
|
|
|
|
|
|
function validate() {
|
|
|
|
if (addressInput.text !== "" && !Utils.isAddress(addressInput.text)) {
|
2021-02-18 11:36:05 -05:00
|
|
|
//% "This needs to be a valid address"
|
|
|
|
validationError = qsTrId("this-needs-to-be-a-valid-address");
|
2020-11-02 12:46:04 -04:00
|
|
|
}
|
|
|
|
return validationError === ""
|
|
|
|
}
|
|
|
|
|
|
|
|
property var getTokenDetails: Backpressure.debounce(popup, 500, function (tokenAddress){
|
2021-11-09 14:40:09 -05:00
|
|
|
RootStore.walletTokensModule.getTokenDetails(tokenAddress)
|
2020-11-02 12:46:04 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
function onKeyReleased(){
|
|
|
|
validationError = "";
|
|
|
|
if (!validate() || addressInput.text === "") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
Qt.callLater(getTokenDetails, addressInput.text)
|
|
|
|
}
|
|
|
|
|
|
|
|
Item {
|
|
|
|
Connections {
|
2021-11-09 14:40:09 -05:00
|
|
|
target: RootStore.walletTokensModule
|
2020-11-02 12:46:04 -04:00
|
|
|
onTokenDetailsWereResolved: {
|
|
|
|
const jsonObj = JSON.parse(tokenDetails)
|
2021-03-25 17:19:05 +11:00
|
|
|
if (jsonObj.error) {
|
|
|
|
validationError = jsonObj.error
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if (jsonObj.name === "" && jsonObj.symbol === "" && jsonObj.decimals === "") {
|
2021-02-18 11:36:05 -05:00
|
|
|
//% "Invalid ERC20 address"
|
|
|
|
validationError = qsTrId("invalid-erc20-address")
|
2020-11-02 12:46:04 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-03-25 17:19:05 +11:00
|
|
|
if (addressInput.text.toLowerCase() === jsonObj.address.toLowerCase()) {
|
2020-11-02 12:46:04 -04:00
|
|
|
symbolInput.text = jsonObj.symbol;
|
|
|
|
decimalsInput.text = jsonObj.decimals;
|
|
|
|
nameInput.text = jsonObj.name;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-11 15:52:54 -04:00
|
|
|
Input {
|
|
|
|
id: addressInput
|
2020-10-30 15:22:54 -04:00
|
|
|
readOnly: !editable
|
2020-11-02 12:46:04 -04:00
|
|
|
textField.maximumLength: 42
|
2020-07-06 16:39:55 -04:00
|
|
|
//% "Enter contract address..."
|
|
|
|
placeholderText: qsTrId("enter-contract-address...")
|
|
|
|
//% "Contract address"
|
|
|
|
label: qsTrId("contract-address")
|
2020-11-02 12:46:04 -04:00
|
|
|
validationError: popup.validationError
|
|
|
|
Keys.onReleased: onKeyReleased()
|
2020-06-11 15:52:54 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
Input {
|
|
|
|
id: nameInput
|
2020-10-30 15:22:54 -04:00
|
|
|
readOnly: !editable
|
2020-06-11 15:52:54 -04:00
|
|
|
anchors.top: addressInput.bottom
|
|
|
|
anchors.topMargin: marginBetweenInputs
|
2020-07-06 16:39:55 -04:00
|
|
|
//% "The name of your token..."
|
|
|
|
placeholderText: qsTrId("the-name-of-your-token...")
|
|
|
|
//% "Name"
|
|
|
|
label: qsTrId("name")
|
2020-06-11 15:52:54 -04:00
|
|
|
}
|
|
|
|
|
2020-11-02 14:18:13 -04:00
|
|
|
Input {
|
|
|
|
id: symbolInput
|
|
|
|
readOnly: !editable
|
|
|
|
//% "ABC"
|
|
|
|
placeholderText: qsTrId("abc")
|
|
|
|
//% "Symbol"
|
|
|
|
label: qsTrId("symbol")
|
2020-06-11 15:52:54 -04:00
|
|
|
anchors.top: nameInput.bottom
|
|
|
|
anchors.topMargin: marginBetweenInputs
|
2020-10-30 15:22:54 -04:00
|
|
|
anchors.left: parent.left
|
2020-11-02 14:18:13 -04:00
|
|
|
anchors.right: undefined
|
|
|
|
width: parent.width / 2 - 20
|
2020-06-11 15:52:54 -04:00
|
|
|
}
|
|
|
|
|
2020-11-02 14:18:13 -04:00
|
|
|
Input {
|
|
|
|
id: decimalsInput
|
|
|
|
readOnly: !editable
|
|
|
|
placeholderText: "18"
|
|
|
|
//% "Decimals"
|
|
|
|
label: qsTrId("decimals")
|
|
|
|
text: "18"
|
2020-10-30 15:22:54 -04:00
|
|
|
anchors.top: nameInput.bottom
|
2020-06-11 15:52:54 -04:00
|
|
|
anchors.topMargin: marginBetweenInputs
|
2020-10-30 15:22:54 -04:00
|
|
|
anchors.right: parent.right
|
2020-11-02 14:18:13 -04:00
|
|
|
anchors.left: undefined
|
|
|
|
width: parent.width / 2 - 20
|
2020-06-11 15:52:54 -04:00
|
|
|
}
|
2020-11-02 14:18:13 -04:00
|
|
|
|
2020-06-11 15:52:54 -04:00
|
|
|
footer: Item {
|
2021-01-13 14:15:52 -05:00
|
|
|
width: parent.width
|
|
|
|
height: addBtn.height
|
2020-10-30 15:22:54 -04:00
|
|
|
visible: editable
|
2021-01-13 14:15:52 -05:00
|
|
|
|
2021-12-06 23:10:54 +02:00
|
|
|
MessageDialog {
|
|
|
|
id: changeError
|
|
|
|
title: qsTr("Changing settings failed")
|
|
|
|
icon: StandardIcon.Critical
|
|
|
|
standardButtons: StandardButton.Ok
|
|
|
|
}
|
|
|
|
|
2021-01-28 12:04:10 +01:00
|
|
|
StatusButton {
|
2020-06-11 15:52:54 -04:00
|
|
|
id: addBtn
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.right: parent.right
|
2020-07-02 11:14:31 -04:00
|
|
|
anchors.rightMargin: Style.current.padding
|
2020-07-06 16:39:55 -04:00
|
|
|
//% "Add"
|
2021-01-28 12:04:10 +01:00
|
|
|
text: qsTrId("add")
|
2020-06-11 15:52:54 -04:00
|
|
|
|
2021-01-28 12:04:10 +01:00
|
|
|
enabled: validationError === "" && addressInput.text !== "" && nameInput.text !== "" && symbolInput.text !== "" && decimalsInput.text !== ""
|
2020-06-11 15:52:54 -04:00
|
|
|
|
|
|
|
onClicked : {
|
2021-10-05 22:50:22 +02:00
|
|
|
const error = RootStore.addCustomToken(addressInput.text, nameInput.text, symbolInput.text, decimalsInput.text);
|
2020-06-11 15:52:54 -04:00
|
|
|
|
|
|
|
if (error) {
|
2021-12-06 23:10:54 +02:00
|
|
|
Global.playErrorSound();
|
|
|
|
changeError.text = error;
|
|
|
|
changeError.open();
|
|
|
|
return;
|
2020-06-11 15:52:54 -04:00
|
|
|
}
|
|
|
|
popup.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|