mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-26 14:32:01 +00:00
35a2dd5244
Also switched StatusModal to derive from StatusDialog instead of Popup type Closes #10149
139 lines
4.2 KiB
QML
139 lines
4.2 KiB
QML
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.nodeAddress === root.messagingStore.activeMailserver
|
|
onCheckedChanged: {
|
|
if (checked) {
|
|
root.messagingStore.setActiveMailserver(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
|
|
}
|
|
}
|
|
}
|