2020-08-06 17:25:53 +10:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import QtGraphicalEffects 1.13
|
|
|
|
import "../imports"
|
2020-09-09 13:04:01 +02:00
|
|
|
import "../shared"
|
2020-08-06 17:25:53 +10:00
|
|
|
|
|
|
|
Item {
|
|
|
|
id: root
|
|
|
|
property string validationError: "Error"
|
2020-09-14 14:12:47 +02:00
|
|
|
//% "ENS Username not found"
|
|
|
|
property string ensAsyncValidationError: qsTrId("ens-username-not-found")
|
2020-08-06 17:25:53 +10:00
|
|
|
property alias label: inpAddress.label
|
2020-10-28 18:44:09 +11:00
|
|
|
property alias text: inpAddress.text
|
2020-08-06 17:25:53 +10:00
|
|
|
property string selectedAddress
|
2020-08-20 14:45:29 +10:00
|
|
|
property var isValid: false
|
2020-10-29 14:07:34 +11:00
|
|
|
property alias isPending: ensResolver.isPending
|
2020-10-28 18:44:09 +11:00
|
|
|
property alias readOnly: inpAddress.readOnly
|
|
|
|
property bool isResolvedAddress: false
|
2020-08-06 17:25:53 +10:00
|
|
|
|
|
|
|
height: inpAddress.height
|
|
|
|
|
2020-10-28 18:44:09 +11:00
|
|
|
onSelectedAddressChanged: validate()
|
2020-11-04 13:37:53 +01:00
|
|
|
onTextChanged: {
|
|
|
|
metrics.text = text
|
|
|
|
root.isResolvedAddress = false
|
|
|
|
if (Utils.isValidAddress(text)) {
|
|
|
|
root.selectedAddress = text
|
|
|
|
} else {
|
|
|
|
root.selectedAddress = ""
|
|
|
|
root.validate()
|
|
|
|
}
|
|
|
|
ensResolver.resolveEns(text)
|
|
|
|
}
|
2020-10-28 18:44:09 +11:00
|
|
|
|
2020-08-20 14:45:29 +10:00
|
|
|
function resetInternal() {
|
|
|
|
selectedAddress = ""
|
|
|
|
inpAddress.resetInternal()
|
|
|
|
metrics.text = ""
|
|
|
|
isValid = false
|
2020-10-28 18:44:09 +11:00
|
|
|
isPending = false
|
|
|
|
isResolvedAddress = false
|
|
|
|
}
|
|
|
|
|
|
|
|
function validate() {
|
|
|
|
let isValidEns = Utils.isValidEns(text)
|
|
|
|
let isValidAddress = Utils.isValidAddress(selectedAddress)
|
|
|
|
let isValid = (isValidEns && !isResolvedAddress) || isPending || isValidAddress
|
|
|
|
inpAddress.validationError = ""
|
|
|
|
if (!isValid){
|
|
|
|
inpAddress.validationError = isResolvedAddress ? ensAsyncValidationError : validationError
|
|
|
|
}
|
2020-08-20 14:45:29 +10:00
|
|
|
root.isValid = isValid
|
2020-08-06 17:25:53 +10:00
|
|
|
return isValid
|
|
|
|
}
|
|
|
|
|
|
|
|
Input {
|
|
|
|
id: inpAddress
|
2020-08-26 11:52:26 -04:00
|
|
|
//% "eg. 0x1234 or ENS"
|
|
|
|
placeholderText: qsTrId("eg--0x1234-or-ens")
|
2020-08-06 17:25:53 +10:00
|
|
|
customHeight: 56
|
|
|
|
validationErrorAlignment: TextEdit.AlignRight
|
|
|
|
validationErrorTopMargin: 8
|
|
|
|
textField.onFocusChanged: {
|
|
|
|
let isValid = true
|
2020-10-28 18:44:09 +11:00
|
|
|
if (text !== "" && Utils.isValidAddress(metrics.text)) {
|
|
|
|
if (textField.focus) {
|
|
|
|
text = metrics.text
|
|
|
|
} else {
|
|
|
|
text = metrics.elidedText
|
|
|
|
}
|
2020-08-06 17:25:53 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
textField.rightPadding: 73
|
|
|
|
TextMetrics {
|
|
|
|
id: metrics
|
|
|
|
elideWidth: 97
|
|
|
|
elide: Text.ElideMiddle
|
|
|
|
}
|
|
|
|
TertiaryButton {
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 8
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: 14
|
2020-10-28 18:44:09 +11:00
|
|
|
visible: !root.readOnly
|
2020-08-26 11:52:26 -04:00
|
|
|
//% "Paste"
|
|
|
|
label: qsTrId("paste")
|
2020-08-06 17:25:53 +10:00
|
|
|
onClicked: {
|
|
|
|
if (inpAddress.textField.canPaste) {
|
|
|
|
inpAddress.textField.paste()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-09-09 13:04:01 +02:00
|
|
|
|
2020-10-29 14:07:34 +11:00
|
|
|
EnsResolver {
|
|
|
|
id: ensResolver
|
2020-09-09 13:04:01 +02:00
|
|
|
anchors.top: inpAddress.bottom
|
|
|
|
anchors.right: inpAddress.right
|
|
|
|
anchors.topMargin: Style.current.halfPadding
|
2020-10-30 10:08:07 +11:00
|
|
|
debounceDelay: root.readOnly ? 0 : 600
|
2020-10-29 14:07:34 +11:00
|
|
|
onResolved: {
|
|
|
|
root.isResolvedAddress = true
|
|
|
|
root.selectedAddress = resolvedAddress
|
2020-11-04 13:37:53 +01:00
|
|
|
root.validate()
|
2020-10-29 14:07:34 +11:00
|
|
|
}
|
|
|
|
onIsPendingChanged: {
|
|
|
|
if (isPending) {
|
|
|
|
root.selectedAddress = ""
|
|
|
|
}
|
2020-09-09 13:04:01 +02:00
|
|
|
}
|
|
|
|
}
|
2020-08-06 17:25:53 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*##^##
|
|
|
|
Designer {
|
|
|
|
D{i:0;autoSize:true;height:480;width:640}
|
|
|
|
}
|
|
|
|
##^##*/
|