2022-08-31 19:09:07 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
import QtQml.Models 2.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1 as StatusQUtils
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
import shared.stores 1.0 as SharedStore
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property string keyPairPubKey: ""
|
|
|
|
property string keyPairName: ""
|
|
|
|
property string keyPairIcon: ""
|
|
|
|
property string keyPairImage: ""
|
|
|
|
property string keyPairDerivedFrom: ""
|
2022-12-16 10:37:08 +01:00
|
|
|
property var keyPairAccounts
|
2022-08-31 19:09:07 +02:00
|
|
|
|
2022-10-14 10:30:23 +02:00
|
|
|
color: Theme.palette.baseColor2
|
2022-08-31 19:09:07 +02:00
|
|
|
radius: Style.current.halfPadding
|
|
|
|
implicitWidth: 448
|
|
|
|
implicitHeight: 198
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
anchors.fill: parent
|
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
|
|
|
|
StatusListItem {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.preferredWidth: parent.width
|
|
|
|
color: "transparent"
|
|
|
|
title: root.keyPairName
|
|
|
|
|
2022-09-02 13:04:59 +02:00
|
|
|
asset {
|
2022-08-31 19:09:07 +02:00
|
|
|
width: 24
|
|
|
|
height: 24
|
|
|
|
name: root.keyPairIcon
|
|
|
|
color: Utils.colorForPubkey(root.keyPairPubKey)
|
2022-09-13 12:03:25 +02:00
|
|
|
letterSize: Math.max(4, asset.width / 2.4)
|
2022-08-31 19:09:07 +02:00
|
|
|
charactersLen: 2
|
|
|
|
isLetterIdenticon: false
|
2022-09-02 13:04:59 +02:00
|
|
|
bgColor: Theme.palette.primaryColor3
|
2022-08-31 19:09:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.preferredHeight: 1
|
|
|
|
color: Style.current.grey3
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
Layout.preferredWidth: parent.width - 2 * Style.current.padding
|
|
|
|
Layout.leftMargin: Style.current.padding
|
|
|
|
Layout.alignment: Qt.AlignLeft
|
|
|
|
text: qsTr("Active Accounts")
|
|
|
|
font.pixelSize: Constants.keycard.general.fontSize2
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
}
|
|
|
|
|
2022-12-27 14:20:58 +01:00
|
|
|
StatusListView {
|
2022-08-31 19:09:07 +02:00
|
|
|
id: accounts
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.preferredWidth: parent.width
|
|
|
|
Layout.bottomMargin: Style.current.padding
|
|
|
|
clip: true
|
|
|
|
spacing: Style.current.halfPadding * 0.5
|
2022-12-16 10:37:08 +01:00
|
|
|
model: root.keyPairAccounts
|
2022-08-31 19:09:07 +02:00
|
|
|
|
|
|
|
delegate: Rectangle {
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
width: parent.width - 2 * Style.current.padding
|
|
|
|
height: Style.current.xlPadding * 2
|
|
|
|
color: Theme.palette.statusModal.backgroundColor
|
|
|
|
radius: Style.current.halfPadding
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
anchors.rightMargin: Style.current.padding
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
Row {
|
|
|
|
spacing: 0
|
|
|
|
padding: 0
|
|
|
|
StatusBaseText {
|
|
|
|
id: address
|
2022-12-16 10:37:08 +01:00
|
|
|
text: StatusQUtils.Utils.elideText(model.account.address, 6, 4)
|
2022-08-31 19:09:07 +02:00
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
font.pixelSize: Constants.keycard.general.fontSize2
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusFlatRoundButton {
|
|
|
|
height: 20
|
|
|
|
width: 20
|
|
|
|
icon.name: "external"
|
|
|
|
icon.width: 16
|
|
|
|
icon.height: 16
|
|
|
|
onClicked: {
|
2022-12-16 10:37:08 +01:00
|
|
|
Qt.openUrlExternally("https://etherscan.io/address/%1".arg(model.account.address))
|
2022-08-31 19:09:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusBaseText {
|
2022-12-16 10:37:08 +01:00
|
|
|
text: model.account.path
|
2022-08-31 19:09:07 +02:00
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
font.pixelSize: Constants.keycard.general.fontSize2
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Item {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.preferredHeight: parent.height
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
Layout.alignment: Qt.AlignVCenter
|
|
|
|
text: {
|
|
|
|
if (Global.appMain) {
|
|
|
|
return "%1%2".arg(SharedStore.RootStore.currencyStore.currentCurrencySymbol)
|
2022-12-16 10:37:08 +01:00
|
|
|
.arg(Utils.toLocaleString(model.account.balance.toFixed(2), appSettings.locale, {"model.account.currency": true}))
|
2022-08-31 19:09:07 +02:00
|
|
|
}
|
|
|
|
// without language/model refactor no way to read currency symbol or `appSettings.locale` before user logs in
|
2022-12-16 10:37:08 +01:00
|
|
|
return "$%1".arg(Utils.toLocaleString(model.account.balance.toFixed(2), localAppSettings.language, {"model.account.currency": true}))
|
2022-08-31 19:09:07 +02:00
|
|
|
}
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
font.pixelSize: Constants.keycard.general.fontSize2
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|