2022-09-15 00:17:55 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
import QtQml.Models 2.14
|
2022-11-22 12:25:39 +01:00
|
|
|
import QtGraphicalEffects 1.14
|
2021-09-28 18:04:06 +03:00
|
|
|
|
2022-07-14 14:03:36 +03:00
|
|
|
import StatusQ.Core 0.1
|
2023-02-15 12:12:12 +01:00
|
|
|
import StatusQ.Core.Theme 0.1
|
2022-09-15 00:17:55 +02:00
|
|
|
import StatusQ.Controls 0.1
|
2023-05-19 19:07:50 +03:00
|
|
|
import StatusQ.Popups 0.1
|
2022-09-15 00:17:55 +02:00
|
|
|
import StatusQ.Popups.Dialog 0.1
|
2022-07-14 14:03:36 +03:00
|
|
|
|
2021-09-28 18:04:06 +03:00
|
|
|
import utils 1.0
|
2021-10-28 23:23:30 +03:00
|
|
|
import shared.views.chat 1.0
|
2021-10-01 18:58:36 +03:00
|
|
|
|
2024-05-22 11:13:39 +03:00
|
|
|
import AppLayouts.Chat.stores 1.0
|
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
StatusDialog {
|
|
|
|
id: root
|
2021-12-17 13:53:10 +01:00
|
|
|
|
2024-05-22 11:13:39 +03:00
|
|
|
property RootStore store
|
|
|
|
property MessageStore 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
|
2023-03-24 16:48:05 +07:00
|
|
|
property string chatId
|
|
|
|
|
2023-05-09 14:31:50 +04:00
|
|
|
readonly property var contactDetails: store ? store.oneToOneChatContact : null
|
|
|
|
readonly property bool isPinActionAvaliable: contactDetails ? contactDetails.isContact : true
|
2021-07-26 13:27:09 -04:00
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
width: 800
|
|
|
|
height: 428
|
|
|
|
padding: 0
|
2021-05-25 15:38:18 -04:00
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
title: root.messageToPin ? qsTr("Pin limit reached") : qsTr("Pinned messages")
|
2022-11-22 12:25:39 +01:00
|
|
|
subtitle: root.messageToPin ? qsTr("Unpin a previous message first")
|
|
|
|
: qsTr("%n message(s)", "", pinnedMessageListView.count)
|
2021-05-25 15:34:46 -04:00
|
|
|
|
2023-05-19 19:07:50 +03:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
function jumpToMessage(messageId) {
|
|
|
|
root.close()
|
|
|
|
root.messageStore.messageModule.jumpToMessage(messageId)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
contentItem: ColumnLayout {
|
2022-11-22 12:25:39 +01:00
|
|
|
id: column
|
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
StatusBaseText {
|
2021-05-25 15:38:18 -04:00
|
|
|
visible: pinnedMessageListView.count === 0
|
2022-04-04 13:26:30 +02:00
|
|
|
text: qsTr("Pinned messages will appear here.")
|
2022-09-15 00:17:55 +02:00
|
|
|
Layout.alignment: Qt.AlignCenter
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
2021-05-25 15:38:18 -04:00
|
|
|
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
|
2022-09-15 00:17:55 +02:00
|
|
|
model: root.pinnedMessagesModel
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: count
|
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
|
2022-07-05 14:12:27 +04:00
|
|
|
|
|
|
|
width: ListView.view.width
|
2021-07-26 13:27:09 -04:00
|
|
|
height: messageItem.height
|
|
|
|
|
2021-10-01 18:58:36 +03:00
|
|
|
MessageView {
|
2021-07-26 13:27:09 -04:00
|
|
|
id: messageItem
|
2022-07-05 14:12:27 +04:00
|
|
|
|
|
|
|
width: parent.width
|
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
rootStore: root.store
|
|
|
|
messageStore: root.messageStore
|
2021-12-17 13:53:10 +01:00
|
|
|
|
|
|
|
messageId: model.id
|
2022-09-30 17:36:49 +03:00
|
|
|
responseToMessageWithId: model.responseToMessageWithId
|
2021-12-17 13:53:10 +01:00
|
|
|
senderId: model.senderId
|
|
|
|
senderDisplayName: model.senderDisplayName
|
2022-09-14 09:35:26 +02:00
|
|
|
senderOptionalName: model.senderOptionalName
|
|
|
|
senderIsEnsVerified: model.senderEnsVerified
|
2022-09-22 01:55:01 +02:00
|
|
|
senderIsAdded: model.senderIsAdded
|
2021-12-17 13:53:10 +01:00
|
|
|
senderIcon: model.senderIcon
|
2023-01-10 13:29:24 +02:00
|
|
|
senderColorHash: model.senderColorHash
|
2022-09-30 17:36:49 +03:00
|
|
|
senderTrustStatus: model.senderTrustStatus
|
2021-12-17 13:53:10 +01:00
|
|
|
amISender: model.amISender
|
2022-07-05 14:12:27 +04:00
|
|
|
messageText: model.messageText
|
2021-12-17 13:53:10 +01:00
|
|
|
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
|
2023-02-15 12:12:12 +01:00
|
|
|
sticker: model.sticker
|
|
|
|
stickerPack: model.stickerPack
|
2023-07-26 17:09:36 +03:00
|
|
|
linkPreviewModel: model.linkPreviewModel
|
2023-08-22 18:46:26 +03:00
|
|
|
links: model.links
|
2022-02-09 01:04:49 +01:00
|
|
|
transactionParams: model.transactionParameters
|
2023-01-10 13:29:24 +02:00
|
|
|
quotedMessageText: model.quotedMessageParsedText
|
|
|
|
quotedMessageFrom: model.quotedMessageFrom
|
|
|
|
quotedMessageContentType: model.quotedMessageContentType
|
|
|
|
quotedMessageDeleted: model.quotedMessageDeleted
|
|
|
|
quotedMessageAuthorDetailsName: model.quotedMessageAuthorName
|
|
|
|
quotedMessageAuthorDetailsDisplayName: model.quotedMessageAuthorDisplayName
|
|
|
|
quotedMessageAuthorDetailsThumbnailImage: model.quotedMessageAuthorThumbnailImage
|
|
|
|
quotedMessageAuthorDetailsEnsVerified: model.quotedMessageAuthorEnsVerified
|
|
|
|
quotedMessageAuthorDetailsIsContact: model.quotedMessageAuthorIsContact
|
|
|
|
quotedMessageAuthorDetailsColorHash: model.quotedMessageAuthorColorHash
|
2024-01-05 16:34:20 +01:00
|
|
|
bridgeName: model.bridgeName
|
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
|
2023-03-24 16:48:05 +07:00
|
|
|
prevMessageAsJsonObj: root.messageStore ? root.messageStore.getMessageByIndexAsJson(index - 1) : {}
|
2021-12-17 13:53:10 +01:00
|
|
|
nextMessageIndex: index + 1
|
2023-03-24 16:48:05 +07:00
|
|
|
nextMessageAsJsonObj: root.messageStore ? root.messageStore.getMessageByIndexAsJson(index + 1) : {}
|
2021-12-17 13:53:10 +01:00
|
|
|
|
|
|
|
// Additional params
|
2022-07-05 14:12:27 +04:00
|
|
|
isInPinnedPopup: true
|
2022-12-26 19:33:27 +03:00
|
|
|
shouldRepeatHeader: true
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
2023-02-15 12:12:12 +01:00
|
|
|
id: mouseArea
|
2021-07-26 13:27:09 -04:00
|
|
|
anchors.fill: parent
|
2023-02-15 12:12:12 +01:00
|
|
|
hoverEnabled: true
|
2021-07-26 13:27:09 -04:00
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
z: 55
|
2023-05-19 19:07:50 +03:00
|
|
|
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
|
|
|
onClicked: (mouse) => {
|
|
|
|
switch (mouse.button) {
|
|
|
|
case Qt.RightButton:
|
|
|
|
Global.openMenu(pinnedPopupMessageContextMenuComponent, this, {
|
|
|
|
messageId: messageItem.messageId,
|
|
|
|
})
|
|
|
|
break
|
|
|
|
case Qt.LeftButton:
|
|
|
|
if (!!root.messageToPin) {
|
|
|
|
if (!radio.checked)
|
|
|
|
radio.checked = true
|
|
|
|
} else {
|
|
|
|
d.jumpToMessage(model.id)
|
|
|
|
}
|
|
|
|
break
|
|
|
|
}
|
2022-09-15 00:17:55 +02:00
|
|
|
}
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
|
2023-02-15 12:12:12 +01:00
|
|
|
StatusFlatRoundButton {
|
|
|
|
id: unpinButton
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: Style.current.bigPadding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.bigPadding
|
|
|
|
z: mouseArea.z + 1
|
|
|
|
width: 32
|
|
|
|
height: 32
|
2023-03-27 20:55:26 +04:00
|
|
|
visible: root.isPinActionAvaliable && !root.messageToPin && (hovered || mouseArea.containsMouse)
|
2023-02-15 12:12:12 +01:00
|
|
|
icon.name: "unpin"
|
|
|
|
tooltip.text: qsTr("Unpin")
|
|
|
|
color: hovered ? Theme.palette.primaryColor2 : Theme.palette.indirectColor1
|
|
|
|
onClicked: {
|
|
|
|
root.messageStore.unpinMessage(model.id)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
StatusRadioButton {
|
2021-07-26 13:27:09 -04:00
|
|
|
id: radio
|
2023-02-15 12:12:12 +01:00
|
|
|
visible: root.messageToPin
|
2021-07-26 13:27:09 -04:00
|
|
|
anchors.right: parent.right
|
2022-09-15 00:17:55 +02:00
|
|
|
anchors.rightMargin: Style.current.bigPadding
|
2021-07-26 13:27:09 -04:00
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
ButtonGroup.group: pinButtonGroup
|
2022-09-15 00:17:55 +02:00
|
|
|
onCheckedChanged: { // NB this should be `onToggled` but MouseArea above handles the whole delegate
|
|
|
|
root.messageToUnpin = checked ? model.id : ""
|
2021-07-22 10:47:15 +03:00
|
|
|
}
|
|
|
|
}
|
2022-09-15 00:17:55 +02:00
|
|
|
|
2023-05-19 19:07:50 +03:00
|
|
|
Component {
|
|
|
|
id: pinnedPopupMessageContextMenuComponent
|
2021-12-17 13:53:10 +01:00
|
|
|
|
2023-05-19 19:07:50 +03:00
|
|
|
StatusMenu {
|
|
|
|
id: messageContextMenu
|
2022-09-19 10:40:02 +02:00
|
|
|
|
2023-05-19 19:07:50 +03:00
|
|
|
property string messageId
|
|
|
|
|
|
|
|
StatusAction {
|
|
|
|
text: qsTr("Unpin")
|
|
|
|
icon.name: "unpin"
|
|
|
|
onTriggered: {
|
|
|
|
root.messageStore.unpinMessage(messageContextMenu.messageId)
|
|
|
|
close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusAction {
|
|
|
|
text: qsTr("Jump to")
|
|
|
|
icon.name: "arrow-up"
|
|
|
|
onTriggered: {
|
|
|
|
d.jumpToMessage(messageContextMenu.messageId)
|
|
|
|
close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onOpened: {
|
|
|
|
messageItem.setMessageActive(model.id, true)
|
|
|
|
}
|
|
|
|
onClosed: {
|
|
|
|
messageItem.setMessageActive(model.id, false)
|
|
|
|
destroy()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-09-19 10:40:02 +02:00
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
}
|
2022-11-22 12:25:39 +01:00
|
|
|
|
2023-02-15 12:12:12 +01:00
|
|
|
layer.enabled: root.visible && !root.messageToPin
|
2022-11-22 12:25:39 +01:00
|
|
|
layer.effect: OpacityMask {
|
|
|
|
maskSource: Rectangle {
|
|
|
|
width: column.width
|
|
|
|
height: column.height
|
|
|
|
radius: background.radius
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
width: parent.width
|
|
|
|
height: parent.radius
|
|
|
|
anchors.top: parent.top
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
}
|
|
|
|
|
2022-09-15 00:17:55 +02:00
|
|
|
footer: StatusDialogFooter {
|
|
|
|
id: footer
|
|
|
|
visible: !!root.messageToPin
|
|
|
|
rightButtons: ObjectModel {
|
|
|
|
StatusButton {
|
|
|
|
visible: footer.visible
|
|
|
|
enabled: !!root.messageToUnpin && pinButtonGroup.checkedButton
|
|
|
|
text: qsTr("Unpin selected message and pin new message")
|
|
|
|
onClicked: {
|
|
|
|
root.messageStore.unpinMessage(root.messageToUnpin)
|
|
|
|
root.messageToUnpin = ""
|
|
|
|
root.messageStore.pinMessage(root.messageToPin)
|
|
|
|
root.messageToPin = ""
|
|
|
|
root.close()
|
|
|
|
}
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
}
|
|
|
|
}
|