2022-09-15 19:34:41 +03:00
|
|
|
import QtQuick 2.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
|
|
|
import shared 1.0
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: root
|
|
|
|
|
2022-11-30 15:15:29 +04:00
|
|
|
/* required */ property int filteredIndex
|
|
|
|
/* required */ property var notification
|
|
|
|
/* required */ property var store
|
|
|
|
/* required */ property var activityCenterStore
|
2022-09-15 19:34:41 +03:00
|
|
|
|
2022-09-23 15:24:50 +03:00
|
|
|
property alias bodyComponent: bodyLoader.sourceComponent
|
|
|
|
property alias badgeComponent: badgeLoader.sourceComponent
|
2022-09-27 20:21:00 +04:00
|
|
|
property alias ctaComponent: ctaLoader.sourceComponent
|
2022-09-15 19:34:41 +03:00
|
|
|
|
2022-11-16 21:17:38 +04:00
|
|
|
signal closeActivityCenter()
|
|
|
|
|
2023-01-23 13:00:06 +04:00
|
|
|
implicitHeight: Math.max(60, bodyLoader.height + bodyLoader.anchors.topMargin * 2 +
|
2022-10-20 15:57:41 +04:00
|
|
|
(dateGroupLabel.visible ? dateGroupLabel.height : 0) +
|
2022-10-29 11:17:35 +04:00
|
|
|
(badgeLoader.item ? badgeLoader.height + Style.current.smallPadding : 0))
|
2022-10-19 16:54:45 +04:00
|
|
|
|
|
|
|
StatusDateGroupLabel {
|
|
|
|
id: dateGroupLabel
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.left: parent.left
|
2022-11-30 15:15:29 +04:00
|
|
|
messageTimestamp: notification ? notification.timestamp : 0
|
|
|
|
previousMessageTimestamp: !notification || filteredIndex === 0 || !notification.previousTimestamp ?
|
|
|
|
0 : notification.previousTimestamp
|
2022-10-19 16:54:45 +04:00
|
|
|
visible: text !== ""
|
|
|
|
}
|
2022-09-15 19:34:41 +03:00
|
|
|
|
2023-01-23 13:00:06 +04:00
|
|
|
Rectangle {
|
|
|
|
id: backgroundRect
|
|
|
|
anchors.fill: parent
|
|
|
|
anchors.topMargin: dateGroupLabel.visible ? dateGroupLabel.height : 0
|
|
|
|
radius: 6
|
|
|
|
color: notification && !notification.read ? Theme.palette.primaryColor3 : "transparent"
|
|
|
|
Behavior on color { ColorAnimation { duration: 200 } }
|
|
|
|
}
|
|
|
|
|
2022-09-23 15:24:50 +03:00
|
|
|
Loader {
|
|
|
|
id: bodyLoader
|
2022-10-19 16:54:45 +04:00
|
|
|
anchors.top: dateGroupLabel.visible ? dateGroupLabel.bottom : parent.top
|
2023-01-23 13:00:06 +04:00
|
|
|
anchors.topMargin: Style.current.smallPadding
|
2022-09-27 20:21:00 +04:00
|
|
|
anchors.right: ctaLoader.left
|
2023-02-15 16:24:18 +04:00
|
|
|
anchors.rightMargin: Style.current.smallPadding
|
2022-09-23 15:24:50 +03:00
|
|
|
anchors.left: parent.left
|
2023-02-15 16:24:18 +04:00
|
|
|
clip: true
|
2022-09-23 15:24:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: badgeLoader
|
2022-10-01 16:07:14 +04:00
|
|
|
anchors.bottom: parent.bottom
|
2023-01-23 13:00:06 +04:00
|
|
|
anchors.bottomMargin: Style.current.smallPadding
|
2022-09-23 15:24:50 +03:00
|
|
|
anchors.left: parent.left
|
2022-11-16 21:17:38 +04:00
|
|
|
anchors.leftMargin: 50 // TODO find a way to align with the text of the message
|
2022-09-23 15:24:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
2022-09-27 20:21:00 +04:00
|
|
|
id: ctaLoader
|
2022-10-05 18:51:42 +04:00
|
|
|
anchors.verticalCenter: bodyLoader.verticalCenter
|
2022-09-15 19:34:41 +03:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.padding
|
2022-09-23 15:24:50 +03:00
|
|
|
|
|
|
|
sourceComponent: StatusFlatRoundButton {
|
2022-10-26 20:00:20 +04:00
|
|
|
icon.width: 20
|
|
|
|
icon.height: 20
|
2022-11-29 12:57:07 +01:00
|
|
|
icon.name: "checkmark"
|
2022-11-30 15:15:29 +04:00
|
|
|
icon.color: notification && notification.read ? icon.disabledColor : Theme.palette.primaryColor1
|
|
|
|
tooltip.text: notification && notification.read ? qsTr("Mark as Unread") : qsTr("Mark as Read")
|
2022-09-23 15:24:50 +03:00
|
|
|
tooltip.orientation: StatusToolTip.Orientation.Left
|
|
|
|
tooltip.x: -tooltip.width - Style.current.padding
|
|
|
|
tooltip.y: 4
|
|
|
|
onClicked: {
|
|
|
|
notification.read ?
|
2022-10-26 20:00:20 +04:00
|
|
|
root.activityCenterStore.markActivityCenterNotificationUnread(root.notification) :
|
|
|
|
root.activityCenterStore.markActivityCenterNotificationRead(root.notification)
|
2022-09-23 15:24:50 +03:00
|
|
|
}
|
2022-09-15 19:34:41 +03:00
|
|
|
}
|
|
|
|
}
|
2022-11-29 12:57:07 +01:00
|
|
|
}
|