2020-08-03 13:17:03 -04:00
|
|
|
import QtQuick 2.12
|
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
import QtQuick.Layouts 1.3
|
|
|
|
import QtQml.Models 2.3
|
2021-08-16 11:11:43 +02:00
|
|
|
import QtQuick.Dialogs 1.0
|
2021-08-06 17:44:57 +02:00
|
|
|
|
|
|
|
import StatusQ.Popups 0.1
|
2021-10-21 00:47:23 +02:00
|
|
|
import StatusQ.Components 0.1
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
import shared 1.0
|
|
|
|
import shared.panels 1.0
|
|
|
|
import shared.popups 1.0
|
|
|
|
import shared.status 1.0
|
2021-10-28 23:23:30 +03:00
|
|
|
import shared.controls.chat 1.0
|
2020-08-03 13:17:03 -04:00
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
StatusPopupMenu {
|
2021-10-21 03:41:54 +03:00
|
|
|
id: root
|
2021-08-06 17:44:57 +02:00
|
|
|
width: emojiContainer.visible ? emojiContainer.width : 176
|
2021-07-16 18:02:47 +03:00
|
|
|
|
2021-10-21 03:41:54 +03:00
|
|
|
property var store
|
2021-05-25 15:34:46 -04:00
|
|
|
property string messageId
|
2021-07-20 11:26:41 -04:00
|
|
|
property int contentType
|
2020-08-03 13:17:03 -04:00
|
|
|
property bool isProfile: false
|
2020-08-27 19:26:12 -04:00
|
|
|
property bool isSticker: false
|
2020-12-08 13:34:02 +01:00
|
|
|
property bool emojiOnly: false
|
2021-05-25 15:34:46 -04:00
|
|
|
property bool hideEmojiPicker: false
|
|
|
|
property bool pinnedMessage: false
|
2021-08-16 15:35:24 +03:00
|
|
|
property bool pinnedPopup: false
|
2021-06-29 10:49:32 -04:00
|
|
|
property bool isText: false
|
|
|
|
property bool isCurrentUser: false
|
2021-08-16 11:11:43 +02:00
|
|
|
property bool isRightClickOnImage: false
|
2021-02-23 11:18:09 +01:00
|
|
|
property string linkUrls: ""
|
2021-02-01 16:29:35 -05:00
|
|
|
property alias emojiContainer: emojiContainer
|
2020-10-02 09:02:56 -04:00
|
|
|
property var identicon: ""
|
|
|
|
property var userName: ""
|
|
|
|
property string nickname: ""
|
|
|
|
property var fromAuthor: ""
|
|
|
|
property var text: ""
|
2021-02-01 15:37:50 -05:00
|
|
|
property var emojiReactionsReactedByUser: []
|
2021-06-29 10:49:32 -04:00
|
|
|
property var onClickEdit: function(){}
|
2021-07-16 18:02:47 +03:00
|
|
|
property var reactionModel
|
2021-08-16 11:11:43 +02:00
|
|
|
property string imageSource: ""
|
2021-08-25 22:31:00 +02:00
|
|
|
property var setXPosition: function() {return 0}
|
|
|
|
property var setYPosition: function() {return 0}
|
2021-07-26 13:27:09 -04:00
|
|
|
property bool canPin: {
|
2021-10-21 03:41:54 +03:00
|
|
|
const nbPinnedMessages = root.store.chatsModelInst.messageView.pinnedMessagesList.count
|
2021-07-26 13:27:09 -04:00
|
|
|
return nbPinnedMessages < Constants.maxNumberOfPins
|
|
|
|
}
|
2021-06-29 10:49:32 -04:00
|
|
|
|
2021-08-25 22:31:00 +02:00
|
|
|
onHeightChanged: {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.y = setYPosition()
|
2021-08-25 22:31:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
onWidthChanged: {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.x = setXPosition()
|
2021-08-25 22:31:00 +02:00
|
|
|
}
|
|
|
|
|
2021-08-16 15:35:24 +03:00
|
|
|
signal shouldCloseParentPopup
|
2021-07-22 10:47:15 +03:00
|
|
|
|
2021-02-01 15:37:50 -05:00
|
|
|
function show(userNameParam, fromAuthorParam, identiconParam, textParam, nicknameParam, emojiReactionsModel) {
|
2020-10-02 09:02:56 -04:00
|
|
|
userName = userNameParam || ""
|
|
|
|
nickname = nicknameParam || ""
|
|
|
|
fromAuthor = fromAuthorParam || ""
|
|
|
|
identicon = identiconParam || ""
|
|
|
|
text = textParam || ""
|
2021-02-01 15:37:50 -05:00
|
|
|
let newEmojiReactions = []
|
|
|
|
if (!!emojiReactionsModel) {
|
|
|
|
emojiReactionsModel.forEach(function (emojiReaction) {
|
|
|
|
newEmojiReactions[emojiReaction.emojiId] = emojiReaction.currentUserReacted
|
|
|
|
})
|
|
|
|
}
|
2021-07-16 18:02:47 +03:00
|
|
|
emojiReactionsReactedByUser = newEmojiReactions;
|
2021-02-01 15:37:50 -05:00
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
/* // copy link feature not ready yet
|
2021-10-21 03:41:54 +03:00
|
|
|
const numLinkUrls = root.linkUrls.split(" ").length
|
2021-02-23 11:18:09 +01:00
|
|
|
copyLinkMenu.enabled = numLinkUrls > 1
|
2021-10-21 03:41:54 +03:00
|
|
|
copyLinkAction.enabled = !!root.linkUrls && numLinkUrls === 1 && !emojiOnly && !root.isProfile
|
2021-08-06 17:44:57 +02:00
|
|
|
*/
|
2021-07-22 10:47:15 +03:00
|
|
|
popup()
|
2020-10-02 09:02:56 -04:00
|
|
|
}
|
|
|
|
|
2021-11-30 15:39:48 -05:00
|
|
|
function openProfileClicked() {
|
|
|
|
openProfilePopup(userName, fromAuthor, identicon, "", nickname);
|
|
|
|
}
|
|
|
|
|
2020-08-03 13:17:03 -04:00
|
|
|
Item {
|
|
|
|
id: emojiContainer
|
|
|
|
width: emojiRow.width
|
|
|
|
height: visible ? emojiRow.height : 0
|
2021-10-21 03:41:54 +03:00
|
|
|
visible: !hideEmojiPicker && (root.emojiOnly || !root.isProfile)
|
2020-08-03 13:17:03 -04:00
|
|
|
Row {
|
|
|
|
id: emojiRow
|
2021-08-06 17:44:57 +02:00
|
|
|
spacing: Style.current.halfPadding
|
|
|
|
leftPadding: Style.current.halfPadding
|
|
|
|
rightPadding: Style.current.halfPadding
|
2021-10-21 03:41:54 +03:00
|
|
|
bottomPadding: root.emojiOnly ? 0 : Style.current.padding
|
2020-08-03 13:17:03 -04:00
|
|
|
|
|
|
|
Repeater {
|
2021-10-21 03:41:54 +03:00
|
|
|
model: root.reactionModel
|
2020-08-03 13:17:03 -04:00
|
|
|
delegate: EmojiReaction {
|
2021-09-28 18:04:06 +03:00
|
|
|
source: Style.svg(filename)
|
2020-08-03 13:17:03 -04:00
|
|
|
emojiId: model.emojiId
|
2021-10-21 03:41:54 +03:00
|
|
|
reactedByUser: !!root.emojiReactionsReactedByUser[model.emojiId]
|
2021-10-01 18:58:36 +03:00
|
|
|
onCloseModal: {
|
|
|
|
chatsModel.toggleReaction(SelectedMessage.messageId, emojiId)
|
2021-10-21 03:41:54 +03:00
|
|
|
root.close()
|
2020-08-12 13:58:19 -04:00
|
|
|
}
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-16 18:02:47 +03:00
|
|
|
Item {
|
2020-08-03 13:17:03 -04:00
|
|
|
id: profileHeader
|
2021-10-21 03:41:54 +03:00
|
|
|
visible: root.isProfile
|
2021-08-06 17:44:57 +02:00
|
|
|
width: parent.width
|
2020-08-03 13:17:03 -04:00
|
|
|
height: visible ? profileImage.height + username.height + Style.current.padding : 0
|
2021-07-16 18:02:47 +03:00
|
|
|
Rectangle {
|
|
|
|
anchors.fill: parent
|
|
|
|
visible: mouseArea.containsMouse
|
|
|
|
color: Style.current.backgroundHover
|
|
|
|
}
|
2021-10-21 00:47:23 +02:00
|
|
|
|
|
|
|
StatusSmartIdenticon {
|
2020-08-03 13:17:03 -04:00
|
|
|
id: profileImage
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: 4
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2021-10-21 00:47:23 +02:00
|
|
|
image.source: identicon
|
|
|
|
image.isIdenticon: true
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: username
|
2021-10-21 03:41:54 +03:00
|
|
|
text: Utils.removeStatusEns(isCurrentUser ? root.store.profileModelInst.ens.preferredUsername || userName : userName)
|
2021-02-15 20:25:07 +04:00
|
|
|
elide: Text.ElideRight
|
|
|
|
maximumLineCount: 3
|
2020-08-03 13:17:03 -04:00
|
|
|
horizontalAlignment: Text.AlignHCenter
|
2021-02-15 20:25:07 +04:00
|
|
|
wrapMode: Text.Wrap
|
2020-08-03 13:17:03 -04:00
|
|
|
anchors.top: profileImage.bottom
|
|
|
|
anchors.topMargin: 4
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.smallPadding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.smallPadding
|
|
|
|
font.weight: Font.Medium
|
|
|
|
font.pixelSize: 15
|
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
2021-07-16 18:02:47 +03:00
|
|
|
id: mouseArea
|
2020-08-03 13:17:03 -04:00
|
|
|
anchors.fill: parent
|
|
|
|
hoverEnabled: true
|
2021-07-16 18:02:47 +03:00
|
|
|
cursorShape: Qt.PointingHandCursor
|
2020-08-03 13:17:03 -04:00
|
|
|
onClicked: {
|
2021-11-30 15:39:48 -05:00
|
|
|
root.openProfileClicked()
|
2021-10-21 03:41:54 +03:00
|
|
|
root.close()
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Separator {
|
|
|
|
anchors.bottom: viewProfileAction.top
|
2021-10-21 03:41:54 +03:00
|
|
|
visible: !root.emojiOnly && !root.hideEmojiPicker
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
/* // copy link feature not ready yet
|
|
|
|
StatusMenuItem {
|
2021-02-23 11:18:09 +01:00
|
|
|
id: copyLinkAction
|
2021-07-16 22:22:50 +02:00
|
|
|
//% "Copy link"
|
|
|
|
text: qsTrId("copy-link")
|
2021-02-23 11:18:09 +01:00
|
|
|
onTriggered: {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.copyToClipboard(linkUrls.split(" ")[0])
|
|
|
|
root.close()
|
2021-02-23 11:18:09 +01:00
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
icon.name: "link"
|
2021-02-23 11:18:09 +01:00
|
|
|
enabled: false
|
|
|
|
}
|
|
|
|
|
2021-10-14 13:48:03 +02:00
|
|
|
// TODO: replace with StatusPopupMenu
|
2021-02-23 11:18:09 +01:00
|
|
|
PopupMenu {
|
|
|
|
id: copyLinkMenu
|
2021-07-16 22:22:50 +02:00
|
|
|
//% "Copy link"
|
|
|
|
title: qsTrId("copy-link")
|
2021-04-07 13:36:30 -04:00
|
|
|
|
2021-02-23 11:18:09 +01:00
|
|
|
Repeater {
|
|
|
|
id: linksRepeater
|
2021-10-21 03:41:54 +03:00
|
|
|
model: root.linkUrls.split(" ")
|
2021-02-23 11:18:09 +01:00
|
|
|
delegate: MenuItem {
|
2021-04-07 13:36:30 -04:00
|
|
|
id: popupMenuItem
|
2021-02-23 11:18:09 +01:00
|
|
|
text: modelData
|
|
|
|
onTriggered: {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.copyToClipboard(modelData)
|
|
|
|
root.close()
|
2021-02-23 11:18:09 +01:00
|
|
|
}
|
2021-04-07 13:36:30 -04:00
|
|
|
contentItem: StyledText {
|
|
|
|
text: popupMenuItem.text
|
|
|
|
font: popupMenuItem.font
|
|
|
|
color: Style.current.textColor
|
|
|
|
horizontalAlignment: Text.AlignLeft
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
elide: Text.ElideRight
|
|
|
|
}
|
|
|
|
background: Rectangle {
|
|
|
|
implicitWidth: 220
|
|
|
|
implicitHeight: 34
|
2021-04-09 09:46:37 -04:00
|
|
|
color: popupMenuItem.highlighted ? Style.current.backgroundHover: Style.current.transparent
|
2021-04-07 13:36:30 -04:00
|
|
|
}
|
2021-02-23 11:18:09 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
*/
|
2021-02-23 11:18:09 +01:00
|
|
|
|
2021-08-16 11:11:43 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: copyImageAction
|
|
|
|
text: qsTr("Copy image")
|
|
|
|
onTriggered: {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.copyImageToClipboard(imageSource ? imageSource : "")
|
|
|
|
root.close()
|
2021-08-16 11:11:43 +02:00
|
|
|
}
|
|
|
|
icon.name: "copy"
|
|
|
|
enabled: isRightClickOnImage
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuItem {
|
|
|
|
id: downloadImageAction
|
|
|
|
text: qsTr("Download image")
|
|
|
|
onTriggered: {
|
|
|
|
fileDialog.open()
|
2021-10-21 03:41:54 +03:00
|
|
|
root.close()
|
2021-08-16 11:11:43 +02:00
|
|
|
}
|
|
|
|
icon.name: "download"
|
|
|
|
enabled: isRightClickOnImage
|
|
|
|
}
|
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
StatusMenuItem {
|
2020-08-03 13:17:03 -04:00
|
|
|
id: viewProfileAction
|
2021-02-18 11:36:05 -05:00
|
|
|
//% "View Profile"
|
2020-08-03 13:17:03 -04:00
|
|
|
text: qsTrId("view-profile")
|
2020-09-17 10:26:26 -04:00
|
|
|
onTriggered: {
|
2021-11-30 15:39:48 -05:00
|
|
|
root.openProfileClicked()
|
2021-10-21 03:41:54 +03:00
|
|
|
root.close()
|
2020-09-17 10:26:26 -04:00
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
icon.name: "profile"
|
|
|
|
enabled: isProfile
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|
2021-06-29 10:49:32 -04:00
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: sendMessageOrReplyTo
|
2021-10-21 03:41:54 +03:00
|
|
|
text: root.isProfile ?
|
2020-08-26 11:52:26 -04:00
|
|
|
//% "Send message"
|
|
|
|
qsTrId("send-message") :
|
2020-08-03 13:17:03 -04:00
|
|
|
//% "Reply to"
|
|
|
|
qsTrId("reply-to")
|
2020-09-17 10:26:26 -04:00
|
|
|
onTriggered: {
|
2021-10-21 03:41:54 +03:00
|
|
|
if (root.isProfile) {
|
2021-10-19 12:27:41 +02:00
|
|
|
appMain.changeAppSectionBySectionType(Constants.appSection.chat)
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.channelView.joinPrivateChat(fromAuthor, "")
|
2020-12-10 12:41:28 +01:00
|
|
|
} else {
|
2021-07-22 10:47:15 +03:00
|
|
|
showReplyArea()
|
2020-12-10 12:41:28 +01:00
|
|
|
}
|
2021-10-21 03:41:54 +03:00
|
|
|
root.close()
|
2020-09-17 10:26:26 -04:00
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
icon.name: "chat"
|
2021-08-16 11:11:43 +02:00
|
|
|
enabled: isProfile || (!hideEmojiPicker && !emojiOnly && !isProfile && !isRightClickOnImage)
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|
2021-07-22 10:47:15 +03:00
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: editMessageAction
|
|
|
|
//% "Edit message"
|
|
|
|
text: qsTrId("edit-message")
|
|
|
|
onTriggered: {
|
|
|
|
onClickEdit();
|
|
|
|
}
|
|
|
|
icon.name: "edit"
|
2021-08-16 11:11:43 +02:00
|
|
|
enabled: isCurrentUser && !hideEmojiPicker && !emojiOnly && !isProfile && !isRightClickOnImage
|
2021-07-16 11:06:52 -04:00
|
|
|
}
|
|
|
|
|
2021-11-11 12:22:03 -04:00
|
|
|
StatusMenuItem {
|
|
|
|
id: copyMessageIdAction
|
|
|
|
text: qsTr("Copy Message Id")
|
|
|
|
icon.name: "chat"
|
|
|
|
enabled: store.isDebugEnabled
|
|
|
|
onTriggered: {
|
|
|
|
root.store.chatsModelInst.copyToClipboard(SelectedMessage.messageId)
|
|
|
|
close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-06 17:44:57 +02:00
|
|
|
StatusMenuItem {
|
|
|
|
id: pinAction
|
|
|
|
text: {
|
|
|
|
if (pinnedMessage) {
|
|
|
|
//% "Unpin"
|
|
|
|
return qsTrId("unpin")
|
|
|
|
}
|
|
|
|
//% "Pin"
|
|
|
|
return qsTrId("pin")
|
|
|
|
|
|
|
|
}
|
2021-07-22 10:47:15 +03:00
|
|
|
onTriggered: {
|
2021-08-06 17:44:57 +02:00
|
|
|
if (pinnedMessage) {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.messageView.unPinMessage(messageId, root.store.chatsModelInst.channelView.activeChannel.id)
|
2021-08-06 17:44:57 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!canPin) {
|
|
|
|
// Open pin modal so that the user can unpin one
|
|
|
|
openPopup(pinnedMessagesPopupComponent, {messageToPin: messageId})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.messageView.pinMessage(messageId, root.store.chatsModelInst.channelView.activeChannel.id)
|
|
|
|
root.close()
|
2021-07-22 10:47:15 +03:00
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
icon.name: "pin"
|
|
|
|
enabled: {
|
2021-08-16 11:11:43 +02:00
|
|
|
if(isProfile || emojiOnly || isRightClickOnImage)
|
2021-08-06 17:44:57 +02:00
|
|
|
return false
|
|
|
|
|
2021-10-21 03:41:54 +03:00
|
|
|
switch (root.store.chatsModelInst.channelView.activeChannel.chatType) {
|
2021-08-06 17:44:57 +02:00
|
|
|
case Constants.chatTypePublic: return false
|
|
|
|
case Constants.chatTypeOneToOne: return true
|
2021-10-29 20:06:18 +02:00
|
|
|
case Constants.chatTypePrivateGroupChat: return root.store.chatsModelInst.channelView.activeChannel.isAdmin(userProfile.pubKey)
|
2021-10-21 03:41:54 +03:00
|
|
|
case Constants.chatTypeCommunity: return root.store.chatsModelInst.communities.activeCommunity.admin
|
2021-08-06 17:44:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusMenuSeparator {
|
2021-08-18 15:37:13 +03:00
|
|
|
visible: deleteMessageAction.enabled && (viewProfileAction.visible
|
|
|
|
|| sendMessageOrReplyTo.visible || editMessageAction.visible || pinAction.visible)
|
2021-07-22 10:47:15 +03:00
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
|
|
|
|
StatusMenuItem {
|
2021-07-26 14:44:25 -04:00
|
|
|
id: deleteMessageAction
|
2021-08-16 11:11:43 +02:00
|
|
|
enabled: isCurrentUser && !isProfile && !emojiOnly && !pinnedPopup && !isRightClickOnImage &&
|
2021-07-20 11:26:41 -04:00
|
|
|
(contentType === Constants.messageType ||
|
|
|
|
contentType === Constants.stickerType ||
|
|
|
|
contentType === Constants.emojiType ||
|
|
|
|
contentType === Constants.imageType ||
|
|
|
|
contentType === Constants.audioType)
|
2021-07-30 12:02:22 -04:00
|
|
|
//% "Delete message"
|
|
|
|
text: qsTrId("delete-message")
|
2021-07-26 14:44:25 -04:00
|
|
|
onTriggered: {
|
2021-10-20 11:50:50 +02:00
|
|
|
if (!localAccountSensitiveSettings.showDeleteMessageWarning) {
|
2021-10-21 03:41:54 +03:00
|
|
|
return root.store.chatsModelInst.messageView.deleteMessage(messageId)
|
2021-07-26 14:44:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
let confirmationDialog = openPopup(genericConfirmationDialog, {
|
2021-07-30 12:02:22 -04:00
|
|
|
//% "Confirm deleting this message"
|
|
|
|
title: qsTrId("confirm-deleting-this-message"),
|
|
|
|
//% "Are you sure you want to delete this message? Be aware that other clients are not guaranteed to delete the message as well."
|
|
|
|
confirmationText: qsTrId("are-you-sure-you-want-to-delete-this-message--be-aware-that-other-clients-are-not-guaranteed-to-delete-the-message-as-well-"),
|
2021-07-26 14:44:25 -04:00
|
|
|
height: 260,
|
|
|
|
"checkbox.visible": true,
|
|
|
|
executeConfirm: function () {
|
|
|
|
if (confirmationDialog.checkbox.checked) {
|
2021-10-20 11:50:50 +02:00
|
|
|
localAccountSensitiveSettings.showDeleteMessageWarning = false
|
2021-07-26 14:44:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
confirmationDialog.close()
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.messageView.deleteMessage(messageId)
|
2021-07-26 14:44:25 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2021-08-06 17:44:57 +02:00
|
|
|
icon.name: "delete"
|
|
|
|
type: StatusMenuItem.Type.Danger
|
2021-07-26 14:44:25 -04:00
|
|
|
}
|
2021-08-16 15:35:24 +03:00
|
|
|
|
|
|
|
StatusMenuItem {
|
2021-10-21 03:41:54 +03:00
|
|
|
enabled: root.pinnedPopup
|
2021-08-16 15:35:24 +03:00
|
|
|
text: qsTr("Jump to")
|
|
|
|
onTriggered: {
|
2021-10-21 03:41:54 +03:00
|
|
|
positionAtMessage(root.messageId)
|
|
|
|
root.close()
|
|
|
|
root.shouldCloseParentPopup()
|
2021-08-16 15:35:24 +03:00
|
|
|
}
|
|
|
|
icon.name: "up"
|
|
|
|
}
|
2021-08-16 11:11:43 +02:00
|
|
|
|
|
|
|
FileDialog {
|
|
|
|
id: fileDialog
|
|
|
|
title: qsTr("Please choose a directory")
|
|
|
|
selectFolder: true
|
|
|
|
modality: Qt.NonModal
|
|
|
|
onAccepted: {
|
2021-10-21 03:41:54 +03:00
|
|
|
root.store.chatsModelInst.downloadImage(imageSource ? imageSource : "", fileDialog.fileUrls)
|
2021-08-16 11:11:43 +02:00
|
|
|
fileDialog.close()
|
|
|
|
}
|
|
|
|
onRejected: {
|
|
|
|
fileDialog.close()
|
|
|
|
}
|
|
|
|
}
|
2020-08-03 13:17:03 -04:00
|
|
|
}
|