2021-09-02 20:49:15 +03:00
|
|
|
import QtQuick 2.13
|
|
|
|
|
|
|
|
import "../../../../imports"
|
2021-09-14 19:23:02 +03:00
|
|
|
import "../panels"
|
|
|
|
import "../controls"
|
2021-09-02 20:49:15 +03:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Controls.Validators 0.1
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: root
|
|
|
|
visible: (opacity > 0.1)
|
|
|
|
property bool searching: false
|
|
|
|
property alias activeAccountsList: activeAccountsView
|
|
|
|
property Timer timer: Timer {
|
|
|
|
interval: 800
|
|
|
|
onTriggered: {
|
|
|
|
searching = false;
|
|
|
|
}
|
|
|
|
}
|
2021-09-14 19:23:02 +03:00
|
|
|
property var store
|
2021-09-02 20:49:15 +03:00
|
|
|
property var dummyModel: []
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: searchingColumn
|
|
|
|
width: parent.width
|
|
|
|
height: 80
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
spacing: 15
|
|
|
|
StatusLoadingIndicator {
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
color: Theme.palette.primaryColor1
|
|
|
|
}
|
|
|
|
StatusBaseText {
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
font.pixelSize: 15
|
|
|
|
text: qsTr("Searching for active accounts")
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ListView {
|
|
|
|
id: activeAccountsView
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.bottomMargin: 10
|
|
|
|
clip: true
|
|
|
|
//TODO replace with active accounts model
|
2021-09-14 19:23:02 +03:00
|
|
|
model: root.store.walletModelInst.accountsView.accounts
|
2021-09-02 20:49:15 +03:00
|
|
|
delegate: SeedAccountDetailsDelegate {
|
|
|
|
deleteButtonVisible: (activeAccountsView.count > 1)
|
2021-09-14 19:23:02 +03:00
|
|
|
onDeleteClicked: {
|
|
|
|
root.store.deleteAccount(address);
|
|
|
|
}
|
2021-09-02 20:49:15 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-14 19:23:02 +03:00
|
|
|
AccountNotFoundPanel {
|
2021-09-02 20:49:15 +03:00
|
|
|
id: accountNotFound
|
|
|
|
width: parent.width
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
}
|
|
|
|
|
|
|
|
states: [
|
|
|
|
State {
|
|
|
|
when: searching
|
|
|
|
PropertyChanges {
|
|
|
|
target: searchingColumn
|
|
|
|
opacity: 1.0
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: activeAccountsView
|
|
|
|
opacity: 0.0
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: accountNotFound
|
|
|
|
opacity: 0.0
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
when: !searching
|
|
|
|
PropertyChanges {
|
|
|
|
target: searchingColumn
|
|
|
|
opacity: 0.0
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: activeAccountsView
|
|
|
|
opacity: 1.0
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: accountNotFound
|
|
|
|
opacity: 0.0
|
|
|
|
}
|
|
|
|
},
|
|
|
|
State {
|
|
|
|
when: (activeAccountsView.count === 0 && !searching)
|
|
|
|
PropertyChanges {
|
|
|
|
target: searchingColumn
|
|
|
|
opacity: 0.0
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: activeAccountsView
|
|
|
|
opacity: 0.0
|
|
|
|
}
|
|
|
|
PropertyChanges {
|
|
|
|
target: accountNotFound
|
|
|
|
opacity: 1.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|