2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Controls 2.13
|
2020-11-17 20:02:56 +01:00
|
|
|
import QtGraphicalEffects 1.13
|
2020-06-17 15:18:31 -04:00
|
|
|
import QtQuick.Layouts 1.13
|
2020-11-17 20:02:56 +01:00
|
|
|
import "./"
|
2020-05-27 17:28:25 -04:00
|
|
|
import "../../../../imports"
|
2020-06-19 14:06:58 -04:00
|
|
|
import "../../../../shared"
|
2020-09-18 10:29:31 +02:00
|
|
|
import "../../../../shared/status"
|
2020-05-27 17:28:25 -04:00
|
|
|
|
2020-09-18 14:24:16 +02:00
|
|
|
ScrollView {
|
|
|
|
height: parent.height
|
|
|
|
width: parent.width
|
|
|
|
contentHeight: notificationsContainer.height
|
|
|
|
clip: true
|
|
|
|
|
2020-11-19 15:59:31 +01:00
|
|
|
Item {
|
2020-09-18 14:24:16 +02:00
|
|
|
id: notificationsContainer
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: contentMargin
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: contentMargin
|
|
|
|
height: this.childrenRect.height + 100
|
|
|
|
|
2020-11-19 15:59:31 +01:00
|
|
|
property Component mutedChatsModalComponent: MutedChatsModal {}
|
|
|
|
|
|
|
|
|
2020-09-18 14:24:16 +02:00
|
|
|
ButtonGroup {
|
|
|
|
id: notificationSetting
|
|
|
|
}
|
|
|
|
|
|
|
|
ButtonGroup {
|
|
|
|
id: soundSetting
|
|
|
|
}
|
|
|
|
|
|
|
|
ButtonGroup {
|
|
|
|
id: messageSetting
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusSectionHeadline {
|
|
|
|
id: sectionHeadlineNotifications
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "Notification preferences"
|
|
|
|
text: qsTrId("notifications-preferences")
|
2020-09-18 14:24:16 +02:00
|
|
|
anchors.top: parent.top
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: column
|
|
|
|
anchors.top: sectionHeadlineNotifications.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusRadioButtonRow {
|
|
|
|
//% "All messages"
|
|
|
|
text: qsTrId("all-messages")
|
|
|
|
buttonGroup: notificationSetting
|
|
|
|
checked: appSettings.notificationSetting === Constants.notifyAllMessages
|
|
|
|
onRadioCheckedChanged: {
|
|
|
|
if (checked) {
|
|
|
|
appSettings.notificationSetting = Constants.notifyAllMessages
|
2020-10-15 13:53:27 +02:00
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusRadioButtonRow {
|
|
|
|
//% "Just @mentions"
|
|
|
|
text: qsTrId("just--mentions")
|
|
|
|
buttonGroup: notificationSetting
|
|
|
|
checked: appSettings.notificationSetting === Constants.notifyJustMentions
|
|
|
|
onRadioCheckedChanged: {
|
|
|
|
if (checked) {
|
|
|
|
appSettings.notificationSetting = Constants.notifyJustMentions
|
2020-10-15 13:53:27 +02:00
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusRadioButtonRow {
|
|
|
|
//% "Nothing"
|
|
|
|
text: qsTrId("nothing")
|
|
|
|
buttonGroup: notificationSetting
|
|
|
|
checked: appSettings.notificationSetting === Constants.notifyNone
|
|
|
|
onRadioCheckedChanged: {
|
|
|
|
if (checked) {
|
|
|
|
appSettings.notificationSetting = Constants.notifyNone
|
2020-10-15 13:53:27 +02:00
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
id: separator
|
|
|
|
anchors.top: column.bottom
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: -Style.current.padding
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusSectionHeadline {
|
|
|
|
id: sectionHeadlineSound
|
2021-01-19 14:26:59 -05:00
|
|
|
text: qsTr("Appearance")
|
2020-09-18 14:24:16 +02:00
|
|
|
anchors.top: separator.bottom
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: column2
|
|
|
|
anchors.top: sectionHeadlineSound.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
width: parent.width
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusSettingsLineButton {
|
|
|
|
//% "Play a sound when receiving a notification"
|
|
|
|
text: qsTrId("play-a-sound-when-receiving-a-notification")
|
|
|
|
isSwitch: true
|
|
|
|
switchChecked: appSettings.notificationSoundsEnabled
|
|
|
|
onClicked: {
|
|
|
|
appSettings.notificationSoundsEnabled = checked
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
2021-01-19 14:26:59 -05:00
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusSettingsLineButton {
|
|
|
|
text: qsTr("Use your operating system's notifications")
|
|
|
|
isSwitch: true
|
|
|
|
switchChecked: appSettings.useOSNotifications
|
|
|
|
onClicked: {
|
|
|
|
appSettings.useOSNotifications = checked
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
2020-12-07 12:37:39 -05:00
|
|
|
StyledText {
|
2021-01-19 14:26:59 -05:00
|
|
|
id: detailText
|
|
|
|
text: qsTr("Setting this to false will instead use Status' notification style as seen below")
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
width: parent.width
|
|
|
|
font.pixelSize: 12
|
2020-12-07 12:37:39 -05:00
|
|
|
wrapMode: Text.WordWrap
|
2021-01-19 14:26:59 -05:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.topMargin: 2
|
2020-12-07 12:37:39 -05:00
|
|
|
}
|
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: column3
|
|
|
|
spacing: Style.current.bigPadding
|
|
|
|
anchors.top: column2.bottom
|
|
|
|
anchors.topMargin: Style.current.padding*2
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
|
|
|
|
StyledText {
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "Message preview"
|
|
|
|
text: qsTrId("message-preview")
|
2020-09-18 14:24:16 +02:00
|
|
|
font.pixelSize: 15
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
2020-11-17 20:02:56 +01:00
|
|
|
Column {
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
anchors.right: parent.right
|
|
|
|
spacing: 10
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
NotificationAppearancePreview {
|
|
|
|
//% "Anonymous"
|
|
|
|
name: qsTrId("anonymous")
|
|
|
|
notificationTitle: "Status"
|
|
|
|
notificationMessage: qsTr("You have a new message")
|
|
|
|
buttonGroup: messageSetting
|
|
|
|
checked: appSettings.notificationMessagePreviewSetting === Constants.notificationPreviewAnonymous
|
|
|
|
onRadioCheckedChanged: {
|
|
|
|
if (checked) {
|
|
|
|
appSettings.notificationMessagePreviewSetting = Constants.notificationPreviewAnonymous
|
2020-11-17 20:02:56 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
NotificationAppearancePreview {
|
|
|
|
//% "Name only"
|
|
|
|
name: qsTrId("name-only")
|
|
|
|
notificationTitle: "Vitalik Buterin"
|
|
|
|
notificationMessage: qsTr("You have a new message")
|
|
|
|
buttonGroup: messageSetting
|
|
|
|
checked: appSettings.notificationMessagePreviewSetting === Constants.notificationPreviewNameOnly
|
|
|
|
onRadioCheckedChanged: {
|
|
|
|
if (checked) {
|
|
|
|
appSettings.notificationMessagePreviewSetting = Constants.notificationPreviewNameOnly
|
2020-11-17 20:02:56 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
NotificationAppearancePreview {
|
|
|
|
//% "Name & Message"
|
|
|
|
name: qsTrId("name---message")
|
|
|
|
notificationTitle: "Vitalik Buterin"
|
|
|
|
notificationMessage: qsTr("Hi there! Yes, no problem, let me know if I can help.")
|
|
|
|
buttonGroup: messageSetting
|
|
|
|
checked: appSettings.notificationMessagePreviewSetting === Constants.notificationPreviewNameAndMessage
|
|
|
|
onRadioCheckedChanged: {
|
|
|
|
if (checked) {
|
2020-11-17 20:02:56 +01:00
|
|
|
appSettings.notificationMessagePreviewSetting = Constants.notificationPreviewNameAndMessage
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "No preview or Advanced? Go to Notification Center"
|
|
|
|
text: qsTrId("no-preview-or-advanced--go-to-notification-center")
|
2020-09-18 14:24:16 +02:00
|
|
|
font.pixelSize: 15
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
id: separator2
|
|
|
|
anchors.top: column3.bottom
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: -Style.current.padding
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusSectionHeadline {
|
|
|
|
id: sectionHeadlineContacts
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "Contacts & Users"
|
|
|
|
text: qsTrId("contacts---users")
|
2020-09-18 14:24:16 +02:00
|
|
|
anchors.top: separator2.bottom
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: column4
|
|
|
|
anchors.top: sectionHeadlineContacts.bottom
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
width: parent.width
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusSettingsLineButton {
|
|
|
|
//% "Receive notifications from non-contacts"
|
|
|
|
text: qsTrId("receive-notifications-from-non-contacts")
|
|
|
|
isSwitch: true
|
|
|
|
switchChecked: appSettings.allowNotificationsFromNonContacts
|
|
|
|
onClicked: {
|
|
|
|
appSettings.allowNotificationsFromNonContacts = checked
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusSettingsLineButton {
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "Muted users"
|
2021-01-19 14:26:59 -05:00
|
|
|
text: qsTrId("muted-users")
|
|
|
|
currentValue: profileModel.mutedContacts.rowCount() > 0 ? profileModel.mutedContacts.rowCount() : qsTr("None")
|
|
|
|
isSwitch: false
|
2020-11-19 15:59:31 +01:00
|
|
|
onClicked: {
|
|
|
|
const mutedChatsModal = notificationsContainer.mutedChatsModalComponent.createObject(notificationsContainer, {
|
|
|
|
showMutedContacts: true
|
|
|
|
})
|
|
|
|
mutedChatsModal.title = qsTr("Muted contacts")
|
|
|
|
mutedChatsModal.open()
|
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusSettingsLineButton {
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "Muted chats"
|
2021-01-19 14:26:59 -05:00
|
|
|
text: qsTrId("muted-chats")
|
|
|
|
currentValue: profileModel.mutedChats.rowCount() > 0 ? profileModel.mutedChats.rowCount() : qsTr("None")
|
|
|
|
isSwitch: false
|
2020-11-19 15:59:31 +01:00
|
|
|
onClicked: {
|
|
|
|
const mutedChatsModal = notificationsContainer.mutedChatsModalComponent.createObject(notificationsContainer, {
|
|
|
|
showMutedContacts: false
|
|
|
|
})
|
|
|
|
mutedChatsModal.title = qsTr("Muted chats")
|
|
|
|
mutedChatsModal.open()
|
|
|
|
}
|
2021-01-19 14:26:59 -05:00
|
|
|
|
|
|
|
StyledText {
|
|
|
|
//% "You can limit what gets shown in notifications"
|
|
|
|
text: qsTrId("you-can-limit-what-gets-shown-in-notifications")
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
width: parent.width
|
|
|
|
font.pixelSize: 12
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.topMargin: 2
|
|
|
|
}
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
id: separator3
|
|
|
|
anchors.top: column4.bottom
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: -Style.current.padding
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Column {
|
|
|
|
id: column5
|
|
|
|
spacing: Style.current.smallPadding
|
|
|
|
anchors.top: separator3.bottom
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
2020-11-17 20:02:56 +01:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
2020-09-18 14:24:16 +02:00
|
|
|
width: parent.width
|
|
|
|
|
2021-01-19 14:26:59 -05:00
|
|
|
StatusButton {
|
2020-09-18 14:24:16 +02:00
|
|
|
flat: true
|
|
|
|
horizontalPadding: 0
|
2021-01-19 14:26:59 -05:00
|
|
|
//% "Reset notification settings"
|
|
|
|
text: qsTrId("reset-notification-settings")
|
|
|
|
type: "warn"
|
2020-11-19 16:07:52 +01:00
|
|
|
onClicked: {
|
|
|
|
appSettings.notificationSetting = defaultAppSettings.notificationSetting
|
|
|
|
appSettings.notificationSoundsEnabled = defaultAppSettings.notificationSoundsEnabled
|
|
|
|
appSettings.notificationMessagePreviewSetting = defaultAppSettings.notificationMessagePreviewSetting
|
|
|
|
appSettings.allowNotificationsFromNonContacts = defaultAppSettings.allowNotificationsFromNonContacts
|
2020-09-18 14:24:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
2020-09-22 09:53:03 +02:00
|
|
|
//% "Restore default notification settings and unmute all chats and users"
|
|
|
|
text: qsTrId("restore-default-notification-settings-and-unmute-all-chats-and-users")
|
2020-09-18 14:24:16 +02:00
|
|
|
font.pixelSize: 15
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
}
|
|
|
|
}
|
2020-05-27 17:28:25 -04:00
|
|
|
}
|
|
|
|
}
|