import QtQuick 2.12 import QtQuick.Controls 2.3 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 import StatusQ.Popups 0.1 import "." import utils 1.0 import shared 1.0 import shared.panels 1.0 import shared.popups 1.0 import shared.status 1.0 import shared.controls 1.0 StatusModal { id: root anchors.centerIn: parent height: 560 padding: 8 headerSettings.title: qsTr("History Nodes") property var messagingStore property var advancedStore property string nameValidationError: "" property string enodeValidationError: "" onClosed: { destroy() } StatusScrollView { id: scrollView anchors.fill: parent contentWidth: availableWidth Column { id: nodesColumn width: scrollView.availableWidth StatusListItem { width: parent.width title: qsTr("Use Waku nodes") components: [ StatusSwitch { checked: root.messagingStore.useMailservers onCheckedChanged: root.messagingStore.toggleUseMailservers(checked) } ] onClicked: { root.messagingStore.toggleUseMailservers(!root.messagingStore.useMailservers) } } Separator { width: parent.width } StatusListItem { width: parent.width title: qsTr("Select node automatically") components: [ StatusSwitch { id: automaticSelectionSwitch checked: root.messagingStore.automaticMailserverSelection onCheckedChanged: root.messagingStore.enableAutomaticMailserverSelection(checked) } ] onClicked: { automaticSelectionSwitch.checked = !automaticSelectionSwitch.checked } } StatusSectionHeadline { text: qsTr("Waku Nodes") visible: !automaticSelectionSwitch.checked width: parent.width height: visible ? implicitHeight : 0 } ButtonGroup { id: nodesButtonGroup } Repeater { id: mailServersListView model: root.messagingStore.mailservers delegate: Component { StatusListItem { title: qsTr("Node %1").arg(index + 1) subTitle: model.name visible: !automaticSelectionSwitch.checked height: visible ? implicitHeight : 0 components: [ StatusRadioButton { id: nodeRadioBtn ButtonGroup.group: nodesButtonGroup checked: model.name === root.messagingStore.pinnedMailserverId onCheckedChanged: { if (checked) { root.messagingStore.setPinnedMailserverId(model.name) } } } ] onClicked: { nodeRadioBtn.checked = true } } } } StatusBaseText { text: qsTr("Add a new node") color: Theme.palette.primaryColor1 width: parent.width MouseArea { anchors.fill: parent cursorShape: Qt.PointingHandCursor onClicked: Global.openPopup(wakuNodeModalComponent) } } } } Component { id: wakuNodeModalComponent AddWakuNodeModal { messagingStore: root.messagingStore advancedStore: root.advancedStore } } }