2024-10-15 21:26:12 +02:00
import QtQuick 2.15
import QtQuick . Controls 2.15
import QtQml . Models 2.15
import QtQuick . Layouts 1.15
import QtGraphicalEffects 1.15
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
2023-04-07 19:06:41 +04:00
import shared . controls 1.0
2020-05-27 17:28:25 -04:00
2022-08-18 16:25:06 +02:00
import StatusQ . Core 0.1
2023-05-08 16:00:32 -04:00
import StatusQ . Popups 0.1
2022-11-21 13:51:39 +01:00
import StatusQ . Popups . Dialog 0.1
2023-04-26 18:46:04 +03:00
import StatusQ . Components 0.1
import StatusQ . Core . Theme 0.1
2022-11-21 13:51:39 +01:00
import StatusQ . Controls 0.1
2023-05-08 16:00:32 -04:00
import StatusQ . Controls . Validators 0.1
2022-08-18 16:25:06 +02: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
2023-04-26 18:46:04 +03:00
property MessagingStore messagingStore
2021-12-30 13:39:47 +01:00
property AdvancedStore advancedStore
2024-02-07 14:47:28 +01:00
property WalletStore walletStore
2021-12-14 19:47:32 +01:00
2024-03-06 10:14:48 +01:00
property bool isFleetSelectionEnabled
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
2023-06-15 21:34:25 +03:00
QtObject {
id: d
readonly property string experimentalFeatureMessage: 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." )
}
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 ( )
2024-03-06 10:14:48 +01:00
visible: root . isFleetSelectionEnabled
2021-02-22 18:10:47 -04:00
}
2023-04-07 19:06:41 +04:00
StatusSettingsLineButton {
id: labelScrolling
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "Chat scrolling" )
currentValue: root . advancedStore . isCustomScrollingEnabled ? qsTr ( "Custom" ) : qsTr ( "System" )
onClicked: scrollingModal . open ( )
}
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
2024-02-20 11:07:22 -08:00
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "Mainnet data verified by Nimbus" )
isSwitch: true
switchChecked: root . advancedStore . isNimbusProxyEnabled
onClicked: {
Global . openPopup ( enableNimbusProxyComponent )
}
}
2022-08-18 16:25:06 +02:00
StatusBaseText {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2021-09-14 11:17:35 -05:00
text: qsTr ( "Application Logs" )
font.underline: mouseArea . containsMouse
2024-10-15 21:26:12 +02:00
color: Theme . palette . primaryColor1
2021-09-14 11:17:35 -05:00
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
2024-10-15 21:26:12 +02:00
height: Theme . bigPadding
2021-08-06 14:25:51 +02:00
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
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2022-04-04 13:26:30 +02:00
text: qsTr ( "Experimental features" )
2024-10-15 21:26:12 +02:00
topPadding: Theme . bigPadding
bottomPadding: Theme . 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-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
}
2024-04-29 14:35:44 -04:00
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
2024-05-03 09:54:33 +02:00
objectName: "enableCreateCommunityButton"
2024-04-29 14:35:44 -04:00
text: qsTr ( "Enable Community Creation" )
isSwitch: true
switchChecked: root . advancedStore . createCommunityEnabled
onClicked: {
root . advancedStore . toggleCreateCommunityEnabled ( )
}
}
2023-10-27 19:18:24 +03:00
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
2024-07-19 14:45:40 -04:00
text: qsTr ( "Archive Protocol Enabled" )
isSwitch: true
switchChecked: root . advancedStore . archiveProtocolEnabled
2023-10-27 19:18:24 +03:00
onClicked: {
2024-07-19 14:45:40 -04:00
root . advancedStore . toggleArchiveProtocolEnabled ( )
2023-10-27 19:18:24 +03:00
}
}
2024-04-29 16:37:22 -04:00
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
2024-07-19 14:45:40 -04:00
text: qsTr ( "ENS Community Permissions Enabled" )
2024-04-29 16:37:22 -04:00
isSwitch: true
2024-07-19 14:45:40 -04:00
switchChecked: root . advancedStore . ensCommunityPermissionsEnabled
2024-04-29 16:37:22 -04:00
onClicked: {
2024-07-19 14:45:40 -04:00
root . advancedStore . toggleEnsCommunityPermissionsEnabled ( )
2024-04-29 16:37:22 -04:00
}
}
2023-04-26 18:46:04 +03:00
Separator {
width: parent . width
}
StatusSectionHeadline {
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2023-04-26 18:46:04 +03:00
text: qsTr ( "WakuV2 options" )
2024-10-15 21:26:12 +02:00
topPadding: Theme . bigPadding
bottomPadding: Theme . padding
2023-04-26 18:46:04 +03:00
}
2023-09-25 18:18:22 +02:00
// TODO: replace with StatusQ component
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "Enable creation of sharded communities" )
isSwitch: true
switchChecked: root . advancedStore . isWakuV2ShardedCommunitiesEnabled
onClicked: root . advancedStore . toggleWakuV2ShardedCommunities ( )
}
2023-04-26 18:46:04 +03:00
StatusListItem {
anchors.left: parent . left
anchors.right: parent . right
title: qsTr ( "Waku Nodes" )
components: [
StatusIcon {
icon: "next"
color: Theme . palette . baseColor1
}
]
onClicked: Global . openPopup ( wakuNodesModalComponent )
}
2021-09-06 18:31:10 -04:00
Row {
2022-05-07 13:45:15 +02:00
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2021-09-06 18:31:10 -04:00
spacing: 11
2023-06-15 21:34:25 +03:00
2021-09-06 18:31:10 -04:00
Component {
id: wakuV2ModeConfirmationDialogComponent
2023-06-15 21:34:25 +03:00
ConfirmationDialog {
2021-09-06 18:31:10 -04:00
id: confirmDialog
2023-06-15 21:34:25 +03:00
property bool lightMode: false
confirmationText: ( ! lightMode ? "" : ( d . experimentalFeatureMessage + "\n\n" ) )
+ qsTr ( "The account will be logged out. When you login again, the selected mode will be enabled" )
confirmButtonLabel: lightMode ? qsTr ( "I understand" ) : qsTr ( "Confirm" )
showCancelButton: lightMode
2021-09-06 18:31:10 -04:00
onConfirmButtonClicked: {
2023-06-15 21:34:25 +03:00
root . advancedStore . setWakuV2LightClientEnabled ( lightMode )
}
onCancelButtonClicked: {
close ( )
2021-09-06 18:31:10 -04:00
}
onClosed: {
2023-06-15 21:34:25 +03:00
if ( root . advancedStore . wakuV2LightClientEnabled ) {
btnWakuV2Light . toggle ( )
2021-09-06 18:31:10 -04:00
} else {
2023-06-15 21:34:25 +03:00
btnWakuV2Full . toggle ( )
2021-09-06 18:31:10 -04:00
}
destroy ( )
}
}
}
ButtonGroup {
id: wakuV2Group
}
BloomSelectorButton {
id: btnWakuV2Light
2024-07-02 14:24:03 +07:00
objectName: "lightWakuModeButton"
2021-09-06 18:31:10 -04:00
buttonGroup: wakuV2Group
2021-12-14 19:47:32 +01:00
checkedByDefault: root . advancedStore . wakuV2LightClientEnabled
2023-06-15 21:34:25 +03:00
btnText: qsTr ( "Light mode" )
2021-09-06 18:31:10 -04:00
onToggled: {
2023-06-15 21:34:25 +03:00
Global . openPopup ( wakuV2ModeConfirmationDialogComponent , { lightMode: true } )
2021-09-06 18:31:10 -04:00
}
}
BloomSelectorButton {
id: btnWakuV2Full
2024-07-02 14:24:03 +07:00
objectName: "relayWakuModeButton"
2021-09-06 18:31:10 -04:00
buttonGroup: wakuV2Group
2021-12-14 19:47:32 +01:00
checkedByDefault: ! root . advancedStore . wakuV2LightClientEnabled
2023-06-15 21:34:25 +03:00
btnText: qsTr ( "Relay mode" )
2021-09-06 18:31:10 -04:00
onToggled: {
2023-06-15 21:34:25 +03:00
Global . openPopup ( wakuV2ModeConfirmationDialogComponent , { lightMode: false } )
2021-09-06 18:31:10 -04:00
}
}
}
2023-10-18 10:03:32 +01:00
// SYNC WAKU SECTION
StatusListItem {
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2023-10-18 10:03:32 +01:00
title: qsTr ( "History nodes" )
2024-06-04 16:55:08 +04:00
label: root . messagingStore . activeMailserverId || "---"
2023-10-18 10:03:32 +01:00
components: [
StatusIcon {
icon: "next"
color: Theme . palette . baseColor1
}
]
onClicked: Global . openPopup ( wakuStoreModalComponent )
}
Component {
id: wakuStoreModalComponent
WakuStoreModal {
messagingStore: root . messagingStore
advancedStore: root . advancedStore
}
}
2022-05-07 13:45:15 +02:00
StatusSectionHeadline {
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2022-02-02 17:06:23 -05:00
text: qsTr ( "Developer features" )
2024-10-15 21:26:12 +02:00
topPadding: Theme . bigPadding
bottomPadding: Theme . padding
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-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
}
2024-04-29 14:02:19 +02:00
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "Enable translations" )
isSwitch: true
switchChecked: localAppSettings . translationsEnabled
onClicked: {
localAppSettings . translationsEnabled = ! localAppSettings . translationsEnabled
if ( ! checked )
Global . openPopup ( disableLanguagesPopupComponent )
}
}
Component {
id: disableLanguagesPopupComponent
ConfirmationDialog {
destroyOnClose: true
headerSettings.title: qsTr ( "Language reset" )
confirmationText: qsTr ( "Display language will be switched back to English. You must restart the application for changes to take effect." )
confirmButtonLabel: qsTr ( "Restart" )
2024-10-08 14:51:48 +02:00
onConfirmButtonClicked: SystemUtils . restartApplication ( )
2024-04-29 14:02:19 +02: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
2024-02-05 09:11:27 -08:00
isEnabled: ! root . advancedStore . isRuntimeLogLevelSet
2021-12-14 19:47:32 +01:00
switchChecked: root . advancedStore . isDebugEnabled
2024-02-05 09:11:27 -08:00
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
}
2024-02-05 09:11:27 -08:00
MouseArea {
id: overlayMouseArea
anchors.fill: parent
enabled: true
hoverEnabled: true
propagateComposedEvents: true
}
StatusToolTip {
text: qsTr ( "The value is overridden with runtime options" )
visible: overlayMouseArea . containsMouse && root . advancedStore . isRuntimeLogLevelSet
delay: 1000
}
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 )
}
}
2023-02-15 10:27:18 +02:00
StatusSettingsLineButton {
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "Fake loading screen" )
isSwitch: true
switchChecked: root . advancedStore . isFakeLoadingScreenEnabled
onClicked: {
root . advancedStore . toggleFakeLoadingScreen ( )
}
}
2023-05-08 16:00:32 -04:00
StatusSettingsLineButton {
anchors.leftMargin: 0
2023-10-03 15:30:42 +02:00
anchors.rightMargin: 0
2024-02-20 10:31:04 +01:00
text: qsTr ( "Enable Goerli as Test Network" )
2023-10-03 15:30:42 +02:00
isSwitch: true
2024-02-20 10:31:04 +01:00
switchChecked: root . advancedStore . isGoerliEnabled
2024-02-15 09:37:03 +01:00
onClicked: Global . openPopup ( enableSepoliaConfirmationDialogComponent )
2023-10-03 15:30:42 +02:00
}
StatusSettingsLineButton {
anchors.leftMargin: 0
2023-10-10 12:31:45 +02:00
anchors.rightMargin: 0
2024-04-19 20:07:01 +07:00
objectName: "manageCommunitiesOnTestnetButton"
2023-10-10 12:31:45 +02:00
text: qsTr ( "Manage communities on testnet" )
isSwitch: true
switchChecked: root . advancedStore . isManageCommunityOnTestModeEnabled
onClicked: {
root . advancedStore . toggleManageCommunityOnTestnet ( )
}
}
StatusSettingsLineButton {
2024-05-21 10:53:33 +02:00
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "Enable community tokens refreshing" )
isSwitch: true
switchChecked: root . advancedStore . refreshTokenEnabled
onClicked: {
root . advancedStore . toggleRefreshTokenEnabled ( )
}
}
StatusSettingsLineButton {
2023-10-10 12:31:45 +02:00
anchors.leftMargin: 0
2023-05-08 16:00:32 -04:00
anchors.rightMargin: 0
text: qsTr ( "How many log files to keep archived" )
currentValue: root . advancedStore . logMaxBackups
onClicked: {
Global . openPopup ( changeNumberOfLogsArchived )
}
}
2024-02-07 14:47:28 +01:00
StatusSettingsLineButton {
id: rpcStatsButton
anchors.leftMargin: 0
anchors.rightMargin: 0
text: qsTr ( "RPC statistics" )
onClicked: rpcStatsModal . open ( )
}
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
2023-04-26 18:46:04 +03:00
Component {
id: wakuNodesModalComponent
WakuNodesModal {
messagingStore: root . messagingStore
advancedStore: root . advancedStore
}
}
2024-02-15 09:37:03 +01:00
Component {
id: enableSepoliaConfirmationDialogComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
destroyOnClose: true
showCancelButton: true
confirmationText: qsTr ( "Are you sure you want to toggle sepolia? The app will be restarted." )
onConfirmButtonClicked: {
2024-02-20 10:31:04 +01:00
root . advancedStore . toggleIsGoerliEnabled ( )
2024-02-15 09:37:03 +01:00
close ( )
2024-10-08 14:51:48 +02:00
SystemUtils . restartApplication ( )
2024-02-15 09:37:03 +01:00
}
onCancelButtonClicked: {
close ( )
}
}
}
2022-02-02 17:06:23 -05:00
Component {
id: enableDeveloperFeaturesConfirmationDialogComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
2023-09-25 18:18:22 +02:00
destroyOnClose: true
2022-02-02 17:06:23 -05:00
showCancelButton: true
2023-06-15 21:34:25 +03:00
confirmationText: qsTr ( "Are you sure you want to enable all the developer features? The app will be restarted." )
2022-02-02 17:06:23 -05:00
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
2023-09-25 18:18:22 +02:00
destroyOnClose: true
2021-11-04 15:41:25 +01:00
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
2023-09-25 18:18:22 +02:00
destroyOnClose: true
2021-11-24 15:20:05 +01:00
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
2023-09-25 18:18:22 +02:00
destroyOnClose: true
2021-11-11 12:22:03 -04:00
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 ( )
}
}
}
2024-02-20 11:07:22 -08:00
Component {
id: enableNimbusProxyComponent
ConfirmationDialog {
property bool mode: false
id: confirmDialog
destroyOnClose: true
showCancelButton: true
confirmationText: qsTr ( "Are you sure you want to %1 Nimbus proxy? You need to restart the app for this change to take effect." ) . arg ( root . advancedStore . isNimbusProxyEnabled ?
qsTr ( "disable" ) :
qsTr ( "enable" ) )
onConfirmButtonClicked: {
root . advancedStore . toggleNimbusProxy ( )
close ( )
}
onCancelButtonClicked: {
close ( )
}
}
}
2023-05-08 16:00:32 -04:00
Component {
id: changeNumberOfLogsArchived
StatusModal {
id: logChangerModal
onClosed: destroy ( )
anchors.centerIn: parent
width: 400
2023-05-23 14:46:16 +02:00
headerSettings.title: qsTr ( "How many log files do you want to keep archived?" )
2023-05-08 16:00:32 -04:00
contentItem: Column {
width: parent . width
StatusBaseText {
width: parent . width
padding: 15
wrapMode: Text . WordWrap
text: qsTr ( "Choose a number between 1 and 100" )
}
2024-04-15 07:28:29 +02:00
StatusAmountInput {
2023-05-08 16:00:32 -04:00
id: numberInput
anchors.left: parent . left
anchors.right: parent . right
2024-10-15 21:26:12 +02:00
anchors.leftMargin: Theme . padding
anchors.rightMargin: Theme . padding
2023-05-08 16:00:32 -04:00
label: qsTr ( "Number of archives files" )
input.text: root . advancedStore . logMaxBackups
placeholderText: qsTr ( "Number between 1 and 100" )
validators: [
2024-04-15 07:28:29 +02:00
StatusIntValidator {
2023-05-08 16:00:32 -04:00
bottom: 1
top: 100
errorMessage: qsTr ( "Number needs to be between 1 and 100" )
locale: LocaleUtils . userInputLocale
}
]
}
StatusBaseText {
width: parent . width
padding: 15
wrapMode: Text . WordWrap
text: qsTr ( "This change will only come into action after a restart" )
}
}
rightButtons: [
StatusButton {
text: qsTr ( "Cancel" )
onClicked: logChangerModal . close ( )
normalColor: "transparent"
hoverColor: "transparent"
} ,
StatusButton {
id: banButton
text: qsTr ( "Change" )
type: StatusBaseButton . Type . Normal
onClicked: {
root . advancedStore . setMaxLogBackups ( numberInput . input . text )
logChangerModal . 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
2023-06-15 21:34:25 +03:00
confirmationText: d . experimentalFeatureMessage
2022-04-04 13:26:30 +02:00
confirmButtonLabel: qsTr ( "I understand" )
2024-07-02 14:24:03 +07:00
confirmButtonObjectName: "leaveGroupConfirmationDialogLeaveButton"
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
}
2023-04-07 19:06:41 +04:00
ScrollingModal {
id: scrollingModal
title: labelScrolling . text
initialVelocity: root . advancedStore . scrollVelocity
initialDeceleration: root . advancedStore . scrollDeceleration
isCustomScrollingEnabled: root . advancedStore . isCustomScrollingEnabled
onVelocityChanged: root . advancedStore . setScrollVelocity ( value )
onDecelerationChanged: root . advancedStore . setScrollDeceleration ( value )
onCustomScrollingChanged: root . advancedStore . setCustomScrollingEnabled ( enabled )
}
2024-02-07 14:47:28 +01:00
RPCStatsModal {
id: rpcStatsModal
walletStore: root . walletStore
title: rpcStatsButton . text
}
2021-04-23 13:22:07 +03:00
}
2020-06-18 08:03:11 -04:00
}