import QtQuick 2.13 import QtQuick.Controls 2.13 import QtQuick.Layouts 1.13 import "../../../../imports" import "../../../../shared" import "../../../../shared/status" Item { id: syncContainer Layout.fillHeight: true Layout.fillWidth: true StyledText { id: element4 //% "Sync settings" text: qsTrId("sync-settings") anchors.left: parent.left anchors.leftMargin: 24 anchors.top: parent.top anchors.topMargin: 24 font.weight: Font.Bold font.pixelSize: 20 } Component { id: mailserversList StatusRadioButton { text: name checked: name == profileModel.mailservers.activeMailserver onClicked: { if (checked) { profileModel.mailservers.setMailserver(name); } } } } Item { id: addMailserver width: parent.width height: addButton.height anchors.top: element4.bottom anchors.topMargin: Style.current.padding anchors.left: parent.left anchors.leftMargin: 24 StatusRoundButton { id: addButton icon.name: "plusSign" size: "medium" anchors.verticalCenter: parent.verticalCenter } StyledText { id: usernameText text: qsTr("Add mailserver") color: Style.current.blue anchors.left: addButton.right anchors.leftMargin: Style.current.padding anchors.verticalCenter: addButton.verticalCenter font.pixelSize: 15 } MouseArea { anchors.fill: parent cursorShape: Qt.PointingHandCursor onClicked: addMailserverPopup.open() } ModalPopup { id: addMailserverPopup title: qsTr("Add mailserver") property string nameValidationError: "" property string enodeValidationError: "" function validate() { nameValidationError = "" enodeValidationError = "" if (nameInput.text === "") { nameValidationError = qsTr("You need to enter a name") } if (enodeInput.text === "") { enodeValidationError = qsTr("You need to enter the enode address") } return !nameValidationError && !enodeValidationError } onOpened: { nameInput.text = ""; enodeInput.text = ""; nameValidationError = ""; enodeValidationError = ""; } footer: StatusButton { anchors.right: parent.right anchors.rightMargin: Style.current.smallPadding text: qsTr("Save") anchors.bottom: parent.bottom enabled: nameInput.text !== "" && enodeInput.text !== "" onClicked: { if (!addMailserverPopup.validate()) { return; } profileModel.mailservers.save(nameInput.text, enodeInput.text) addMailserverPopup.close() } } Input { id: nameInput label: qsTr("Name") placeholderText: qsTr("Specify a name") validationError: addMailserverPopup.nameValidationError } Input { id: enodeInput label: qsTr("History node address") placeholderText: qsTr("enode://{enode-id}:{password}@{ip-address}:{port-number}") validationError: addMailserverPopup.enodeValidationError anchors.top: nameInput.bottom anchors.topMargin: Style.current.bigPadding } } } StyledText { id: switchLbl text: qsTr("Automatic mailserver selection") anchors.left: parent.left anchors.leftMargin: 24 anchors.top: addMailserver.bottom anchors.topMargin: 24 } StatusSwitch { id: automaticSelectionSwitch checked: profileModel.mailservers.automaticSelection onCheckedChanged: profileModel.mailservers.enableAutomaticSelection(checked) anchors.top: addMailserver.bottom anchors.topMargin: Style.current.padding anchors.left: switchLbl.right anchors.leftMargin: Style.current.padding } StyledText { text: profileModel.mailservers.activeMailserver || qsTr("...") anchors.left: parent.left anchors.leftMargin: 24 anchors.top: switchLbl.bottom anchors.topMargin: 24 visible: automaticSelectionSwitch.checked } ListView { id: mailServersListView anchors.topMargin: 200 anchors.top: automaticSelectionSwitch.bottom anchors.fill: parent model: profileModel.mailservers.list delegate: mailserversList visible: !automaticSelectionSwitch.checked } }