2022-09-12 10:06:26 +00:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
2021-09-28 15:04:06 +00:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-18 12:01:09 +00:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
2021-05-28 17:35:21 +00:00
|
|
|
import ".."
|
2022-09-12 10:06:26 +00:00
|
|
|
import "../popups"
|
2021-05-28 17:35:21 +00:00
|
|
|
|
|
|
|
Item {
|
2021-10-01 15:58:36 +00:00
|
|
|
id: root
|
2021-05-28 17:35:21 +00:00
|
|
|
|
2022-05-10 16:04:25 +00:00
|
|
|
property bool hasMentions: false
|
|
|
|
property bool hasReplies: false
|
|
|
|
property bool hideReadNotifications: false
|
2022-09-12 10:06:26 +00:00
|
|
|
|
|
|
|
property int currentActivityCategory: ActivityCenterPopup.ActivityCategory.All
|
|
|
|
|
2021-10-01 15:58:36 +00:00
|
|
|
property alias errorText: errorText.text
|
|
|
|
|
2022-09-12 10:06:26 +00:00
|
|
|
signal categoryTriggered(int category)
|
|
|
|
signal markAllReadClicked()
|
2021-05-28 17:35:21 +00:00
|
|
|
|
2022-09-12 10:06:26 +00:00
|
|
|
height: 64
|
2021-05-28 17:35:21 +00:00
|
|
|
|
2022-09-12 10:06:26 +00:00
|
|
|
RowLayout {
|
|
|
|
id: row
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.leftMargin: Style.current.padding
|
2021-05-28 17:35:21 +00:00
|
|
|
anchors.rightMargin: Style.current.padding
|
|
|
|
spacing: Style.current.padding
|
|
|
|
|
2022-09-12 10:06:26 +00:00
|
|
|
StatusListView {
|
|
|
|
id: listView
|
|
|
|
// NOTE: some entries are hidden until implimentation
|
|
|
|
model: [ { text: qsTr("All"), category: ActivityCenterPopup.ActivityCategory.All, visible: true },
|
|
|
|
{ text: qsTr("Admin"), category: ActivityCenterPopup.ActivityCategory.Admin, visible: false },
|
|
|
|
{ text: qsTr("Mentions"), category: ActivityCenterPopup.ActivityCategory.Mentions, visible: true },
|
|
|
|
{ text: qsTr("Replies"), category: ActivityCenterPopup.ActivityCategory.Replies, visible: true },
|
|
|
|
{ text: qsTr("Contact requests"), category: ActivityCenterPopup.ActivityCategory.ContactRequests, visible: true },
|
|
|
|
{ text: qsTr("Identity verification"), category: ActivityCenterPopup.ActivityCategory.IdentityVerification, visible: false },
|
|
|
|
{ text: qsTr("Transactions"), category: ActivityCenterPopup.ActivityCategory.Transactions, visible: false },
|
|
|
|
{ text: qsTr("Membership"), category: ActivityCenterPopup.ActivityCategory.Membership, visible: false },
|
|
|
|
{ text: qsTr("System"), category: ActivityCenterPopup.ActivityCategory.System, visible: false } ]
|
|
|
|
orientation: StatusListView.Horizontal
|
|
|
|
spacing: 0
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
|
|
|
delegate: StatusFlatButton {
|
|
|
|
visible: modelData.visible
|
|
|
|
width: visible ? implicitWidth : 0
|
|
|
|
text: modelData.text
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
height: 32
|
|
|
|
size: StatusBaseButton.Size.Small
|
|
|
|
highlighted: modelData.category == root.currentActivityCategory
|
|
|
|
onClicked: root.categoryTriggered(modelData.category)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-18 12:01:09 +00:00
|
|
|
StatusFlatRoundButton {
|
|
|
|
id: markAllReadBtn
|
|
|
|
icon.name: "double-checkmark"
|
|
|
|
onClicked: markAllReadClicked()
|
2021-05-28 17:35:21 +00:00
|
|
|
|
2021-10-18 12:01:09 +00:00
|
|
|
StatusToolTip {
|
|
|
|
visible: markAllReadBtn.hovered
|
2022-04-04 11:26:30 +00:00
|
|
|
text: qsTr("Mark all as Read")
|
2021-10-18 12:01:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusFlatRoundButton {
|
2022-09-12 10:06:26 +00:00
|
|
|
id: hideReadNotificationsBtn
|
|
|
|
icon.name: "hide"
|
|
|
|
onClicked: hideReadNotifications = !hideReadNotifications
|
2021-10-18 12:01:09 +00:00
|
|
|
|
2022-09-12 10:06:26 +00:00
|
|
|
StatusToolTip {
|
|
|
|
visible: markAllReadBtn.hovered
|
|
|
|
text: hideReadNotifications ? qsTr("Show read notifications") : qsTr("Hide read notifications")
|
2021-10-18 12:01:09 +00:00
|
|
|
}
|
|
|
|
}
|
2021-05-28 17:35:21 +00:00
|
|
|
}
|
2021-06-11 17:41:59 +00:00
|
|
|
|
2021-10-18 12:01:09 +00:00
|
|
|
StatusBaseText {
|
2021-06-11 17:41:59 +00:00
|
|
|
id: errorText
|
|
|
|
visible: !!text
|
2022-09-12 10:06:26 +00:00
|
|
|
anchors.top: parent.top
|
2021-06-11 17:41:59 +00:00
|
|
|
anchors.topMargin: Style.current.smallPadding
|
2021-10-18 12:01:09 +00:00
|
|
|
color: Theme.palette.dangerColor1
|
2021-06-11 17:41:59 +00:00
|
|
|
}
|
2021-05-28 17:35:21 +00:00
|
|
|
}
|