feat(activity-center): Add details view dialog for contact requests
Fixes: #8461
This commit is contained in:
parent
07523d2c85
commit
0a37716c7c
|
@ -18,6 +18,7 @@ Item {
|
||||||
signal declineClicked()
|
signal declineClicked()
|
||||||
signal blockClicked()
|
signal blockClicked()
|
||||||
signal profileClicked()
|
signal profileClicked()
|
||||||
|
signal detailsClicked()
|
||||||
|
|
||||||
implicitWidth: Math.max(textItem.width, buttons.width)
|
implicitWidth: Math.max(textItem.width, buttons.width)
|
||||||
implicitHeight: Math.max(textItem.height, buttons.height)
|
implicitHeight: Math.max(textItem.height, buttons.height)
|
||||||
|
@ -54,5 +55,6 @@ Item {
|
||||||
onDeclineClicked: root.declineClicked()
|
onDeclineClicked: root.declineClicked()
|
||||||
onProfileClicked: root.profileClicked()
|
onProfileClicked: root.profileClicked()
|
||||||
onBlockClicked: root.blockClicked()
|
onBlockClicked: root.blockClicked()
|
||||||
|
onDetailsClicked: root.detailsClicked()
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -0,0 +1,99 @@
|
||||||
|
import QtQuick 2.14
|
||||||
|
import QtQuick.Controls 2.14
|
||||||
|
import QtQuick.Layouts 1.14
|
||||||
|
import QtQml.Models 2.14
|
||||||
|
|
||||||
|
import StatusQ.Core 0.1
|
||||||
|
import StatusQ.Popups.Dialog 0.1
|
||||||
|
import StatusQ.Controls 0.1
|
||||||
|
import StatusQ.Core.Theme 0.1
|
||||||
|
import StatusQ.Components 0.1
|
||||||
|
import StatusQ.Core.Utils 0.1 as CoreUtils
|
||||||
|
|
||||||
|
import shared 1.0
|
||||||
|
import utils 1.0
|
||||||
|
|
||||||
|
StatusDialog {
|
||||||
|
id: root
|
||||||
|
|
||||||
|
property StatusMessageDetails messageDetails
|
||||||
|
property string timestampString
|
||||||
|
property string timestampTooltipString
|
||||||
|
|
||||||
|
signal accepted
|
||||||
|
signal declined
|
||||||
|
|
||||||
|
anchors.centerIn: parent
|
||||||
|
width: 638
|
||||||
|
padding: Style.current.bigPadding
|
||||||
|
|
||||||
|
title: qsTr("Review Contact Request")
|
||||||
|
RowLayout {
|
||||||
|
id: messageRow
|
||||||
|
spacing: 8
|
||||||
|
width: parent.width
|
||||||
|
|
||||||
|
Item {
|
||||||
|
Layout.preferredWidth: root.messageDetails.sender.profileImage.assetSettings.width
|
||||||
|
Layout.preferredHeight: profileImage.height
|
||||||
|
Layout.alignment: Qt.AlignTop
|
||||||
|
Layout.leftMargin: -Style.current.halfPadding
|
||||||
|
Layout.topMargin: 2
|
||||||
|
|
||||||
|
StatusSmartIdenticon {
|
||||||
|
id: profileImage
|
||||||
|
name: root.messageDetails.sender.displayName
|
||||||
|
asset: root.messageDetails.sender.profileImage.assetSettings
|
||||||
|
ringSettings: root.messageDetails.sender.profileImage.ringSettings
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ColumnLayout {
|
||||||
|
spacing: 2
|
||||||
|
Layout.alignment: Qt.AlignTop
|
||||||
|
Layout.fillWidth: true
|
||||||
|
|
||||||
|
StatusMessageHeader {
|
||||||
|
sender: root.messageDetails.sender
|
||||||
|
amISender: root.messageDetails.amISender
|
||||||
|
messageOriginInfo: root.messageDetails.messageOriginInfo
|
||||||
|
tertiaryDetail: Utils.getElidedCompressedPk(sender.id)
|
||||||
|
timestamp.text: root.timestampString
|
||||||
|
timestamp.tooltip.text: root.timestampTooltipString
|
||||||
|
}
|
||||||
|
|
||||||
|
RowLayout {
|
||||||
|
spacing: 2
|
||||||
|
Layout.fillWidth: true
|
||||||
|
|
||||||
|
StatusBaseText {
|
||||||
|
text: CoreUtils.Utils.stripHtmlTags(root.messageDetails.messageText)
|
||||||
|
wrapMode: Text.Wrap
|
||||||
|
font.pixelSize: 15
|
||||||
|
Layout.alignment: Qt.AlignVCenter
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.rightMargin: -Style.current.halfPadding
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
footer: StatusDialogFooter {
|
||||||
|
rightButtons: ObjectModel {
|
||||||
|
StatusButton {
|
||||||
|
text: qsTr("Accept Contact Request")
|
||||||
|
onClicked: {
|
||||||
|
root.accepted()
|
||||||
|
root.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
StatusButton {
|
||||||
|
type: StatusBaseButton.Type.Danger
|
||||||
|
text: qsTr("Reject Contact Request")
|
||||||
|
onClicked: {
|
||||||
|
root.declined()
|
||||||
|
root.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -10,6 +10,7 @@ import shared.panels 1.0
|
||||||
import utils 1.0
|
import utils 1.0
|
||||||
|
|
||||||
import "../panels"
|
import "../panels"
|
||||||
|
import "../popups"
|
||||||
|
|
||||||
ActivityNotificationMessage {
|
ActivityNotificationMessage {
|
||||||
id: root
|
id: root
|
||||||
|
@ -33,5 +34,22 @@ ActivityNotificationMessage {
|
||||||
root.store.contactsStore.dismissContactRequest(senderId)
|
root.store.contactsStore.dismissContactRequest(senderId)
|
||||||
root.store.contactsStore.blockContact(senderId)
|
root.store.contactsStore.blockContact(senderId)
|
||||||
}
|
}
|
||||||
|
onDetailsClicked: {
|
||||||
|
Global.openPopup(reviewContactRequestPopupComponent,
|
||||||
|
{
|
||||||
|
messageDetails: root.messageDetails,
|
||||||
|
timestampString: root.timestampString,
|
||||||
|
timestampTooltipString: root.timestampTooltipString
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Component {
|
||||||
|
id: reviewContactRequestPopupComponent
|
||||||
|
ReviewContactRequestPopup {
|
||||||
|
id: reviewRequestPopup
|
||||||
|
onAccepted: root.store.contactsStore.acceptContactRequest(notification.message.senderId)
|
||||||
|
onDeclined: root.store.contactsStore.dismissContactRequest(notification.message.senderId)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,6 +116,7 @@ ActivityNotificationBase {
|
||||||
elide: Text.ElideRight
|
elide: Text.ElideRight
|
||||||
font.pixelSize: 15
|
font.pixelSize: 15
|
||||||
Layout.alignment: Qt.AlignVCenter
|
Layout.alignment: Qt.AlignVCenter
|
||||||
|
Layout.fillWidth: true
|
||||||
Layout.maximumWidth: 400 // From designs, fixed value to align all possible CTAs
|
Layout.maximumWidth: 400 // From designs, fixed value to align all possible CTAs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ Row {
|
||||||
signal declineClicked()
|
signal declineClicked()
|
||||||
signal blockClicked()
|
signal blockClicked()
|
||||||
signal profileClicked()
|
signal profileClicked()
|
||||||
|
signal detailsClicked()
|
||||||
|
|
||||||
StatusFlatRoundButton {
|
StatusFlatRoundButton {
|
||||||
id: declineBtn
|
id: declineBtn
|
||||||
|
@ -65,6 +66,12 @@ Row {
|
||||||
onTriggered: root.profileClicked()
|
onTriggered: root.profileClicked()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StatusAction {
|
||||||
|
text: qsTr("Details")
|
||||||
|
icon.name: "info"
|
||||||
|
onTriggered: root.detailsClicked()
|
||||||
|
}
|
||||||
|
|
||||||
StatusMenuSeparator {}
|
StatusMenuSeparator {}
|
||||||
|
|
||||||
StatusAction {
|
StatusAction {
|
||||||
|
|
Loading…
Reference in New Issue