2023-04-26 17:53:49 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
|
2024-06-12 11:52:11 +03:00
|
|
|
import StatusQ 0.1
|
2023-04-26 17:53:49 +02:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
2023-07-21 10:41:24 +02:00
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
2023-04-26 17:53:49 +02:00
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
import "../stores/NetworkSelectPopup"
|
|
|
|
import "../controls"
|
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
StatusListView {
|
2023-04-26 17:53:49 +02:00
|
|
|
id: root
|
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
required property var flatNetworks
|
2023-04-26 17:53:49 +02:00
|
|
|
property bool useEnabledRole: true
|
|
|
|
property SingleSelectionInfo singleSelection: SingleSelectionInfo {}
|
2023-07-21 10:41:24 +02:00
|
|
|
property var preferredSharingNetworks: []
|
|
|
|
property bool preferredNetworksMode: false
|
2024-05-13 22:25:18 +02:00
|
|
|
property bool showCheckboxes: true
|
2024-06-06 11:49:13 +02:00
|
|
|
property bool showRadioButtons: true
|
2023-04-26 17:53:49 +02:00
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
signal toggleNetwork(var network, int index)
|
|
|
|
|
2024-06-12 11:52:11 +03:00
|
|
|
/// Mirrors Nim's UxEnabledState enum from networks/item.nim
|
|
|
|
enum UxEnabledState {
|
|
|
|
Enabled,
|
|
|
|
AllEnabled,
|
|
|
|
Disabled
|
|
|
|
}
|
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
model: root.flatNetworks
|
|
|
|
|
|
|
|
delegate: NetworkSelectItemDelegate {
|
2024-06-12 11:52:11 +03:00
|
|
|
id: delegateItem
|
|
|
|
|
|
|
|
required property var model
|
|
|
|
readonly property int multiSelectCheckState: {
|
|
|
|
if(root.preferredNetworksMode) {
|
|
|
|
return root.preferredSharingNetworks.length === root.count ?
|
|
|
|
Qt.PartiallyChecked :
|
|
|
|
root.preferredSharingNetworks.includes(model.chainId.toString()) ? Qt.Checked : Qt.Unchecked
|
|
|
|
}
|
|
|
|
else if(root.useEnabledRole) {
|
|
|
|
return model.isEnabled ? Qt.Checked : Qt.Unchecked
|
|
|
|
} else if (model.enabledState === NetworkSelectionView.UxEnabledState.Enabled) {
|
|
|
|
return Qt.Checked
|
|
|
|
} else {
|
|
|
|
if( model.enabledState === NetworkSelectionView.UxEnabledState.AllEnabled) {
|
|
|
|
return Qt.PartiallyChecked
|
|
|
|
} else {
|
|
|
|
return Qt.Unchecked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
readonly property int singleSelectCheckState: {
|
|
|
|
if (root.singleSelection.currentModel === root.model && root.singleSelection.currentIndex === model.index)
|
|
|
|
return Qt.Checked
|
|
|
|
return Qt.Unchecked
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
implicitHeight: 48
|
|
|
|
implicitWidth: root.width
|
2024-06-12 11:52:11 +03:00
|
|
|
title: model.chainName
|
|
|
|
iconUrl: Style.svg(model.iconUrl)
|
|
|
|
showIndicator: (multiSelection && root.showCheckboxes) || (!multiSelection && root.showRadioButtons)
|
|
|
|
multiSelection: !root.singleSelection.enabled
|
|
|
|
|
|
|
|
Binding on checkState {
|
|
|
|
when: root.singleSelection.enabled
|
|
|
|
value: singleSelectCheckState
|
|
|
|
}
|
|
|
|
|
|
|
|
Binding on checkState {
|
|
|
|
when: !root.singleSelection.enabled
|
|
|
|
value: multiSelectCheckState
|
|
|
|
}
|
|
|
|
|
|
|
|
nextCheckState: checkState
|
|
|
|
onToggled: {
|
|
|
|
if(!root.singleSelection.enabled) {
|
|
|
|
Qt.callLater(root.toggleNetwork, delegateItem.model, delegateItem.model.index)
|
|
|
|
} else if(!checkState !== Qt.Checked) { // Don't allow uncheck
|
|
|
|
checkState = checkState === Qt.Checked ? Qt.Unchecked : Qt.Checked
|
|
|
|
root.toggleNetwork(delegateItem.model, model.index)
|
|
|
|
}
|
|
|
|
}
|
2024-03-13 18:38:16 +01:00
|
|
|
}
|
2023-04-26 17:53:49 +02:00
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
section {
|
|
|
|
property: "layer"
|
|
|
|
delegate: Loader {
|
|
|
|
required property int section
|
2023-04-26 17:53:49 +02:00
|
|
|
width: parent.width
|
2024-03-13 18:38:16 +01:00
|
|
|
sourceComponent: section === 2 ? layer2text: null
|
|
|
|
|
|
|
|
Component {
|
|
|
|
id: layer2text
|
|
|
|
StatusBaseText {
|
|
|
|
width: parent.width
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
text: qsTr("Layer 2")
|
|
|
|
height: 40
|
|
|
|
leftPadding: 16
|
|
|
|
topPadding: 10
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
}
|
2023-04-26 17:53:49 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|