import QtQuick 2.13 import QtQuick.Controls 2.13 import utils 1.0 import "../../../../../shared" import "../../../../../shared/popups" import "../../../../../shared/panels" import "../../../../../shared/status" import ".." Item { width: parent.width height: 64 Row { id: filterButtons anchors.verticalCenter: parent.verticalCenter anchors.left: parent.left anchors.leftMargin: Style.current.padding height: allBtn.height spacing: Style.current.padding StatusButton { id: allBtn //% "All" text: qsTrId("all") type: "secondary" size: "small" highlighted: activityCenter.currentFilter === ActivityCenter.Filter.All onClicked: activityCenter.currentFilter = ActivityCenter.Filter.All } StatusButton { id: mentionsBtn //% "Mentions" text: qsTrId("mentions") type: "secondary" enabled: hasMentions size: "small" highlighted: activityCenter.currentFilter === ActivityCenter.Filter.Mentions onClicked: activityCenter.currentFilter = ActivityCenter.Filter.Mentions } StatusButton { id: repliesbtn //% "Replies" text: qsTrId("replies") enabled: hasReplies type: "secondary" size: "small" highlighted: activityCenter.currentFilter === ActivityCenter.Filter.Replies onClicked: activityCenter.currentFilter = ActivityCenter.Filter.Replies } // StatusButton { // id: contactRequestsBtn // //% "Contact requests" // text: qsTrId("contact-requests") // enabled: hasContactRequests // type: "secondary" // size: "small" // highlighted: activityCenter.currentFilter === ActivityCenter.Filter.ContactRequests // onClicked: activityCenter.currentFilter = ActivityCenter.Filter.ContactRequests // } } Row { id: otherButtons anchors.verticalCenter: parent.verticalCenter anchors.right: parent.right anchors.rightMargin: Style.current.padding height: markAllReadBtn.height spacing: Style.current.padding StatusIconButton { id: markAllReadBtn icon.name: "double-check" iconColor: Style.current.primary icon.width: 24 icon.height: 24 width: 32 height: 32 onClicked: { errorText.text = chatsModel.activityNotificationList.markAllActivityCenterNotificationsRead() } StatusToolTip { visible: markAllReadBtn.hovered //% "Mark all as Read" text: qsTrId("mark-all-as-read") } } StatusContextMenuButton { id: moreActionsBtn onClicked: moreActionsMenu.open() // TODO: replace with StatusPopupMenu PopupMenu { id: moreActionsMenu x: moreActionsBtn.width - moreActionsMenu.width y: moreActionsBtn.height + 4 Action { icon.source: hideReadNotifications ? Style.svg("eye") : Style.svg("eye-barred") icon.width: 16 icon.height: 16 text: hideReadNotifications ? //% "Show read notifications" qsTrId("show-read-notifications") : //% "Hide read notifications" qsTrId("hide-read-notifications") onTriggered: hideReadNotifications = !hideReadNotifications } Action { icon.source: Style.svg("bell") icon.width: 16 icon.height: 16 //% "Notification settings" text: qsTrId("chat-notification-preferences") onTriggered: { activityCenter.close() appMain.changeAppSection(Constants.profile) // TODO: replace with shared store constant // Profile/RootStore.notifications_id profileLayoutContainer.changeProfileSection(7) } } } } } StyledText { id: errorText visible: !!text anchors.top: filterButtons.bottom anchors.topMargin: Style.current.smallPadding color: Style.current.danger } }