2022-09-05 11:15:47 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
import shared.controls 1.0
|
|
|
|
|
|
|
|
import "../popups"
|
|
|
|
import "../controls"
|
2024-01-15 10:20:52 +01:00
|
|
|
import "../stores"
|
2023-02-20 13:57:45 +03:00
|
|
|
import ".."
|
2022-09-05 11:15:47 +02:00
|
|
|
|
|
|
|
StatusListItem {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property var store
|
|
|
|
property var contactsStore
|
2024-02-02 10:55:56 +01:00
|
|
|
property var networkConnectionStore
|
2022-09-05 11:15:47 +02:00
|
|
|
property string name
|
|
|
|
property string address
|
2022-10-20 15:33:23 +02:00
|
|
|
property string ens
|
2023-12-29 14:10:55 +01:00
|
|
|
property string colorId
|
2023-02-20 13:57:45 +03:00
|
|
|
property string chainShortNames
|
2023-07-03 11:23:26 +02:00
|
|
|
property bool areTestNetworksEnabled: false
|
2024-02-20 10:31:04 +01:00
|
|
|
property bool isGoerliEnabled: false
|
2022-09-05 11:15:47 +02:00
|
|
|
|
2024-02-19 09:40:16 +01:00
|
|
|
property int usage: SavedAddressesDelegate.Usage.Delegate
|
|
|
|
property bool showButtons: sensor.containsMouse
|
|
|
|
|
|
|
|
property alias sendButton: sendButton
|
|
|
|
|
|
|
|
signal aboutToOpenPopup()
|
2023-02-20 13:57:45 +03:00
|
|
|
signal openSendModal(string recipient)
|
2022-09-05 11:15:47 +02:00
|
|
|
|
2024-02-19 09:40:16 +01:00
|
|
|
enum Usage {
|
|
|
|
Delegate,
|
|
|
|
Item
|
|
|
|
}
|
|
|
|
|
2023-04-04 14:09:36 +02:00
|
|
|
implicitWidth: ListView.view ? ListView.view.width : 0
|
2022-09-05 11:15:47 +02:00
|
|
|
|
|
|
|
title: name
|
|
|
|
objectName: name
|
2023-02-20 13:57:45 +03:00
|
|
|
subTitle: {
|
|
|
|
if (ens.length > 0)
|
|
|
|
return ens
|
2023-12-29 16:40:14 +01:00
|
|
|
else {
|
|
|
|
return sensor.containsMouse ? WalletUtils.colorizedChainPrefix(root.chainShortNames) +
|
|
|
|
Utils.richColorText(root.address, Theme.palette.directColor1)
|
|
|
|
: root.chainShortNames + root.address
|
|
|
|
}
|
2023-02-20 13:57:45 +03:00
|
|
|
}
|
2023-12-29 16:40:14 +01:00
|
|
|
|
2022-09-05 11:15:47 +02:00
|
|
|
border.color: Theme.palette.baseColor5
|
2023-12-29 16:40:14 +01:00
|
|
|
|
|
|
|
asset {
|
|
|
|
width: 40
|
|
|
|
height: 40
|
|
|
|
color: Utils.getColorForId(root.colorId)
|
|
|
|
charactersLen: {
|
|
|
|
let parts = root.name.split(" ")
|
|
|
|
if (parts.length > 1) {
|
|
|
|
return 2
|
|
|
|
}
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
isLetterIdenticon: true
|
|
|
|
useAcronymForLetterIdenticon: true
|
|
|
|
}
|
2023-02-20 13:57:45 +03:00
|
|
|
|
|
|
|
statusListItemIcon.hoverEnabled: true
|
|
|
|
|
2022-09-05 11:15:47 +02:00
|
|
|
statusListItemComponentsSlot.spacing: 0
|
|
|
|
|
2023-02-20 13:57:45 +03:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
2024-01-10 10:47:29 +01:00
|
|
|
readonly property string visibleAddress: !!root.ens? root.ens : root.address
|
2024-01-15 13:27:47 +01:00
|
|
|
readonly property var preferredSharedNetworkNamesArray: root.chainShortNames.split(":").filter(Boolean)
|
2023-02-20 13:57:45 +03:00
|
|
|
}
|
|
|
|
|
2024-02-19 09:40:16 +01:00
|
|
|
onClicked: {
|
|
|
|
if (root.usage === SavedAddressesDelegate.Usage.Item) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
Global.openSavedAddressActivityPopup({
|
|
|
|
name: root.name,
|
|
|
|
address: root.address,
|
|
|
|
chainShortNames: root.chainShortNames,
|
|
|
|
ens: root.ens,
|
|
|
|
colorId: root.colorId
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-09-05 11:15:47 +02:00
|
|
|
components: [
|
2024-01-10 09:40:15 +01:00
|
|
|
StatusRoundButton {
|
2024-02-19 09:40:16 +01:00
|
|
|
id: sendButton
|
2024-01-10 09:40:15 +01:00
|
|
|
visible: !!root.name && root.showButtons
|
|
|
|
type: StatusRoundButton.Type.Quinary
|
|
|
|
radius: 8
|
|
|
|
icon.name: "send"
|
2024-02-02 10:55:56 +01:00
|
|
|
enabled: root.networkConnectionStore.sendBuyBridgeEnabled
|
2024-01-10 09:40:15 +01:00
|
|
|
onClicked: root.openSendModal(d.visibleAddress)
|
|
|
|
},
|
2022-09-05 11:15:47 +02:00
|
|
|
StatusRoundButton {
|
2023-03-06 15:30:58 +03:00
|
|
|
objectName: "savedAddressView_Delegate_menuButton_" + root.name
|
2022-09-05 11:15:47 +02:00
|
|
|
visible: !!root.name
|
2024-01-10 09:40:15 +01:00
|
|
|
enabled: root.showButtons
|
2023-02-20 13:57:45 +03:00
|
|
|
type: StatusRoundButton.Type.Quinary
|
|
|
|
radius: 8
|
2022-09-05 11:15:47 +02:00
|
|
|
icon.name: "more"
|
|
|
|
onClicked: {
|
2024-01-09 14:50:01 +01:00
|
|
|
menu.openMenu(this, x + width - menu.width - statusListItemComponentsSlot.spacing, y + height + Style.current.halfPadding,
|
2023-03-13 14:51:57 +03:00
|
|
|
{
|
|
|
|
name: root.name,
|
|
|
|
address: root.address,
|
|
|
|
chainShortNames: root.chainShortNames,
|
|
|
|
ens: root.ens,
|
2023-12-29 14:10:55 +01:00
|
|
|
colorId: root.colorId,
|
2023-03-13 14:51:57 +03:00
|
|
|
}
|
|
|
|
);
|
2022-09-05 11:15:47 +02:00
|
|
|
}
|
2023-03-13 14:51:57 +03:00
|
|
|
|
2022-09-05 11:15:47 +02:00
|
|
|
}
|
|
|
|
]
|
|
|
|
|
2022-12-01 19:58:37 +03:00
|
|
|
StatusMenu {
|
2024-01-05 11:57:15 +01:00
|
|
|
id: menu
|
|
|
|
property string name
|
|
|
|
property string address
|
|
|
|
property string chainShortNames
|
|
|
|
property string ens
|
2023-12-29 14:10:55 +01:00
|
|
|
property string colorId
|
2023-03-13 14:51:57 +03:00
|
|
|
|
|
|
|
readonly property int maxHeight: 341
|
|
|
|
height: implicitHeight > maxHeight ? maxHeight : implicitHeight
|
|
|
|
contentWidth: 216
|
|
|
|
|
|
|
|
function openMenu(parent, x, y, model) {
|
2024-01-05 11:57:15 +01:00
|
|
|
menu.name = model.name;
|
|
|
|
menu.address = model.address;
|
|
|
|
menu.chainShortNames = model.chainShortNames;
|
|
|
|
menu.ens = model.ens;
|
|
|
|
menu.colorId = model.colorId;
|
2023-03-13 14:51:57 +03:00
|
|
|
popup(parent, x, y);
|
2022-09-05 11:15:47 +02:00
|
|
|
}
|
|
|
|
onClosed: {
|
2024-01-05 11:57:15 +01:00
|
|
|
menu.name = "";
|
|
|
|
menu.address = "";
|
|
|
|
menu.chainShortNames = ""
|
|
|
|
menu.ens = ""
|
|
|
|
menu.colorId = ""
|
2022-09-05 11:15:47 +02:00
|
|
|
}
|
2024-01-16 08:50:25 +01:00
|
|
|
|
2022-12-01 19:58:37 +03:00
|
|
|
StatusAction {
|
2023-12-29 16:40:14 +01:00
|
|
|
text: qsTr("Edit saved address")
|
2024-01-04 16:53:04 +01:00
|
|
|
objectName: "editSavedAddress"
|
2022-09-05 11:15:47 +02:00
|
|
|
assetSettings.name: "pencil-outline"
|
|
|
|
onTriggered: {
|
2024-02-19 09:40:16 +01:00
|
|
|
if (root.usage === SavedAddressesDelegate.Usage.Item) {
|
|
|
|
root.aboutToOpenPopup()
|
|
|
|
}
|
2023-12-26 11:19:41 +01:00
|
|
|
Global.openAddEditSavedAddressesPopup({
|
|
|
|
edit: true,
|
2024-01-05 11:57:15 +01:00
|
|
|
address: menu.address,
|
|
|
|
name: menu.name,
|
|
|
|
chainShortNames: menu.chainShortNames,
|
|
|
|
ens: menu.ens,
|
|
|
|
colorId: menu.colorId
|
2023-12-26 11:19:41 +01:00
|
|
|
})
|
2022-09-05 11:15:47 +02:00
|
|
|
}
|
|
|
|
}
|
2024-01-16 08:50:25 +01:00
|
|
|
|
2024-01-10 10:47:29 +01:00
|
|
|
StatusSuccessAction {
|
|
|
|
id: copyAddressAction
|
2023-02-20 13:57:45 +03:00
|
|
|
objectName: "copySavedAddressAction"
|
2024-01-10 10:47:29 +01:00
|
|
|
successText: qsTr("Address copied")
|
|
|
|
text: qsTr("Copy address")
|
|
|
|
icon.name: "copy"
|
|
|
|
timeout: 1500
|
|
|
|
autoDismissMenu: true
|
2023-02-20 13:57:45 +03:00
|
|
|
onTriggered: {
|
2024-01-10 10:47:29 +01:00
|
|
|
store.copyToClipboard(d.visibleAddress)
|
2023-02-20 13:57:45 +03:00
|
|
|
}
|
|
|
|
}
|
2024-01-16 08:50:25 +01:00
|
|
|
|
2023-12-29 16:40:14 +01:00
|
|
|
StatusAction {
|
|
|
|
text: qsTr("Show address QR")
|
|
|
|
objectName: "showQrSavedAddressAction"
|
|
|
|
assetSettings.name: "qr"
|
|
|
|
onTriggered: {
|
2024-02-19 09:40:16 +01:00
|
|
|
if (root.usage === SavedAddressesDelegate.Usage.Item) {
|
|
|
|
root.aboutToOpenPopup()
|
|
|
|
}
|
2024-01-15 10:20:52 +01:00
|
|
|
Global.openShowQRPopup({
|
|
|
|
showSingleAccount: true,
|
|
|
|
showForSavedAddress: true,
|
|
|
|
switchingAccounsEnabled: false,
|
|
|
|
changingPreferredChainsEnabled: true,
|
|
|
|
hasFloatingButtons: true,
|
|
|
|
name: menu.name,
|
|
|
|
address: menu.address,
|
|
|
|
colorId: menu.colorId,
|
|
|
|
preferredSharingChainIds: RootStore.getNetworkIds(menu.chainShortNames)
|
|
|
|
})
|
2023-12-29 16:40:14 +01:00
|
|
|
}
|
|
|
|
}
|
2024-01-15 13:27:47 +01:00
|
|
|
|
2024-01-16 08:50:25 +01:00
|
|
|
StatusAction {
|
|
|
|
text: qsTr("View activity")
|
|
|
|
objectName: "viewActivitySavedAddressAction"
|
|
|
|
assetSettings.name: "wallet"
|
|
|
|
onTriggered: {
|
2024-02-19 09:40:16 +01:00
|
|
|
if (root.usage === SavedAddressesDelegate.Usage.Item) {
|
|
|
|
root.aboutToOpenPopup()
|
|
|
|
}
|
2024-01-16 08:50:25 +01:00
|
|
|
Global.changeAppSectionBySectionType(Constants.appSection.wallet,
|
|
|
|
WalletLayout.LeftPanelSelection.AllAddresses,
|
|
|
|
WalletLayout.RightPanelSelection.Activity,
|
|
|
|
{savedAddress: menu.address})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 13:27:47 +01:00
|
|
|
StatusMenuSeparator {
|
|
|
|
visible: d.preferredSharedNetworkNamesArray.length > 0
|
|
|
|
}
|
2023-07-03 11:23:26 +02:00
|
|
|
|
2023-02-20 13:57:45 +03:00
|
|
|
StatusAction {
|
2024-01-15 13:27:47 +01:00
|
|
|
text: Utils.getActionNameForDisplayingAddressOnNetwork(Constants.networkShortChainNames.mainnet)
|
|
|
|
enabled: d.preferredSharedNetworkNamesArray.includes(Constants.networkShortChainNames.mainnet)
|
|
|
|
icon.name: "link"
|
2023-02-20 13:57:45 +03:00
|
|
|
onTriggered: {
|
2024-02-20 10:31:04 +01:00
|
|
|
let link = Utils.getUrlForAddressOnNetwork(Constants.networkShortChainNames.mainnet, root.areTestNetworksEnabled, root.isGoerliEnabled, d.visibleAddress ? d.visibleAddress : root.ens)
|
2024-01-15 13:27:47 +01:00
|
|
|
Global.openLink(link)
|
2023-02-20 13:57:45 +03:00
|
|
|
}
|
|
|
|
}
|
2023-07-03 11:23:26 +02:00
|
|
|
|
2023-03-13 14:51:57 +03:00
|
|
|
StatusAction {
|
2024-01-15 13:27:47 +01:00
|
|
|
text: Utils.getActionNameForDisplayingAddressOnNetwork(Constants.networkShortChainNames.arbiscan)
|
|
|
|
enabled: d.preferredSharedNetworkNamesArray.includes(Constants.networkShortChainNames.arbiscan)
|
|
|
|
icon.name: "link"
|
2023-03-13 14:51:57 +03:00
|
|
|
onTriggered: {
|
2024-02-20 10:31:04 +01:00
|
|
|
let link = Utils.getUrlForAddressOnNetwork(Constants.networkShortChainNames.arbiscan, root.areTestNetworksEnabled, root.isGoerliEnabled, d.visibleAddress ? d.visibleAddress : root.ens)
|
2024-01-15 13:27:47 +01:00
|
|
|
Global.openLink(link)
|
2023-03-13 14:51:57 +03:00
|
|
|
}
|
|
|
|
}
|
2024-01-15 13:27:47 +01:00
|
|
|
|
2023-03-13 14:51:57 +03:00
|
|
|
StatusAction {
|
2024-01-15 13:27:47 +01:00
|
|
|
text: Utils.getActionNameForDisplayingAddressOnNetwork(Constants.networkShortChainNames.optimism)
|
|
|
|
enabled: d.preferredSharedNetworkNamesArray.includes(Constants.networkShortChainNames.optimism)
|
|
|
|
icon.name: "link"
|
2023-03-13 14:51:57 +03:00
|
|
|
onTriggered: {
|
2024-02-20 10:31:04 +01:00
|
|
|
let link = Utils.getUrlForAddressOnNetwork(Constants.networkShortChainNames.optimism, root.areTestNetworksEnabled, root.isGoerliEnabled, d.visibleAddress ? d.visibleAddress : root.ens)
|
2024-01-15 13:27:47 +01:00
|
|
|
Global.openLink(link)
|
2023-03-13 14:51:57 +03:00
|
|
|
}
|
|
|
|
}
|
2024-01-15 13:27:47 +01:00
|
|
|
|
2022-09-05 11:15:47 +02:00
|
|
|
StatusMenuSeparator { }
|
2024-01-15 13:27:47 +01:00
|
|
|
|
2022-12-01 19:58:37 +03:00
|
|
|
StatusAction {
|
2023-12-29 16:40:14 +01:00
|
|
|
text: qsTr("Remove saved address")
|
2022-12-01 19:58:37 +03:00
|
|
|
type: StatusAction.Type.Danger
|
2022-09-05 11:15:47 +02:00
|
|
|
assetSettings.name: "delete"
|
|
|
|
objectName: "deleteSavedAddress"
|
|
|
|
onTriggered: {
|
2024-02-19 09:40:16 +01:00
|
|
|
if (root.usage === SavedAddressesDelegate.Usage.Item) {
|
|
|
|
root.aboutToOpenPopup()
|
|
|
|
}
|
2023-12-26 11:19:41 +01:00
|
|
|
Global.openDeleteSavedAddressesPopup({
|
2024-01-05 11:57:15 +01:00
|
|
|
name: menu.name,
|
|
|
|
address: menu.address,
|
|
|
|
ens: menu.ens,
|
|
|
|
colorId: menu.colorId,
|
|
|
|
chainShortNames: menu.chainShortNames
|
2023-12-26 11:19:41 +01:00
|
|
|
})
|
2022-09-05 11:15:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|