2021-10-06 11:16:39 +02:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: root
|
|
|
|
spacing: 4
|
|
|
|
|
2021-12-30 13:39:47 +01:00
|
|
|
property var privacyStore
|
2022-06-28 14:11:18 -04:00
|
|
|
property var contactsStore
|
2021-10-06 11:16:39 +02:00
|
|
|
property alias mainMenuItems: mainMenuItems.model
|
|
|
|
property alias settingsMenuItems: settingsMenuItems.model
|
|
|
|
property alias extraMenuItems: extraMenuItems.model
|
2022-02-11 10:44:49 +01:00
|
|
|
property alias appsMenuItems: appsMenuItems.model
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
property bool browserMenuItemEnabled: false
|
2022-03-07 15:34:59 -05:00
|
|
|
property bool walletMenuItemEnabled: false
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
|
|
signal menuItemClicked(var menu_item)
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: mainMenuItems
|
|
|
|
delegate: StatusNavigationListItem {
|
2022-08-11 15:27:13 +02:00
|
|
|
objectName: itemId + "-MainMenuItem"
|
2022-02-25 14:32:46 +01:00
|
|
|
itemId: model.subsection
|
2021-10-06 11:16:39 +02:00
|
|
|
title: model.text
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: model.icon
|
2022-02-25 14:32:46 +01:00
|
|
|
selected: Global.settingsSubsection === model.subsection
|
2021-10-06 11:16:39 +02:00
|
|
|
onClicked: root.menuItemClicked(model)
|
2022-05-26 16:40:41 +03:00
|
|
|
badge.value: {
|
|
|
|
switch (model.subsection) {
|
|
|
|
case Constants.settingsSubsection.backUpSeed:
|
|
|
|
return !root.privacyStore.mnemonicBackedUp
|
|
|
|
default: return "";
|
|
|
|
}
|
|
|
|
}
|
2022-04-21 12:50:01 +02:00
|
|
|
visible: {
|
2022-05-26 16:40:41 +03:00
|
|
|
switch (model.subsection) {
|
|
|
|
case Constants.settingsSubsection.ensUsernames:
|
|
|
|
return root.walletMenuItemEnabled;
|
|
|
|
case Constants.settingsSubsection.backUpSeed:
|
|
|
|
return !root.privacyStore.mnemonicBackedUp;
|
|
|
|
default: return true;
|
|
|
|
}
|
2022-04-21 12:50:01 +02:00
|
|
|
}
|
2021-10-06 11:16:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-11 10:44:49 +01:00
|
|
|
StatusListSectionHeadline {
|
|
|
|
text: qsTr("Apps")
|
|
|
|
}
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: appsMenuItems
|
|
|
|
delegate: StatusNavigationListItem {
|
|
|
|
id: appsMenuDelegate
|
2022-08-11 15:27:13 +02:00
|
|
|
objectName: itemId + "-AppMenuItem"
|
2022-02-25 14:32:46 +01:00
|
|
|
itemId: model.subsection
|
2022-02-11 10:44:49 +01:00
|
|
|
title: model.text
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: model.icon
|
2022-02-25 14:32:46 +01:00
|
|
|
selected: Global.settingsSubsection === model.subsection
|
2022-02-11 10:44:49 +01:00
|
|
|
onClicked: root.menuItemClicked(model)
|
2022-03-04 12:09:45 +01:00
|
|
|
visible: {
|
2022-06-17 12:29:14 +03:00
|
|
|
(model.subsection !== Constants.settingsSubsection.browserSettings && model.subsection !== Constants.settingsSubsection.wallet) ||
|
2022-06-21 11:00:54 +02:00
|
|
|
(model.subsection === Constants.settingsSubsection.browserSettings && root.browserMenuItemEnabled) ||
|
|
|
|
(model.subsection === Constants.settingsSubsection.communitiesSettings) ||
|
2022-06-17 12:29:14 +03:00
|
|
|
(model.subsection === Constants.settingsSubsection.wallet && root.walletMenuItemEnabled)
|
2022-03-04 12:09:45 +01:00
|
|
|
}
|
2022-03-21 11:33:14 -04:00
|
|
|
badge.value: {
|
|
|
|
switch (model.subsection) {
|
|
|
|
case Constants.settingsSubsection.messaging:
|
2022-06-28 14:11:18 -04:00
|
|
|
return root.contactsStore.receivedContactRequestsModel.count
|
2022-03-21 11:33:14 -04:00
|
|
|
default: return ""
|
|
|
|
}
|
|
|
|
}
|
2022-02-11 10:44:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-06 11:16:39 +02:00
|
|
|
StatusListSectionHeadline { text: qsTr("Settings") }
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: settingsMenuItems
|
|
|
|
delegate: StatusNavigationListItem {
|
|
|
|
id: settingsMenuDelegate
|
2022-08-11 15:27:13 +02:00
|
|
|
objectName: itemId + "-SettingsMenuItem"
|
2022-02-25 14:32:46 +01:00
|
|
|
itemId: model.subsection
|
2021-10-06 11:16:39 +02:00
|
|
|
title: model.text
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: model.icon
|
2022-02-25 14:32:46 +01:00
|
|
|
selected: Global.settingsSubsection === model.subsection
|
2021-10-06 11:16:39 +02:00
|
|
|
onClicked: root.menuItemClicked(model)
|
2022-02-25 14:32:46 +01:00
|
|
|
visible: model.subsection !== Constants.settingsSubsection.browserSettings || root.browserMenuItemEnabled
|
2021-10-06 11:16:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-03 14:16:27 +01:00
|
|
|
StatusListSectionHeadline { text: qsTr("About & Help") }
|
2021-10-06 11:16:39 +02:00
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: extraMenuItems
|
|
|
|
delegate: StatusNavigationListItem {
|
2022-08-11 15:27:13 +02:00
|
|
|
objectName: itemId + "-ExtraMenuItem"
|
2022-02-25 14:32:46 +01:00
|
|
|
itemId: model.subsection
|
2021-10-06 11:16:39 +02:00
|
|
|
title: model.text
|
2022-08-11 14:55:08 +03:00
|
|
|
asset.name: model.icon
|
2022-02-25 14:32:46 +01:00
|
|
|
selected: Global.settingsSubsection === model.subsection
|
|
|
|
visible: model.subsection !== Constants.settingsSubsection.browserSettings || root.browserMenuItemEnabled
|
2021-10-06 11:16:39 +02:00
|
|
|
onClicked: root.menuItemClicked(model)
|
|
|
|
}
|
|
|
|
}
|
2022-08-11 15:27:13 +02:00
|
|
|
}
|