2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
import StatusQ 0.1
|
2022-07-19 15:17:35 +02:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
2022-08-03 14:51:47 +02:00
|
|
|
import StatusQ.Components 0.1
|
2022-07-19 15:17:35 +02:00
|
|
|
import StatusQ.Core.Theme 0.1
|
2023-04-26 17:53:49 +02:00
|
|
|
import StatusQ.Core.Utils 0.1 as StatusQUtils
|
2024-04-10 22:56:10 +02:00
|
|
|
import StatusQ.Popups 0.1
|
2022-07-19 15:17:35 +02:00
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
2024-05-01 18:15:42 +02:00
|
|
|
import shared.popups.walletconnect 1.0
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-05 22:50:22 +02:00
|
|
|
|
|
|
|
import "../controls"
|
2020-05-28 09:49:28 -04:00
|
|
|
|
|
|
|
Item {
|
2022-07-19 15:17:35 +02:00
|
|
|
id: root
|
2021-10-05 22:50:22 +02:00
|
|
|
|
2023-03-15 10:17:25 +01:00
|
|
|
property var networkConnectionStore
|
2023-04-13 11:59:17 +02:00
|
|
|
property var overview
|
2022-01-31 14:29:27 +01:00
|
|
|
property var store
|
2022-02-15 14:19:45 +01:00
|
|
|
property var walletStore
|
2020-06-03 15:59:18 -04:00
|
|
|
|
2023-12-26 11:19:41 +01:00
|
|
|
property alias headerButton: headerButton
|
|
|
|
property alias networkFilter: networkFilter
|
|
|
|
|
|
|
|
signal buttonClicked()
|
2023-04-26 17:53:49 +02:00
|
|
|
|
2022-09-13 19:17:54 +03:00
|
|
|
implicitHeight: 88
|
2020-05-28 09:49:28 -04:00
|
|
|
|
2022-07-19 15:17:35 +02:00
|
|
|
GridLayout {
|
|
|
|
width: parent.width
|
|
|
|
columns: 2
|
2023-04-26 17:53:49 +02:00
|
|
|
rowSpacing: 0
|
2020-05-28 09:49:28 -04:00
|
|
|
|
2022-07-19 15:17:35 +02:00
|
|
|
// account + balance
|
2022-09-13 19:17:54 +03:00
|
|
|
RowLayout {
|
2022-07-19 15:17:35 +02:00
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
StatusBaseText {
|
2023-12-26 16:27:53 +01:00
|
|
|
objectName: "walletHeaderTitle"
|
2022-09-13 19:17:54 +03:00
|
|
|
Layout.alignment: Qt.AlignVCenter
|
2023-04-26 17:53:49 +02:00
|
|
|
verticalAlignment: Text.AlignVCenter
|
2023-12-26 11:19:41 +01:00
|
|
|
color: {
|
|
|
|
if (root.walletStore.showSavedAddresses)
|
|
|
|
return Theme.palette.directColor1
|
|
|
|
|
|
|
|
return overview.isAllAccounts ? Theme.palette.directColor5 : Utils.getColorForId(overview.colorId)
|
|
|
|
}
|
2023-04-26 17:53:49 +02:00
|
|
|
lineHeightMode: Text.FixedHeight
|
|
|
|
lineHeight: 38
|
2022-07-19 15:17:35 +02:00
|
|
|
font.bold: true
|
2023-04-26 17:53:49 +02:00
|
|
|
font.pixelSize: 28
|
2023-12-26 11:19:41 +01:00
|
|
|
text: {
|
|
|
|
if (root.walletStore.showSavedAddresses)
|
|
|
|
return qsTr("Saved addresses")
|
|
|
|
|
|
|
|
return overview.isAllAccounts ? qsTr("All Accounts") : overview.name
|
|
|
|
}
|
2022-07-19 15:17:35 +02:00
|
|
|
}
|
2023-04-26 17:53:49 +02:00
|
|
|
StatusEmoji {
|
2022-09-13 19:17:54 +03:00
|
|
|
Layout.alignment: Qt.AlignVCenter
|
2023-04-26 17:53:49 +02:00
|
|
|
Layout.preferredWidth: 28
|
|
|
|
Layout.preferredHeight: 28
|
2023-12-26 11:19:41 +01:00
|
|
|
emojiId: !!root.overview && StatusQUtils.Emoji.iconId(root.overview.emoji ?? "", StatusQUtils.Emoji.size.big) || ""
|
|
|
|
visible: !root.walletStore.showSavedAddresses &&
|
|
|
|
!!root.overview && !root.overview.isAllAccounts
|
2022-07-19 15:17:35 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-28 09:49:28 -04:00
|
|
|
|
2023-04-26 17:53:49 +02:00
|
|
|
RowLayout {
|
|
|
|
spacing: 16
|
2022-07-19 15:17:35 +02:00
|
|
|
Layout.alignment: Qt.AlignTrailing
|
2023-04-26 17:53:49 +02:00
|
|
|
Layout.topMargin: 5
|
2023-04-05 14:10:44 +03:00
|
|
|
|
2024-04-10 22:56:10 +02:00
|
|
|
ConnectedDappsButton {
|
|
|
|
Layout.alignment: Qt.AlignTop
|
|
|
|
|
|
|
|
spacing: 8
|
2024-05-01 14:15:40 +02:00
|
|
|
visible: !root.walletStore.showSavedAddresses && Global.featureFlags.dappsEnabled
|
2024-04-10 22:56:10 +02:00
|
|
|
|
|
|
|
onConnectDapp: {
|
2024-05-01 18:15:42 +02:00
|
|
|
connectDappLoader.active = true
|
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: connectDappLoader
|
|
|
|
|
|
|
|
active: false
|
|
|
|
|
|
|
|
onLoaded: item.open()
|
|
|
|
|
|
|
|
sourceComponent: ConnectDappModal {
|
|
|
|
visible: true
|
|
|
|
|
|
|
|
onClosed: connectDappLoader.active = false
|
|
|
|
|
|
|
|
onPair: (uri) => {
|
|
|
|
this.close()
|
|
|
|
console.debug(`TODO(#14556): ConnectionRequestDappModal with ${uri}`)
|
|
|
|
}
|
|
|
|
}
|
2024-04-10 22:56:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-26 17:53:49 +02:00
|
|
|
StatusButton {
|
2023-12-26 11:19:41 +01:00
|
|
|
id: headerButton
|
2023-12-26 16:27:53 +01:00
|
|
|
objectName: "walletHeaderButton"
|
2023-04-26 17:53:49 +02:00
|
|
|
Layout.preferredHeight: 38
|
|
|
|
Layout.alignment: Qt.AlignTop
|
2023-03-08 14:44:47 +01:00
|
|
|
|
2023-04-26 17:53:49 +02:00
|
|
|
spacing: 8
|
|
|
|
size: StatusBaseButton.Size.Small
|
2023-12-26 11:19:41 +01:00
|
|
|
borderColor: root.walletStore.showSavedAddresses? "transparent" : Theme.palette.directColor7
|
|
|
|
normalColor: root.walletStore.showSavedAddresses? Theme.palette.primaryColor3 : Theme.palette.transparent
|
|
|
|
hoverColor: root.walletStore.showSavedAddresses? Theme.palette.primaryColor2 : Theme.palette.baseColor2
|
2023-04-26 17:53:49 +02:00
|
|
|
|
2023-12-26 11:19:41 +01:00
|
|
|
font.weight: root.walletStore.showSavedAddresses? Font.Medium : Font.Normal
|
2023-04-26 17:53:49 +02:00
|
|
|
textPosition: StatusBaseButton.TextPosition.Left
|
2023-12-26 11:19:41 +01:00
|
|
|
textColor: root.walletStore.showSavedAddresses? Theme.palette.primaryColor1 : Theme.palette.baseColor1
|
2023-04-26 17:53:49 +02:00
|
|
|
|
2023-12-26 11:19:41 +01:00
|
|
|
icon.name: root.walletStore.showSavedAddresses? "" : "invite-users"
|
2023-04-26 17:53:49 +02:00
|
|
|
icon.height: 16
|
|
|
|
icon.width: 16
|
|
|
|
icon.color: hovered ? Theme.palette.directColor1 : Theme.palette.baseColor1
|
2023-04-05 14:10:44 +03:00
|
|
|
}
|
2020-05-28 09:49:28 -04:00
|
|
|
|
2023-04-26 17:53:49 +02:00
|
|
|
// network filter
|
|
|
|
NetworkFilter {
|
|
|
|
id: networkFilter
|
|
|
|
|
|
|
|
Layout.alignment: Qt.AlignTop
|
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
flatNetworks: walletStore.filteredFlatModel
|
2023-04-26 17:53:49 +02:00
|
|
|
|
|
|
|
onToggleNetwork: (network) => {
|
|
|
|
walletStore.toggleNetwork(network.chainId)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
spacing: 4
|
2023-12-26 11:19:41 +01:00
|
|
|
visible: !root.walletStore.showSavedAddresses &&
|
|
|
|
!!root.networkConnectionStore &&
|
|
|
|
!networkConnectionStore.accountBalanceNotAvailable
|
2023-04-26 17:53:49 +02:00
|
|
|
StatusTextWithLoadingState {
|
|
|
|
font.pixelSize: 28
|
|
|
|
font.bold: true
|
|
|
|
customColor: Theme.palette.directColor1
|
2023-12-26 11:19:41 +01:00
|
|
|
text: loading ?
|
|
|
|
Constants.dummyText :
|
|
|
|
!!root.overview?
|
|
|
|
LocaleUtils.currencyAmountToLocaleString(root.overview.currencyBalance) : ""
|
|
|
|
loading: !!root.overview && root.overview.balanceLoading
|
2023-04-26 17:53:49 +02:00
|
|
|
lineHeightMode: Text.FixedHeight
|
|
|
|
lineHeight: 38
|
|
|
|
}
|
2022-07-19 15:17:35 +02:00
|
|
|
}
|
2022-02-15 14:19:45 +01:00
|
|
|
}
|
2022-07-19 15:17:35 +02:00
|
|
|
}
|