2023-04-18 18:05:24 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1 as StatusQUtils
|
|
|
|
|
|
|
|
import AppLayouts.Wallet 1.0
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
import "../controls"
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property var store
|
2024-03-05 10:27:40 +01:00
|
|
|
property bool isCollectiblesTransfer
|
2023-04-18 18:05:24 +02:00
|
|
|
property bool isBridgeTx: false
|
|
|
|
property bool interactive: true
|
|
|
|
property var selectedAsset
|
|
|
|
property var selectedRecipient: null
|
|
|
|
property int selectedRecipientType
|
|
|
|
|
2023-09-19 17:06:57 +02:00
|
|
|
readonly property bool ready: (d.isAddressValid || !!resolvedENSAddress) && !d.isPending
|
2023-04-18 18:05:24 +02:00
|
|
|
property string addressText
|
|
|
|
property string resolvedENSAddress
|
|
|
|
|
|
|
|
signal recalculateRoutesAndFees()
|
|
|
|
signal isLoading()
|
|
|
|
|
|
|
|
onAddressTextChanged: d.isPending = false
|
|
|
|
|
|
|
|
onSelectedRecipientChanged: {
|
|
|
|
root.isLoading()
|
|
|
|
if(!!root.selectedRecipient && root.selectedRecipientType !== TabAddressSelectorView.Type.None) {
|
2023-09-19 17:06:57 +02:00
|
|
|
let preferredChainIds = []
|
2023-04-18 18:05:24 +02:00
|
|
|
switch(root.selectedRecipientType) {
|
2023-09-27 16:41:55 +03:00
|
|
|
case TabAddressSelectorView.Type.Account: {
|
2023-09-19 17:06:57 +02:00
|
|
|
root.addressText = root.selectedRecipient.address
|
|
|
|
preferredChainIds = root.selectedRecipient.preferredSharingChainIds
|
|
|
|
break
|
|
|
|
}
|
2023-04-18 18:05:24 +02:00
|
|
|
case TabAddressSelectorView.Type.SavedAddress: {
|
2023-09-19 17:06:57 +02:00
|
|
|
root.addressText = root.selectedRecipient.address
|
2024-03-02 11:48:11 +01:00
|
|
|
|
|
|
|
// Resolve before using
|
2023-09-19 17:06:57 +02:00
|
|
|
if (!!root.selectedRecipient.ens && root.selectedRecipient.ens.length > 0) {
|
2024-03-02 11:48:11 +01:00
|
|
|
d.isPending = true
|
|
|
|
d.resolveENS(root.selectedRecipient.ens)
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
2023-09-19 17:06:57 +02:00
|
|
|
preferredChainIds = store.getShortChainIds(root.selectedRecipient.chainShortNames)
|
2023-07-05 21:32:02 +02:00
|
|
|
break
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
case TabAddressSelectorView.Type.RecentsAddress: {
|
2023-06-29 14:35:18 -03:00
|
|
|
let isIncoming = root.selectedRecipient.txType === Constants.TransactionType.Receive
|
|
|
|
root.addressText = isIncoming ? root.selectedRecipient.sender : root.selectedRecipient.recipient
|
2023-04-18 18:05:24 +02:00
|
|
|
root.item.input.text = root.addressText
|
2023-09-19 17:06:57 +02:00
|
|
|
break
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
case TabAddressSelectorView.Type.Address: {
|
2023-09-19 17:06:57 +02:00
|
|
|
root.addressText = root.selectedRecipient.address
|
2023-04-18 18:05:24 +02:00
|
|
|
root.item.input.text = root.selectedRecipient.address
|
2023-07-05 21:32:02 +02:00
|
|
|
break
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
}
|
2023-09-19 17:06:57 +02:00
|
|
|
|
|
|
|
// set preferred chains
|
2024-03-05 10:27:40 +01:00
|
|
|
if(!isCollectiblesTransfer) {
|
2023-09-19 17:06:57 +02:00
|
|
|
if(root.isBridgeTx)
|
|
|
|
root.store.setAllNetworksAsRoutePreferredChains()
|
|
|
|
else
|
|
|
|
root.store.updateRoutePreferredChains(preferredChainIds)
|
|
|
|
}
|
|
|
|
|
|
|
|
recalculateRoutesAndFees()
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
property bool isAddressValid: Utils.isValidAddress(root.addressText)
|
2023-09-19 17:06:57 +02:00
|
|
|
readonly property var resolveENS: Backpressure.debounce(root, 1500, function (ensName) {
|
2023-04-18 18:05:24 +02:00
|
|
|
store.resolveENS(ensName)
|
|
|
|
})
|
|
|
|
property bool isPending: false
|
|
|
|
function clearValues() {
|
|
|
|
root.addressText = ""
|
|
|
|
root.resolvedENSAddress = ""
|
|
|
|
root.selectedRecipientType = TabAddressSelectorView.Type.None
|
|
|
|
root.selectedRecipient = null
|
|
|
|
}
|
|
|
|
property Timer waitTimer: Timer {
|
|
|
|
interval: 1500
|
2023-09-19 17:06:57 +02:00
|
|
|
onTriggered: d.evaluateAndSetPreferredChains()
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
|
2023-09-19 17:06:57 +02:00
|
|
|
function evaluateAndSetPreferredChains() {
|
|
|
|
let address = !!root.item.input && !!root.store.plainText(root.item.input.text) ? root.store.plainText(root.item.input.text): ""
|
2024-03-05 10:27:40 +01:00
|
|
|
let result = store.splitAndFormatAddressPrefix(address, !root.isBridgeTx && !isCollectiblesTransfer)
|
2023-09-19 17:06:57 +02:00
|
|
|
if(!!result.address) {
|
|
|
|
root.addressText = result.address
|
|
|
|
if(!!root.item.input)
|
|
|
|
root.item.input.text = result.formattedText
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
2023-09-19 17:06:57 +02:00
|
|
|
root.recalculateRoutesAndFees()
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-27 16:41:55 +03:00
|
|
|
sourceComponent: root.selectedRecipientType === TabAddressSelectorView.Type.SavedAddress
|
|
|
|
? savedAddressRecipient
|
|
|
|
: root.selectedRecipientType === TabAddressSelectorView.Type.Account
|
|
|
|
? myAccountRecipient : addressRecipient
|
2023-04-18 18:05:24 +02:00
|
|
|
|
|
|
|
Component {
|
|
|
|
id: savedAddressRecipient
|
|
|
|
SavedAddressListItem {
|
|
|
|
property string chainShortNames: !!modelData ? modelData.chainShortNames: ""
|
|
|
|
implicitWidth: parent.width
|
|
|
|
modelData: root.selectedRecipient
|
|
|
|
radius: 8
|
|
|
|
clearVisible: true
|
|
|
|
color: Theme.palette.indirectColor1
|
|
|
|
sensor.enabled: false
|
|
|
|
subTitle: {
|
|
|
|
if(!!modelData) {
|
|
|
|
if (!!modelData && !!modelData.ens && modelData.ens.length > 0)
|
|
|
|
return Utils.richColorText(modelData.ens, Theme.palette.directColor1)
|
|
|
|
else
|
|
|
|
return WalletUtils.colorizedChainPrefix(modelData.chainShortNames) + StatusQUtils.Utils.elideText(modelData.address,6,4)
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
onCleared: d.clearValues()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: myAccountRecipient
|
|
|
|
WalletAccountListItem {
|
2023-08-15 20:21:51 +02:00
|
|
|
property string chainShortNames: !!modelData ? store.getNetworkShortNames(modelData.preferredSharingChainIds): ""
|
2023-04-18 18:05:24 +02:00
|
|
|
implicitWidth: parent.width
|
|
|
|
modelData: root.selectedRecipient
|
|
|
|
radius: 8
|
|
|
|
clearVisible: true
|
|
|
|
color: Theme.palette.indirectColor1
|
|
|
|
sensor.enabled: false
|
|
|
|
subTitle: {
|
|
|
|
if(!!modelData) {
|
|
|
|
let elidedAddress = StatusQUtils.Utils.elideText(modelData.address,6,4)
|
2023-07-21 10:41:24 +02:00
|
|
|
let chainShortNames = store.getNetworkShortNames(modelData.preferredSharingChainIds)
|
2023-04-18 18:05:24 +02:00
|
|
|
return WalletUtils.colorizedChainPrefix(chainShortNames) + StatusQUtils.Utils.elideText(elidedAddress,6,4)
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
onCleared: d.clearValues()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: addressRecipient
|
|
|
|
StatusInput {
|
|
|
|
id: recipientInput
|
|
|
|
width: parent.width
|
|
|
|
height: visible ? implicitHeight: 0
|
|
|
|
visible: !root.isBridgeTx && !!root.selectedAsset
|
|
|
|
|
|
|
|
placeholderText: qsTr("Enter an ENS name or address")
|
|
|
|
input.background.color: Theme.palette.indirectColor1
|
|
|
|
input.background.border.width: 0
|
|
|
|
input.implicitHeight: 56
|
|
|
|
input.clearable: root.interactive
|
|
|
|
input.edit.readOnly: !root.interactive
|
|
|
|
multiline: false
|
|
|
|
input.edit.textFormat: TextEdit.RichText
|
2023-05-16 11:47:18 +02:00
|
|
|
text: addressText
|
2023-04-18 18:05:24 +02:00
|
|
|
|
|
|
|
input.rightComponent: RowLayout {
|
|
|
|
StatusButton {
|
|
|
|
font.weight: Font.Normal
|
|
|
|
borderColor: Theme.palette.primaryColor1
|
|
|
|
size: StatusBaseButton.Size.Tiny
|
|
|
|
text: qsTr("Paste")
|
|
|
|
visible: !store.plainText(recipientInput.text)
|
|
|
|
onClicked: recipientInput.input.edit.paste()
|
|
|
|
}
|
|
|
|
StatusIcon {
|
|
|
|
Layout.preferredWidth: 16
|
|
|
|
Layout.preferredHeight: 16
|
|
|
|
icon: "tiny/checkmark"
|
|
|
|
color: Theme.palette.primaryColor1
|
2023-09-19 17:06:57 +02:00
|
|
|
visible: root.ready
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
ClearButton {
|
|
|
|
Layout.preferredWidth: 24
|
|
|
|
Layout.preferredHeight: 24
|
|
|
|
visible: !!store.plainText(recipientInput.text)
|
|
|
|
onClicked: {
|
|
|
|
recipientInput.input.edit.clear()
|
|
|
|
d.clearValues()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-10-30 10:34:07 +01:00
|
|
|
Keys.onTabPressed: event.accepted = true
|
2023-04-18 18:05:24 +02:00
|
|
|
Keys.onReleased: {
|
|
|
|
let plainText = store.plainText(input.edit.text)
|
|
|
|
if(!plainText) {
|
|
|
|
d.clearValues()
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
root.isLoading()
|
2023-09-19 17:06:57 +02:00
|
|
|
if(Utils.isValidEns(plainText)) {
|
2023-04-18 18:05:24 +02:00
|
|
|
d.isPending = true
|
|
|
|
d.resolveENS(plainText)
|
|
|
|
}
|
2023-09-19 17:06:57 +02:00
|
|
|
else {
|
|
|
|
d.waitTimer.restart()
|
|
|
|
}
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: store.mainModuleInst
|
|
|
|
function onResolvedENS(resolvedPubKey: string, resolvedAddress: string, uuid: string) {
|
|
|
|
d.isPending = false
|
|
|
|
if(Utils.isValidAddress(resolvedAddress)) {
|
|
|
|
root.resolvedENSAddress = resolvedAddress
|
2023-09-19 17:06:57 +02:00
|
|
|
root.addressText = root.resolvedENSAddress
|
|
|
|
if(!!root.item.input)
|
|
|
|
root.item.input.text = root.resolvedENSAddress
|
|
|
|
d.evaluateAndSetPreferredChains()
|
2023-04-18 18:05:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|