2022-02-11 10:44:49 +01:00
|
|
|
import QtQuick 2.13
|
2023-04-17 13:36:40 +02:00
|
|
|
import SortFilterProxyModel 0.2
|
2022-02-11 10:44:49 +01:00
|
|
|
|
2022-03-01 11:08:15 +01:00
|
|
|
import utils 1.0
|
2022-02-11 10:44:49 +01:00
|
|
|
import shared.status 1.0
|
2022-03-01 11:08:15 +01:00
|
|
|
import shared.panels 1.0
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Core 0.1
|
2022-03-15 15:59:58 +01:00
|
|
|
import StatusQ.Components 0.1
|
2022-02-11 10:44:49 +01:00
|
|
|
|
|
|
|
import "../../stores"
|
2022-03-01 15:40:53 +01:00
|
|
|
import "../../controls"
|
2022-03-02 15:24:39 +01:00
|
|
|
import "../../popups"
|
2022-02-11 10:44:49 +01:00
|
|
|
|
|
|
|
Column {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property WalletStore walletStore
|
|
|
|
|
|
|
|
signal goToNetworksView()
|
2023-04-17 13:36:40 +02:00
|
|
|
signal goToAccountView(var account)
|
2022-03-04 10:09:58 +01:00
|
|
|
signal goToDappPermissionsView()
|
2022-03-01 11:08:15 +01:00
|
|
|
|
2023-03-10 15:36:27 -05:00
|
|
|
Component.onCompleted: {
|
|
|
|
// TODO remove this call and handle it from the backend
|
|
|
|
// once the profile is refactored and the navigation is driven from the backend
|
|
|
|
root.walletStore.loadDapps()
|
|
|
|
}
|
|
|
|
|
2022-03-01 11:08:15 +01:00
|
|
|
Separator {
|
|
|
|
height: 17
|
|
|
|
}
|
|
|
|
|
2022-03-15 15:59:58 +01:00
|
|
|
StatusListItem {
|
|
|
|
title: qsTr("DApp Permissions")
|
2022-03-01 11:08:15 +01:00
|
|
|
height: 64
|
2022-03-15 15:59:58 +01:00
|
|
|
width: parent.width
|
2022-03-04 10:09:58 +01:00
|
|
|
onClicked: goToDappPermissionsView()
|
2022-08-07 23:20:11 +03:00
|
|
|
label: qsTr("%n DApp(s) connected", "", root.walletStore.dappList.count)
|
2022-03-15 15:59:58 +01:00
|
|
|
components: [
|
|
|
|
StatusIcon {
|
2023-04-25 12:32:57 +02:00
|
|
|
icon: "next"
|
2022-03-15 15:59:58 +01:00
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
]
|
2022-03-01 11:08:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
height: 17
|
|
|
|
}
|
|
|
|
|
2022-03-15 15:59:58 +01:00
|
|
|
StatusListItem {
|
2022-07-21 14:15:02 +02:00
|
|
|
objectName: "networksItem"
|
2022-03-15 15:59:58 +01:00
|
|
|
title: qsTr("Networks")
|
2022-03-01 11:08:15 +01:00
|
|
|
height: 64
|
2022-03-15 15:59:58 +01:00
|
|
|
width: parent.width
|
2022-02-11 10:44:49 +01:00
|
|
|
onClicked: goToNetworksView()
|
2022-03-15 15:59:58 +01:00
|
|
|
components: [
|
|
|
|
StatusIcon {
|
2023-04-25 12:32:57 +02:00
|
|
|
icon: "next"
|
2022-03-15 15:59:58 +01:00
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
]
|
2022-02-11 10:44:49 +01:00
|
|
|
}
|
2022-03-01 11:08:15 +01:00
|
|
|
|
|
|
|
Separator {
|
|
|
|
height: 17
|
|
|
|
}
|
|
|
|
|
2022-03-15 15:59:58 +01:00
|
|
|
StatusDescriptionListItem {
|
|
|
|
height: 64
|
|
|
|
subTitle: qsTr("Accounts")
|
2022-03-01 11:08:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusSectionHeadline {
|
|
|
|
text: qsTr("Generated from Your Seed Phrase")
|
2022-03-15 15:59:58 +01:00
|
|
|
leftPadding: Style.current.padding
|
|
|
|
topPadding: Style.current.halfPadding
|
|
|
|
bottomPadding: Style.current.halfPadding/2
|
2022-03-01 11:08:15 +01:00
|
|
|
}
|
|
|
|
|
2022-07-20 10:18:27 +02:00
|
|
|
ListView {
|
|
|
|
width: parent.width
|
|
|
|
height: childrenRect.height
|
|
|
|
objectName: "generatedAccounts"
|
2023-04-17 13:36:40 +02:00
|
|
|
model: SortFilterProxyModel {
|
|
|
|
sourceModel: walletStore.accounts
|
|
|
|
filters: ExpressionFilter {
|
|
|
|
expression: {
|
|
|
|
return model.walletType === "generated" || model.walletType === ""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-03-01 15:40:53 +01:00
|
|
|
delegate: WalletAccountDelegate {
|
2023-04-18 18:05:24 +02:00
|
|
|
width: ListView.view.width
|
2022-03-01 15:40:53 +01:00
|
|
|
account: model
|
2022-03-07 10:33:38 +01:00
|
|
|
onGoToAccountView: {
|
2023-04-17 13:36:40 +02:00
|
|
|
root.goToAccountView(model)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SortFilterProxyModel {
|
|
|
|
id: importedAccounts
|
|
|
|
sourceModel: walletStore.accounts
|
|
|
|
filters: ExpressionFilter {
|
|
|
|
expression: {
|
|
|
|
return model.walletType !== "generated" && model.walletType !== "watch" && model.walletType !== ""
|
2022-03-07 10:33:38 +01:00
|
|
|
}
|
2022-03-01 15:40:53 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-01 11:08:15 +01:00
|
|
|
StatusSectionHeadline {
|
|
|
|
text: qsTr("Imported")
|
2022-03-15 15:59:58 +01:00
|
|
|
leftPadding: Style.current.padding
|
|
|
|
topPadding: Style.current.halfPadding
|
|
|
|
bottomPadding: Style.current.halfPadding/2
|
2023-04-17 13:36:40 +02:00
|
|
|
visible: importedAccounts.count > 0
|
2022-03-01 11:08:15 +01:00
|
|
|
}
|
|
|
|
|
2022-03-01 15:40:53 +01:00
|
|
|
Repeater {
|
2023-04-25 12:32:57 +02:00
|
|
|
width: parent.width
|
2023-04-17 13:36:40 +02:00
|
|
|
model: importedAccounts
|
2022-03-01 15:40:53 +01:00
|
|
|
delegate: WalletAccountDelegate {
|
2023-04-25 12:32:57 +02:00
|
|
|
width: parent.width
|
2022-03-01 15:40:53 +01:00
|
|
|
account: model
|
2022-03-07 10:33:38 +01:00
|
|
|
onGoToAccountView: {
|
2023-04-17 13:36:40 +02:00
|
|
|
root.goToAccountView(model)
|
2022-03-07 10:33:38 +01:00
|
|
|
}
|
2022-03-01 15:40:53 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-17 13:36:40 +02:00
|
|
|
SortFilterProxyModel {
|
|
|
|
id: watchOnlyAccounts
|
|
|
|
sourceModel: walletStore.accounts
|
|
|
|
filters: ValueFilter {
|
|
|
|
roleName: "walletType"
|
|
|
|
value: "watch"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-01 11:08:15 +01:00
|
|
|
StatusSectionHeadline {
|
|
|
|
text: qsTr("Watch-Only")
|
2022-03-15 15:59:58 +01:00
|
|
|
leftPadding: Style.current.padding
|
|
|
|
topPadding: Style.current.halfPadding
|
|
|
|
bottomPadding: Style.current.halfPadding/2
|
2023-04-17 13:36:40 +02:00
|
|
|
visible: watchOnlyAccounts.count > 0
|
2022-03-01 11:08:15 +01:00
|
|
|
}
|
2022-03-01 15:40:53 +01:00
|
|
|
|
|
|
|
Repeater {
|
2023-04-25 12:32:57 +02:00
|
|
|
width: parent.width
|
2023-04-17 13:36:40 +02:00
|
|
|
model: watchOnlyAccounts
|
2022-03-01 15:40:53 +01:00
|
|
|
delegate: WalletAccountDelegate {
|
2023-04-25 12:32:57 +02:00
|
|
|
width: parent.width
|
2022-03-01 15:40:53 +01:00
|
|
|
account: model
|
2022-03-07 10:33:38 +01:00
|
|
|
onGoToAccountView: {
|
2023-04-17 13:36:40 +02:00
|
|
|
root.goToAccountView(model)
|
2022-03-07 10:33:38 +01:00
|
|
|
}
|
2022-03-01 15:40:53 +01:00
|
|
|
}
|
|
|
|
}
|
2022-03-15 15:59:58 +01:00
|
|
|
|
2022-03-16 13:54:00 +01:00
|
|
|
// Adding padding to the end so that when the view is scrolled to the end there is some gap left
|
2022-03-15 15:59:58 +01:00
|
|
|
Item {
|
|
|
|
height: Style.current.bigPadding
|
|
|
|
width: parent.width
|
|
|
|
}
|
|
|
|
}
|