2020-06-17 15:18:31 -04:00
import QtQuick 2.13
import QtQuick . Controls 2.13
import QtQuick . Layouts 1.13
2020-11-03 17:04:57 -04:00
import QtGraphicalEffects 1.13
2021-09-28 18:04:06 +03:00
import utils 1.0
2021-10-28 00:27:49 +03:00
import shared 1.0
import shared . panels 1.0
import shared . popups 1.0
import shared . status 1.0
2020-05-27 17:28:25 -04:00
2021-12-30 13:39:47 +01:00
import "../stores"
2021-10-06 11:16:39 +02:00
import "../controls"
import "../popups"
import "../panels"
2022-05-07 13:45:15 +02:00
SettingsContentBase {
2021-10-06 11:16:39 +02:00
id: root
2021-12-09 14:28:02 +01:00
2021-12-30 13:39:47 +01:00
property AdvancedStore advancedStore
2021-12-14 19:47:32 +01:00
2021-08-06 14:25:51 +02:00
Item {
id: advancedContainer
2022-05-07 13:45:15 +02:00
width: root . contentWidth
2021-08-06 14:25:51 +02:00
height: generalColumn . height
2021-01-05 11:36:42 -05:00
2021-08-06 14:25:51 +02:00
Column {
id: generalColumn
anchors.top: parent . top
anchors.left: parent . left
2022-05-07 13:45:15 +02:00
width: root . contentWidth
2021-01-14 15:12:37 +01:00
2021-10-06 11:16:39 +02:00
// TODO: replace with StatusQ component
2021-08-06 14:25:51 +02:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-04-04 13:26:30 +02:00
text: qsTr ( "Fleet" )
2021-12-14 19:47:32 +01:00
currentValue: root . advancedStore . fleet
2021-08-06 14:25:51 +02:00
onClicked: fleetModal . open ( )
2021-02-22 18:10:47 -04:00
}
2021-10-06 11:16:39 +02:00
// TODO: replace with StatusQ component
2021-08-06 14:25:51 +02:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-04-04 13:26:30 +02:00
text: qsTr ( "Minimize on close" )
2021-08-06 14:25:51 +02:00
isSwitch: true
2021-10-20 11:50:50 +02:00
switchChecked: ! localAccountSensitiveSettings . quitOnClose
2021-08-06 14:25:51 +02:00
onClicked: function ( checked ) {
2021-10-20 11:50:50 +02:00
localAccountSensitiveSettings . quitOnClose = ! checked
2021-08-06 14:25:51 +02:00
}
}
2021-01-19 15:51:16 -05:00
2021-10-06 11:16:39 +02:00
// TODO: replace with StatusQ component
2021-09-14 11:17:35 -05:00
StyledText {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2021-09-14 11:17:35 -05:00
text: qsTr ( "Application Logs" )
font.pixelSize: 15
font.underline: mouseArea . containsMouse
color: Style . current . blue
topPadding: 23
MouseArea {
id: mouseArea
anchors.fill: parent
cursorShape: Qt . PointingHandCursor
hoverEnabled: true
onClicked: {
2021-12-14 19:47:32 +01:00
Qt . openUrlExternally ( root . advancedStore . logDir ( ) )
2021-09-14 11:17:35 -05:00
}
}
}
2021-08-06 14:25:51 +02:00
Item {
id: spacer1
height: Style . current . bigPadding
width: parent . width
}
2020-08-18 15:10:30 -04:00
2021-08-06 14:25:51 +02:00
Separator {
2022-05-07 13:45:15 +02:00
width: parent . width
2021-08-06 14:25:51 +02:00
}
2020-06-26 10:08:08 -04:00
2021-08-06 14:25:51 +02:00
StatusSectionHeadline {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2022-04-04 13:26:30 +02:00
text: qsTr ( "Experimental features" )
2021-08-06 14:25:51 +02:00
topPadding: Style . current . bigPadding
bottomPadding: Style . current . padding
2020-09-22 10:12:48 -05:00
}
2021-10-06 11:16:39 +02:00
// TODO: replace with StatusQ component
2021-08-06 14:25:51 +02:00
StatusSettingsLineButton {
2022-07-15 01:24:46 +01:00
id: wallet
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-04-04 13:26:30 +02:00
text: qsTr ( "Wallet" )
2022-07-15 01:24:46 +01:00
objectName: qsTr ( "WalletSettingsLineButton" )
2021-08-06 14:25:51 +02:00
isSwitch: true
2021-10-20 11:50:50 +02:00
switchChecked: localAccountSensitiveSettings . isWalletEnabled
2021-08-06 14:25:51 +02:00
onClicked: {
2021-10-20 11:50:50 +02:00
if ( ! localAccountSensitiveSettings . isWalletEnabled ) {
2021-12-24 09:24:26 +01:00
confirmationPopup . experimentalFeature = root . advancedStore . experimentalFeatures . wallet
2021-08-06 14:25:51 +02:00
confirmationPopup . open ( )
} else {
2021-12-24 09:24:26 +01:00
root . advancedStore . toggleExperimentalFeature ( root . advancedStore . experimentalFeatures . wallet )
2021-08-13 16:04:04 -04:00
}
}
}
2021-10-06 11:16:39 +02:00
// TODO: replace with StatusQ component
2021-08-06 14:25:51 +02:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-04-04 13:26:30 +02:00
text: qsTr ( "Dapp Browser" )
2021-08-06 14:25:51 +02:00
isSwitch: true
2021-10-20 11:50:50 +02:00
switchChecked: localAccountSensitiveSettings . isBrowserEnabled
2021-08-06 14:25:51 +02:00
onClicked: {
2021-10-20 11:50:50 +02:00
if ( ! localAccountSensitiveSettings . isBrowserEnabled ) {
2021-12-24 09:24:26 +01:00
confirmationPopup . experimentalFeature = root . advancedStore . experimentalFeatures . browser
2021-08-06 14:25:51 +02:00
confirmationPopup . open ( )
} else {
2021-12-24 09:24:26 +01:00
root . advancedStore . toggleExperimentalFeature ( root . advancedStore . experimentalFeatures . browser )
2021-08-06 14:25:51 +02:00
}
2021-04-23 13:22:07 +03:00
}
2021-01-14 15:12:37 +01:00
}
2020-11-23 15:14:48 -04:00
2022-04-08 12:41:35 +02:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-05-26 09:15:11 +02:00
text: qsTr ( "Community History Archive Protocol" )
2022-04-08 12:41:35 +02:00
isSwitch: true
switchChecked: root . advancedStore . isCommunityHistoryArchiveSupportEnabled
onClicked: {
if ( ! root . advancedStore . isCommunityHistoryArchiveSupportEnabled ) {
confirmationPopup . experimentalFeature = root . advancedStore . experimentalFeatures . communityHistoryArchiveSupport
confirmationPopup . open ( )
} else {
root . advancedStore . toggleExperimentalFeature ( root . advancedStore . experimentalFeatures . communityHistoryArchiveSupport )
}
}
}
2021-10-06 11:16:39 +02:00
// TODO: replace with StatusQ component
2021-08-06 14:25:51 +02:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-04-04 13:26:30 +02:00
text: qsTr ( "Node Management" )
2021-08-06 14:25:51 +02:00
isSwitch: true
2021-10-20 11:50:50 +02:00
switchChecked: localAccountSensitiveSettings . nodeManagementEnabled
2021-08-06 14:25:51 +02:00
onClicked: {
2021-10-20 11:50:50 +02:00
if ( ! localAccountSensitiveSettings . nodeManagementEnabled ) {
2021-12-24 09:24:26 +01:00
confirmationPopup . experimentalFeature = root . advancedStore . experimentalFeatures . nodeManagement
2021-08-06 14:25:51 +02:00
confirmationPopup . open ( )
} else {
2021-12-24 09:24:26 +01:00
root . advancedStore . toggleExperimentalFeature ( root . advancedStore . experimentalFeatures . nodeManagement )
2021-08-06 14:25:51 +02:00
}
}
2021-06-30 14:46:26 -04:00
}
2021-08-06 14:25:51 +02:00
StatusSectionHeadline {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2021-12-14 19:47:32 +01:00
visible: ! root . advancedStore . isWakuV2
2022-04-04 13:26:30 +02:00
text: qsTr ( "Bloom filter level" )
2021-08-06 14:25:51 +02:00
topPadding: Style . current . bigPadding
bottomPadding: Style . current . padding
}
2021-07-21 09:11:27 -04:00
2021-08-06 14:25:51 +02:00
Row {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2021-12-14 19:47:32 +01:00
visible: ! root . advancedStore . isWakuV2
2021-08-06 14:25:51 +02:00
spacing: 11
2021-07-12 08:10:12 -04:00
2021-08-06 14:25:51 +02:00
Component {
id: bloomConfirmationDialogComponent
ConfirmationDialog {
property string mode: "normal"
2021-07-12 08:10:12 -04:00
2021-08-06 14:25:51 +02:00
id: confirmDialog
2022-04-04 13:26:30 +02:00
header.title: qsTr ( "Warning!" )
confirmationText: qsTr ( "The account will be logged out. When you login again, the selected mode will be enabled" )
2021-08-06 14:25:51 +02:00
onConfirmButtonClicked: {
2021-12-14 19:47:32 +01:00
root . advancedStore . setBloomLevel ( mode )
2021-08-06 14:25:51 +02:00
}
onClosed: {
2021-12-14 19:47:32 +01:00
switch ( root . advancedStore . bloomLevel ) {
case "light" : btnBloomLight . click ( ) ; break ;
case "normal" : btnBloomNormal . click ( ) ; break ;
case "full" : btnBloomFull . click ( ) ; break ;
}
2021-08-06 14:25:51 +02:00
destroy ( )
2021-07-21 09:11:27 -04:00
}
2021-07-12 08:10:12 -04:00
}
}
2021-07-21 09:11:27 -04:00
2021-08-06 14:25:51 +02:00
ButtonGroup {
id: bloomGroup
}
2021-07-21 09:11:27 -04:00
2021-08-06 14:25:51 +02:00
BloomSelectorButton {
id: btnBloomLight
buttonGroup: bloomGroup
2021-12-14 19:47:32 +01:00
checkedByDefault: root . advancedStore . bloomLevel == "light"
2022-04-04 13:26:30 +02:00
btnText: qsTr ( "Light Node" )
2021-08-06 14:25:51 +02:00
onToggled: {
2021-12-14 19:47:32 +01:00
if ( root . advancedStore . bloomLevel != "light" ) {
2021-12-07 22:33:12 +02:00
Global . openPopup ( bloomConfirmationDialogComponent , { mode: "light" } )
2021-08-06 14:25:51 +02:00
} else {
btnBloomLight . click ( )
}
2021-07-21 09:11:27 -04:00
}
}
2021-08-06 14:25:51 +02:00
BloomSelectorButton {
id: btnBloomNormal
buttonGroup: bloomGroup
2021-12-14 19:47:32 +01:00
checkedByDefault: root . advancedStore . bloomLevel == "normal"
2022-04-04 13:26:30 +02:00
btnText: qsTr ( "Normal" )
2021-08-06 14:25:51 +02:00
onToggled: {
2021-12-14 19:47:32 +01:00
if ( root . advancedStore . bloomLevel != "normal" ) {
2021-12-07 22:33:12 +02:00
Global . openPopup ( bloomConfirmationDialogComponent , { mode: "normal" } )
2021-08-06 14:25:51 +02:00
} else {
btnBloomNormal . click ( )
}
2021-07-21 09:11:27 -04:00
}
}
2021-08-06 14:25:51 +02:00
BloomSelectorButton {
id: btnBloomFull
buttonGroup: bloomGroup
2021-12-14 19:47:32 +01:00
checkedByDefault: root . advancedStore . bloomLevel == "full"
2022-04-04 13:26:30 +02:00
btnText: qsTr ( "Full Node" )
2021-08-06 14:25:51 +02:00
onToggled: {
2021-12-14 19:47:32 +01:00
if ( root . advancedStore . bloomLevel != "full" ) {
2021-12-07 22:33:12 +02:00
Global . openPopup ( bloomConfirmationDialogComponent , { mode: "full" } )
2021-08-06 14:25:51 +02:00
} else {
btnBloomFull . click ( )
}
2021-07-21 09:11:27 -04:00
}
}
2021-08-09 17:23:44 +02:00
}
2021-09-06 18:31:10 -04:00
StatusSectionHeadline {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2021-12-14 19:47:32 +01:00
visible: root . advancedStore . isWakuV2
2021-09-06 18:31:10 -04:00
text: qsTr ( "WakuV2 mode" )
topPadding: Style . current . bigPadding
bottomPadding: Style . current . padding
}
Row {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2021-09-06 18:31:10 -04:00
spacing: 11
2021-12-14 19:47:32 +01:00
visible: root . advancedStore . isWakuV2
2021-09-06 18:31:10 -04:00
Component {
id: wakuV2ModeConfirmationDialogComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
2022-04-04 13:26:30 +02:00
confirmationText: qsTr ( "The account will be logged out. When you login again, the selected mode will be enabled" )
2021-09-06 18:31:10 -04:00
onConfirmButtonClicked: {
2021-12-14 19:47:32 +01:00
root . advancedStore . setWakuV2LightClientEnabled ( mode )
2021-09-06 18:31:10 -04:00
}
onClosed: {
2021-12-14 19:47:32 +01:00
if ( root . advancedStore . wakuV2LightClientEnabled ) {
2021-09-06 18:31:10 -04:00
btnWakuV2Light . click ( )
} else {
btnWakuV2Full . click ( ) ;
}
destroy ( )
}
}
}
ButtonGroup {
id: wakuV2Group
}
BloomSelectorButton {
id: btnWakuV2Light
buttonGroup: wakuV2Group
2021-12-14 19:47:32 +01:00
checkedByDefault: root . advancedStore . wakuV2LightClientEnabled
2022-04-04 13:26:30 +02:00
btnText: qsTr ( "Light Node" )
2021-09-06 18:31:10 -04:00
onToggled: {
2021-12-14 19:47:32 +01:00
if ( ! root . advancedStore . wakuV2LightClientEnabled ) {
2021-12-07 22:33:12 +02:00
Global . openPopup ( wakuV2ModeConfirmationDialogComponent , { mode: true } )
2021-09-06 18:31:10 -04:00
} else {
btnWakuV2Light . click ( )
}
}
}
BloomSelectorButton {
id: btnWakuV2Full
buttonGroup: wakuV2Group
2021-12-14 19:47:32 +01:00
checkedByDefault: ! root . advancedStore . wakuV2LightClientEnabled
2022-04-04 13:26:30 +02:00
btnText: qsTr ( "Full Node" )
2021-09-06 18:31:10 -04:00
onToggled: {
2021-12-14 19:47:32 +01:00
if ( root . advancedStore . wakuV2LightClientEnabled ) {
2021-12-07 22:33:12 +02:00
Global . openPopup ( wakuV2ModeConfirmationDialogComponent , { mode: false } )
2021-09-06 18:31:10 -04:00
} else {
btnWakuV2Full . click ( )
}
}
}
}
2022-05-07 13:45:15 +02:00
StatusSectionHeadline {
anchors.left: parent . left
anchors.right: parent . right
anchors.leftMargin: Style . current . padding
anchors.rightMargin: Style . current . padding
2022-02-02 17:06:23 -05:00
text: qsTr ( "Developer features" )
topPadding: Style . current . bigPadding
bottomPadding: Style . current . padding
}
Separator {
2022-05-07 13:45:15 +02:00
width: parent . width
2022-02-02 17:06:23 -05:00
}
2021-08-09 17:23:44 +02:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-02-02 17:06:23 -05:00
text: qsTr ( "Full developer mode" )
isEnabled: {
return ! localAccountSensitiveSettings . downloadChannelMessagesEnabled ||
! root . advancedStore . isTelemetryEnabled ||
! root . advancedStore . isDebugEnabled ||
! root . advancedStore . isAutoMessageEnabled
}
2021-08-09 17:23:44 +02:00
onClicked: {
2022-02-02 17:06:23 -05:00
Global . openPopup ( enableDeveloperFeaturesConfirmationDialogComponent )
2021-08-09 17:23:44 +02:00
}
}
2021-11-04 15:41:25 +01:00
2022-02-02 17:06:23 -05:00
Separator {
2022-05-07 13:45:15 +02:00
width: parent . width
2022-02-02 17:06:23 -05:00
}
2021-11-04 15:41:25 +01:00
// TODO: replace with StatusQ component
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-02-02 17:06:23 -05:00
text: qsTr ( "Download messages" )
2021-11-04 15:41:25 +01:00
isSwitch: true
2022-02-02 17:06:23 -05:00
switchChecked: localAccountSensitiveSettings . downloadChannelMessagesEnabled
2021-11-04 15:41:25 +01:00
onClicked: {
2022-02-02 17:06:23 -05:00
localAccountSensitiveSettings . downloadChannelMessagesEnabled = ! localAccountSensitiveSettings . downloadChannelMessagesEnabled
2021-11-04 15:41:25 +01:00
}
}
2021-11-11 12:22:03 -04:00
2021-11-24 15:20:05 +01:00
// TODO: replace with StatusQ component
2021-11-11 12:22:03 -04:00
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-02-02 17:06:23 -05:00
text: qsTr ( "Telemetry" )
2021-11-11 12:22:03 -04:00
isSwitch: true
2021-12-14 19:47:32 +01:00
switchChecked: root . advancedStore . isTelemetryEnabled
2021-11-11 12:22:03 -04:00
onClicked: {
2022-02-02 17:06:23 -05:00
Global . openPopup ( enableTelemetryConfirmationDialogComponent )
2021-11-11 12:22:03 -04:00
}
}
2021-11-24 15:20:05 +01:00
// TODO: replace with StatusQ component
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2021-12-07 22:33:12 +02:00
text: qsTr ( "Debug" )
2021-11-24 15:20:05 +01:00
isSwitch: true
2021-12-14 19:47:32 +01:00
switchChecked: root . advancedStore . isDebugEnabled
2021-11-24 15:20:05 +01:00
onClicked: {
2021-12-07 22:33:12 +02:00
Global . openPopup ( enableDebugComponent )
2021-12-07 10:31:21 +01:00
}
}
// TODO: replace with StatusQ component
StatusSettingsLineButton {
2022-05-07 13:45:15 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
2022-02-02 17:06:23 -05:00
text: qsTr ( "Auto message" )
2021-12-07 10:31:21 +01:00
isSwitch: true
2021-12-14 19:47:32 +01:00
switchChecked: root . advancedStore . isAutoMessageEnabled
2021-12-07 10:31:21 +01:00
onClicked: {
2022-02-02 17:06:23 -05:00
Global . openPopup ( enableAutoMessageConfirmationDialogComponent )
}
}
2021-08-06 14:25:51 +02:00
}
2020-08-25 11:00:03 +02:00
2021-08-06 14:25:51 +02:00
FleetsModal {
id: fleetModal
2021-12-14 19:47:32 +01:00
advancedStore: root . advancedStore
2021-04-23 13:22:07 +03:00
}
2020-08-27 13:28:31 -04:00
2022-02-02 17:06:23 -05:00
Component {
id: enableDeveloperFeaturesConfirmationDialogComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
showCancelButton: true
confirmationText: qsTr ( "Are you sure you want to enable all the develoer features? The app will be restarted." )
onConfirmButtonClicked: {
localAccountSensitiveSettings . downloadChannelMessagesEnabled = true
Qt . callLater ( root . advancedStore . enableDeveloperFeatures )
close ( )
}
onCancelButtonClicked: {
close ( )
}
}
}
2021-11-04 15:41:25 +01:00
Component {
id: enableTelemetryConfirmationDialogComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
showCancelButton: true
confirmationText: qsTr ( "Are you sure you want to enable telemetry? This will reduce your privacy level while using Status. You need to restart the app for this change to take effect." )
onConfirmButtonClicked: {
2021-12-14 19:47:32 +01:00
root . advancedStore . toggleTelemetry ( )
2021-11-04 15:41:25 +01:00
close ( )
2021-11-24 15:20:05 +01:00
}
onCancelButtonClicked: {
close ( )
}
}
}
Component {
id: enableAutoMessageConfirmationDialogComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
showCancelButton: true
confirmationText: qsTr ( "Are you sure you want to enable auto message? You need to restart the app for this change to take effect." )
onConfirmButtonClicked: {
2021-12-14 19:47:32 +01:00
root . advancedStore . toggleAutoMessage ( )
2021-11-24 15:20:05 +01:00
close ( )
2021-11-04 15:41:25 +01:00
}
onCancelButtonClicked: {
close ( )
}
}
}
2021-11-11 12:22:03 -04:00
Component {
id: enableDebugComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
showCancelButton: true
2022-02-02 17:06:23 -05:00
confirmationText: qsTr ( "Are you sure you want to %1 debug mode? You need to restart the app for this change to take effect." ) . arg ( root . advancedStore . isDebugEnabled ?
2022-02-09 10:43:23 +01:00
qsTr ( "disable" ) :
2021-11-11 12:22:03 -04:00
qsTr ( "enable" ) )
onConfirmButtonClicked: {
2021-12-14 19:47:32 +01:00
root . advancedStore . toggleDebug ( )
2021-11-11 12:22:03 -04:00
close ( )
}
onCancelButtonClicked: {
close ( )
}
}
}
2021-08-06 14:25:51 +02:00
ConfirmationDialog {
id: confirmationPopup
2021-12-24 09:24:26 +01:00
property string experimentalFeature: ""
2021-08-06 14:25:51 +02:00
showCancelButton: true
2022-04-04 13:26:30 +02:00
confirmationText: qsTr ( "This feature is experimental and is meant for testing purposes by core contributors and the community. It's not meant for real use and makes no claims of security or integrity of funds or data. Use at your own risk." )
confirmButtonLabel: qsTr ( "I understand" )
2021-08-06 14:25:51 +02:00
onConfirmButtonClicked: {
2021-12-24 09:24:26 +01:00
root . advancedStore . toggleExperimentalFeature ( experimentalFeature )
experimentalFeature = ""
2021-08-06 14:25:51 +02:00
close ( )
}
onCancelButtonClicked: {
close ( )
}
2021-04-23 13:22:07 +03:00
}
}
2020-06-18 08:03:11 -04:00
}