2023-02-21 20:11:44 +04:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-18 14:01:09 +02:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
2024-07-18 16:10:24 -04:00
|
|
|
import StatusQ.Components 0.1
|
2021-10-18 14:01:09 +02:00
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
2023-02-23 15:09:05 +04:00
|
|
|
import "../stores"
|
2021-05-28 13:35:21 -04:00
|
|
|
|
|
|
|
Item {
|
2021-10-01 18:58:36 +03:00
|
|
|
id: root
|
2021-05-28 13:35:21 -04:00
|
|
|
|
2022-10-05 18:51:42 +04:00
|
|
|
property bool hasAdmin: false
|
2022-05-10 19:04:25 +03:00
|
|
|
property bool hasMentions: false
|
|
|
|
property bool hasReplies: false
|
2022-09-16 16:06:52 +03:00
|
|
|
property bool hasContactRequests: false
|
2022-10-05 18:51:42 +04:00
|
|
|
property bool hasMembership: false
|
2022-09-16 16:06:52 +03:00
|
|
|
|
2022-05-10 19:04:25 +03:00
|
|
|
property bool hideReadNotifications: false
|
2022-09-16 16:06:52 +03:00
|
|
|
property int unreadNotificationsCount: 0
|
2022-09-12 14:06:26 +04:00
|
|
|
|
2023-02-23 15:09:05 +04:00
|
|
|
property int activeGroup: ActivityCenterStore.ActivityCenterGroup.All
|
2022-09-12 14:06:26 +04:00
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
property alias errorText: errorText.text
|
|
|
|
|
2023-02-21 20:11:44 +04:00
|
|
|
signal groupTriggered(int group)
|
2022-09-12 14:06:26 +04:00
|
|
|
signal markAllReadClicked()
|
2022-09-16 16:06:52 +03:00
|
|
|
signal showHideReadNotifications(bool hideReadNotifications)
|
2021-05-28 13:35:21 -04:00
|
|
|
|
2022-09-12 14:06:26 +04:00
|
|
|
height: 64
|
2021-05-28 13:35:21 -04:00
|
|
|
|
2022-09-12 14:06:26 +04:00
|
|
|
RowLayout {
|
|
|
|
id: row
|
|
|
|
anchors.fill: parent
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.leftMargin: Theme.padding
|
|
|
|
anchors.rightMargin: Theme.padding
|
|
|
|
spacing: Theme.padding
|
2021-05-28 13:35:21 -04:00
|
|
|
|
2022-11-18 13:22:07 +04:00
|
|
|
StatusRollArea {
|
2022-09-12 14:06:26 +04:00
|
|
|
Layout.fillWidth: true
|
2022-11-18 13:22:07 +04:00
|
|
|
|
|
|
|
content: RowLayout {
|
|
|
|
spacing: 0
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
// NOTE: some entries are hidden until implimentation
|
2023-02-23 15:09:05 +04:00
|
|
|
model: [ { text: qsTr("All"), group: ActivityCenterStore.ActivityCenterGroup.All, visible: true, enabled: true },
|
|
|
|
{ text: qsTr("Admin"), group: ActivityCenterStore.ActivityCenterGroup.Admin, visible: root.hasAdmin, enabled: root.hasAdmin },
|
|
|
|
{ text: qsTr("Mentions"), group: ActivityCenterStore.ActivityCenterGroup.Mentions, visible: true, enabled: root.hasMentions },
|
|
|
|
{ text: qsTr("Replies"), group: ActivityCenterStore.ActivityCenterGroup.Replies, visible: true, enabled: root.hasReplies },
|
|
|
|
{ text: qsTr("Contact requests"), group: ActivityCenterStore.ActivityCenterGroup.ContactRequests, visible: true, enabled: root.hasContactRequests },
|
|
|
|
{ text: qsTr("Transactions"), group: ActivityCenterStore.ActivityCenterGroup.Transactions, visible: false, enabled: true },
|
|
|
|
{ text: qsTr("Membership"), group: ActivityCenterStore.ActivityCenterGroup.Membership, visible: true, enabled: root.hasMembership },
|
|
|
|
{ text: qsTr("System"), group: ActivityCenterStore.ActivityCenterGroup.System, visible: false, enabled: true } ]
|
2022-11-18 13:22:07 +04:00
|
|
|
|
|
|
|
StatusFlatButton {
|
2024-03-20 17:22:57 +07:00
|
|
|
objectName: "activityCenterGroupButton"
|
2022-11-18 13:22:07 +04:00
|
|
|
enabled: modelData.enabled
|
|
|
|
visible: modelData.visible
|
|
|
|
text: modelData.text
|
|
|
|
size: StatusBaseButton.Size.Small
|
2023-02-21 20:11:44 +04:00
|
|
|
highlighted: modelData.group === root.activeGroup
|
|
|
|
onClicked: root.groupTriggered(modelData.group)
|
2023-02-23 15:09:05 +04:00
|
|
|
onEnabledChanged: if (!enabled && highlighted) root.groupTriggered(ActivityCenterStore.ActivityCenterGroup.All)
|
2022-11-21 20:17:39 +04:00
|
|
|
Layout.preferredWidth: visible ? implicitWidth : 0
|
2022-11-18 13:22:07 +04:00
|
|
|
}
|
|
|
|
}
|
2022-09-12 14:06:26 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-03 09:49:14 +02:00
|
|
|
StatusBetaTag {
|
|
|
|
tooltipText: qsTr("Under construction.<br>More notification types to be coming soon.")
|
|
|
|
}
|
2024-07-18 16:10:24 -04:00
|
|
|
|
2021-10-18 14:01:09 +02:00
|
|
|
StatusFlatRoundButton {
|
|
|
|
id: markAllReadBtn
|
2024-03-20 17:22:57 +07:00
|
|
|
objectName: "markAllReadButton"
|
2022-09-16 16:06:52 +03:00
|
|
|
enabled: root.unreadNotificationsCount > 0
|
2021-10-18 14:01:09 +02:00
|
|
|
icon.name: "double-checkmark"
|
2022-09-16 16:06:52 +03:00
|
|
|
onClicked: root.markAllReadClicked()
|
2021-05-28 13:35:21 -04:00
|
|
|
|
2021-10-18 14:01:09 +02:00
|
|
|
StatusToolTip {
|
2022-09-16 16:06:52 +03:00
|
|
|
visible: markAllReadBtn.hovered
|
|
|
|
text: qsTr("Mark all as Read")
|
2021-10-18 14:01:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusFlatRoundButton {
|
2022-09-12 14:06:26 +04:00
|
|
|
id: hideReadNotificationsBtn
|
2024-03-20 17:22:57 +07:00
|
|
|
objectName: "hideReadNotificationsButton"
|
2022-09-16 16:06:52 +03:00
|
|
|
icon.name: root.hideReadNotifications ? "hide" : "show"
|
|
|
|
onClicked: root.showHideReadNotifications(!root.hideReadNotifications)
|
2021-10-18 14:01:09 +02:00
|
|
|
|
2022-09-12 14:06:26 +04:00
|
|
|
StatusToolTip {
|
2022-09-16 16:06:52 +03:00
|
|
|
visible: hideReadNotificationsBtn.hovered
|
2022-10-01 16:07:14 +04:00
|
|
|
offset: width / 4
|
2022-09-16 16:06:52 +03:00
|
|
|
text: root.hideReadNotifications ? qsTr("Show read notifications") : qsTr("Hide read notifications")
|
2021-10-18 14:01:09 +02:00
|
|
|
}
|
|
|
|
}
|
2021-05-28 13:35:21 -04:00
|
|
|
}
|
2021-06-11 13:41:59 -04:00
|
|
|
|
2021-10-18 14:01:09 +02:00
|
|
|
StatusBaseText {
|
2021-06-11 13:41:59 -04:00
|
|
|
id: errorText
|
|
|
|
visible: !!text
|
2022-09-12 14:06:26 +04:00
|
|
|
anchors.top: parent.top
|
2024-10-15 21:26:12 +02:00
|
|
|
anchors.topMargin: Theme.smallPadding
|
2021-10-18 14:01:09 +02:00
|
|
|
color: Theme.palette.dangerColor1
|
2021-06-11 13:41:59 -04:00
|
|
|
}
|
2021-05-28 13:35:21 -04:00
|
|
|
}
|