2021-05-25 15:34:46 -04:00
|
|
|
import QtQuick 2.13
|
2021-07-26 13:27:09 -04:00
|
|
|
import QtQuick.Controls 2.3
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Controls 0.1 as StatusQControls
|
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
2021-10-28 23:23:30 +03:00
|
|
|
import shared.views 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.popups 1.0
|
2021-10-28 23:23:30 +03:00
|
|
|
import shared.views.chat 1.0
|
2021-10-01 18:58:36 +03:00
|
|
|
|
|
|
|
import "../controls"
|
|
|
|
import "../panels"
|
|
|
|
//TODO remove or make view?
|
|
|
|
import "../views"
|
2021-05-25 15:34:46 -04:00
|
|
|
|
2021-10-14 13:33:34 +02:00
|
|
|
// TODO: replace with StatusMOdal
|
2021-05-25 15:34:46 -04:00
|
|
|
ModalPopup {
|
2021-12-17 13:53:10 +01:00
|
|
|
id: popup
|
|
|
|
|
2022-01-19 10:59:08 -05:00
|
|
|
property var store
|
2021-10-01 18:58:36 +03:00
|
|
|
property var messageStore
|
2021-12-17 13:53:10 +01:00
|
|
|
property var pinnedMessagesModel //this doesn't belong to the messageStore, it is a part of the ChatContentStore, but we didn't introduce it yet.
|
2021-07-26 13:27:09 -04:00
|
|
|
property string messageToPin
|
|
|
|
property string messageToUnpin
|
2022-01-05 16:50:03 +01:00
|
|
|
property var emojiReactionsModel
|
2021-07-26 13:27:09 -04:00
|
|
|
|
2021-05-25 15:34:46 -04:00
|
|
|
header: Item {
|
|
|
|
height: childrenRect.height
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: title
|
2022-04-04 13:26:30 +02:00
|
|
|
text: !!popup.messageToPin ? qsTr("Pin limit reached") :
|
|
|
|
qsTr("Pinned messages")
|
2021-05-25 15:34:46 -04:00
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
font.bold: true
|
|
|
|
font.pixelSize: 17
|
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
2021-05-25 15:38:18 -04:00
|
|
|
property int nbMessages: pinnedMessageListView.count
|
|
|
|
|
2021-05-25 15:34:46 -04:00
|
|
|
id: nbPinnedMessages
|
2021-07-26 13:27:09 -04:00
|
|
|
text: {
|
2021-12-17 13:53:10 +01:00
|
|
|
if (!!popup.messageToPin) {
|
2022-04-04 13:26:30 +02:00
|
|
|
return qsTr("Unpin a previous message first")
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
|
2022-04-04 13:26:30 +02:00
|
|
|
return nbMessages > 1 ? qsTr("%1 messages").arg(nbMessages) :
|
|
|
|
qsTr("%1 message").arg(nbMessages)
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.top: title.bottom
|
|
|
|
anchors.topMargin: 2
|
|
|
|
font.pixelSize: 15
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
anchors.top: nbPinnedMessages.bottom
|
|
|
|
anchors.topMargin: Style.current.padding
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: -Style.current.padding
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-25 15:38:18 -04:00
|
|
|
Item {
|
|
|
|
anchors.fill: parent
|
2021-05-25 15:34:46 -04:00
|
|
|
|
2021-05-25 15:38:18 -04:00
|
|
|
StyledText {
|
|
|
|
visible: pinnedMessageListView.count === 0
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Pinned messages will appear here.")
|
2021-05-25 15:38:18 -04:00
|
|
|
anchors.centerIn: parent
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
}
|
|
|
|
|
2021-07-26 13:27:09 -04:00
|
|
|
ButtonGroup {
|
|
|
|
id: pinButtonGroup
|
|
|
|
}
|
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
StatusListView {
|
2021-05-25 15:38:18 -04:00
|
|
|
id: pinnedMessageListView
|
2021-12-17 13:53:10 +01:00
|
|
|
model: popup.pinnedMessagesModel
|
2021-05-25 15:38:18 -04:00
|
|
|
height: parent.height
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: -Style.current.padding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: -Style.current.padding
|
|
|
|
topMargin: Style.current.halfPadding
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: -Style.current.halfPadding
|
2021-12-17 13:53:10 +01:00
|
|
|
|
2021-07-26 13:27:09 -04:00
|
|
|
delegate: Item {
|
2021-10-01 18:58:36 +03:00
|
|
|
id: messageDelegate
|
2021-08-16 15:35:24 +03:00
|
|
|
property var listView: ListView.view
|
2021-07-26 13:27:09 -04:00
|
|
|
width: parent.width
|
|
|
|
height: messageItem.height
|
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
MessageView {
|
2021-07-26 13:27:09 -04:00
|
|
|
id: messageItem
|
2022-02-11 16:41:34 -05:00
|
|
|
store: popup.store
|
2021-12-17 13:53:10 +01:00
|
|
|
messageStore: popup.messageStore
|
|
|
|
messageContextMenu: msgContextMenu
|
|
|
|
|
|
|
|
messageId: model.id
|
|
|
|
responseToMessageWithId: model.responseToMessageWithId
|
|
|
|
senderId: model.senderId
|
|
|
|
senderDisplayName: model.senderDisplayName
|
|
|
|
senderLocalName: model.senderLocalName
|
|
|
|
senderIcon: model.senderIcon
|
|
|
|
amISender: model.amISender
|
|
|
|
message: model.messageText
|
|
|
|
messageImage: model.messageImage
|
|
|
|
messageTimestamp: model.timestamp
|
|
|
|
messageOutgoingStatus: model.outgoingStatus
|
|
|
|
messageContentType: model.contentType
|
|
|
|
pinnedMessage: model.pinned
|
2022-01-05 16:50:03 +01:00
|
|
|
messagePinnedBy: model.pinnedBy
|
2021-12-20 15:21:35 +01:00
|
|
|
reactionsModel: model.reactions
|
2022-06-28 14:11:18 -04:00
|
|
|
senderTrustStatus: model.senderTrustStatus
|
2022-01-25 13:56:53 +01:00
|
|
|
linkUrls: model.links
|
2022-02-01 13:45:28 -05:00
|
|
|
isInPinnedPopup: true
|
2022-02-09 01:04:49 +01:00
|
|
|
transactionParams: model.transactionParameters
|
2021-12-17 13:53:10 +01:00
|
|
|
|
|
|
|
// This is possible since we have all data loaded before we load qml.
|
|
|
|
// When we fetch messages to fulfill a gap we have to set them at once.
|
|
|
|
prevMessageIndex: index - 1
|
|
|
|
prevMessageAsJsonObj: popup.messageStore? popup.messageStore.getMessageByIndexAsJson(index - 1) : {}
|
|
|
|
nextMessageIndex: index + 1
|
2022-01-05 16:50:03 +01:00
|
|
|
nextMessageAsJsonObj: popup.messageStore? popup.messageStore.getMessageByIndexAsJson(index + 1) : {}
|
2021-12-17 13:53:10 +01:00
|
|
|
|
|
|
|
// Additional params
|
|
|
|
forceHoverHandler: !popup.messageToPin
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
2021-12-17 13:53:10 +01:00
|
|
|
enabled: !!popup.messageToPin
|
2021-07-26 13:27:09 -04:00
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
z: 55
|
|
|
|
onClicked: radio.toggle()
|
|
|
|
}
|
|
|
|
|
2021-10-25 14:30:23 +02:00
|
|
|
StatusQControls.StatusRadioButton {
|
2021-07-26 13:27:09 -04:00
|
|
|
id: radio
|
2021-12-17 13:53:10 +01:00
|
|
|
visible: !!popup.messageToPin
|
2021-07-26 13:27:09 -04:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 18
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
ButtonGroup.group: pinButtonGroup
|
|
|
|
function toggle() {
|
|
|
|
radio.checked = !radio.checked
|
|
|
|
if (radio.checked) {
|
2021-12-17 13:53:10 +01:00
|
|
|
popup.messageToUnpin = model.id
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
2021-07-22 10:47:15 +03:00
|
|
|
}
|
|
|
|
}
|
2021-05-25 15:38:18 -04:00
|
|
|
}
|
2022-02-09 10:43:23 +01:00
|
|
|
}
|
2021-11-02 20:58:48 +01:00
|
|
|
MessageContextMenuView {
|
|
|
|
id: msgContextMenu
|
2022-01-05 16:50:03 +01:00
|
|
|
reactionModel: popup.emojiReactionsModel
|
2022-01-19 10:59:08 -05:00
|
|
|
store: popup.store
|
2021-11-02 20:58:48 +01:00
|
|
|
pinnedPopup: true
|
|
|
|
pinnedMessage: true
|
|
|
|
onShouldCloseParentPopup: {
|
|
|
|
popup.close()
|
|
|
|
}
|
2021-12-17 13:53:10 +01:00
|
|
|
|
|
|
|
onPinMessage: {
|
|
|
|
popup.messageStore.pinMessage(messageId)
|
|
|
|
}
|
|
|
|
|
|
|
|
onUnpinMessage: {
|
|
|
|
popup.messageStore.unpinMessage(messageId)
|
|
|
|
}
|
2021-12-20 15:21:35 +01:00
|
|
|
|
|
|
|
onToggleReaction: {
|
|
|
|
popup.messageStore.toggleReaction(messageId, emojiId)
|
|
|
|
}
|
2022-01-05 16:50:03 +01:00
|
|
|
|
|
|
|
onOpenProfileClicked: {
|
2022-06-20 17:48:38 +03:00
|
|
|
Global.openProfilePopup(publicKey, null, state)
|
2022-01-05 16:50:03 +01:00
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-25 15:38:18 -04:00
|
|
|
|
2021-07-26 13:27:09 -04:00
|
|
|
footer: Item {
|
|
|
|
width: parent.width
|
2021-09-23 12:07:07 +02:00
|
|
|
height: btnUnpin.height
|
2021-07-26 13:27:09 -04:00
|
|
|
|
2021-10-19 13:58:06 +02:00
|
|
|
StatusQControls.StatusButton {
|
2021-07-26 13:27:09 -04:00
|
|
|
id: btnUnpin
|
2021-12-17 13:53:10 +01:00
|
|
|
visible: !!popup.messageToPin
|
|
|
|
enabled: !!popup.messageToUnpin
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Unpin")
|
2021-10-25 14:30:23 +02:00
|
|
|
type: StatusQControls.StatusBaseButton.Type.Danger
|
2021-07-26 13:27:09 -04:00
|
|
|
anchors.right: parent.right
|
|
|
|
onClicked: {
|
2021-12-17 13:53:10 +01:00
|
|
|
popup.messageStore.unpinMessage(popup.messageToUnpin)
|
|
|
|
popup.messageToUnpin = ""
|
2022-02-03 10:57:38 -05:00
|
|
|
popup.messageStore.pinMessage(popup.messageToPin)
|
2021-12-17 13:53:10 +01:00
|
|
|
popup.messageToPin = ""
|
2021-07-26 13:27:09 -04:00
|
|
|
popup.close()
|
|
|
|
}
|
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
}
|
|
|
|
}
|