From f78693d247d89e54ea0c1621e444adc00f0f4ae9 Mon Sep 17 00:00:00 2001 From: Boris Melnik Date: Tue, 14 Jun 2022 13:01:08 +0300 Subject: [PATCH] feat(StatusQ.Controls): Introduce `StatusActivityCenterButton` (#705) --- .../StatusQ/Components/StatusChatToolBar.qml | 37 +---------- .../Controls/StatusActivityCenterButton.qml | 65 +++++++++++++++++++ ui/StatusQ/src/StatusQ/Controls/qmldir | 1 + 3 files changed, 68 insertions(+), 35 deletions(-) create mode 100644 ui/StatusQ/src/StatusQ/Controls/StatusActivityCenterButton.qml diff --git a/ui/StatusQ/src/StatusQ/Components/StatusChatToolBar.qml b/ui/StatusQ/src/StatusQ/Components/StatusChatToolBar.qml index 4332ae4fef..c10e8bd342 100644 --- a/ui/StatusQ/src/StatusQ/Components/StatusChatToolBar.qml +++ b/ui/StatusQ/src/StatusQ/Components/StatusChatToolBar.qml @@ -135,43 +135,10 @@ Item { (menuButton.visible || membersButton.visible || searchButton.visible) } - StatusFlatRoundButton { + StatusActivityCenterButton { id: notificationButton - width: 32 - height: 32 - - icon.name: "notification" - icon.height: 21 - type: StatusFlatRoundButton.Type.Secondary - - // initializing the tooltip - tooltip.text: qsTr("Activity") - tooltip.orientation: StatusToolTip.Orientation.Bottom - tooltip.y: parent.height + 12 - + unreadNotificationsCount: statusChatToolBar.notificationCount onClicked: statusChatToolBar.notificationButtonClicked() - - StatusBadge { - id: statusBadge - - visible: value > 0 - anchors.top: parent.top - anchors.left: parent.right - anchors.topMargin: -3 - anchors.leftMargin: { - if (statusBadge.value > 99) { - return -22 - } - if (statusBadge.value > 9) { - return -21 - } - return -18 - } - - value: statusChatToolBar.notificationCount - border.width: 2 - border.color: parent.hovered ? Theme.palette.baseColor2 : Theme.palette.statusAppLayout.backgroundColor - } } } } diff --git a/ui/StatusQ/src/StatusQ/Controls/StatusActivityCenterButton.qml b/ui/StatusQ/src/StatusQ/Controls/StatusActivityCenterButton.qml new file mode 100644 index 0000000000..12e7143c78 --- /dev/null +++ b/ui/StatusQ/src/StatusQ/Controls/StatusActivityCenterButton.qml @@ -0,0 +1,65 @@ +import QtQuick 2.14 +import StatusQ.Core 0.1 +import StatusQ.Core.Theme 0.1 +import StatusQ.Components 0.1 + +/*! + \qmltype StatusActivityCenterButton + \inherits StatusFlatRoundButton + \inqmlmodule StatusQ.Controls + \since StatusQ.Controls 0.1 + \brief The StatusActivityCenterButton provides the button for Activity Center popup + + Example of how to use it: + + \qml + StatusActivityCenterButton { + unreadNotificationsCount: activityCenter.unreadNotificationsCount + onClicked: activityCenterPopup.open() + } + \endqml + + For a list of components available see StatusQ. +*/ + +StatusFlatRoundButton { + id: notificationButton + + /*! + \qmlproperty int StatusActivityCenterButton::unreadNotificationsCount + This property holds the count of notifications. + */ + property alias unreadNotificationsCount: statusBadge.value + + implicitWidth: 32 + implicitHeight: 32 + + icon.name: "notification" + icon.height: 21 + type: StatusFlatRoundButton.Type.Secondary + + // initializing the tooltip + tooltip.text: qsTr("Activity") + tooltip.orientation: StatusToolTip.Orientation.Bottom + tooltip.y: parent.height + 12 + + StatusBadge { + id: statusBadge + + visible: value > 0 + anchors.top: parent.top + anchors.left: parent.right + anchors.topMargin: -3 + anchors.leftMargin: { + if (statusBadge.value > 99) { + return -22 + } + if (statusBadge.value > 9) { + return -21 + } + return -18 + } + border.width: 2 + border.color: parent.hovered ? Theme.palette.baseColor2 : Theme.palette.statusAppLayout.backgroundColor + } +} diff --git a/ui/StatusQ/src/StatusQ/Controls/qmldir b/ui/StatusQ/src/StatusQ/Controls/qmldir index 7473560857..863dc5199d 100644 --- a/ui/StatusQ/src/StatusQ/Controls/qmldir +++ b/ui/StatusQ/src/StatusQ/Controls/qmldir @@ -43,3 +43,4 @@ StatusColorSelectorGrid 0.1 StatusColorSelectorGrid.qml StatusSeedPhraseInput 0.1 StatusSeedPhraseInput.qml StatusImageCrop 0.1 StatusImageCrop.qml StatusFloatingButtonsSelector 0.1 StatusFloatingButtonsSelector.qml +StatusActivityCenterButton 0.1 StatusActivityCenterButton.qml