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
|
|
|
|
|
|
|
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
|
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-19 13:58:06 +02:00
|
|
|
import StatusQ.Controls 0.1 as StatusQControls
|
|
|
|
|
2021-10-14 13:33:34 +02:00
|
|
|
// TODO: replace with StatusMOdal
|
2021-05-25 15:34:46 -04:00
|
|
|
ModalPopup {
|
2021-10-01 18:58:36 +03:00
|
|
|
property var rootStore
|
|
|
|
property var messageStore
|
2021-07-26 13:27:09 -04:00
|
|
|
property bool userCanPin: {
|
2021-10-22 23:49:47 +03:00
|
|
|
switch (popup.rootStore.chatsModelInst.channelView.activeChannel.chatType) {
|
2021-07-26 13:27:09 -04:00
|
|
|
case Constants.chatTypePublic: return false
|
|
|
|
case Constants.chatTypeStatusUpdate: return false
|
|
|
|
case Constants.chatTypeOneToOne: return true
|
2021-10-22 23:49:47 +03:00
|
|
|
case Constants.chatTypePrivateGroupChat: return popup.rootStore.chatsModelInst.channelView.activeChannel.isAdmin(profileModel.profile.pubKey)
|
|
|
|
case Constants.chatTypeCommunity: return popup.rootStore.chatsModelInst.communities.activeCommunity.admin
|
2021-07-26 13:27:09 -04:00
|
|
|
default: return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
property string messageToPin
|
|
|
|
property string messageToUnpin
|
|
|
|
|
2021-05-25 15:34:46 -04:00
|
|
|
id: popup
|
|
|
|
|
|
|
|
header: Item {
|
|
|
|
height: childrenRect.height
|
|
|
|
width: parent.width
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: title
|
2021-07-30 12:02:22 -04:00
|
|
|
//% "Pin limit reached"
|
|
|
|
text: !!messageToPin ? qsTrId("pin-limit-reached") :
|
2021-07-26 13:27:09 -04:00
|
|
|
//% "Pinned messages"
|
|
|
|
qsTrId("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: {
|
|
|
|
if (!!messageToPin) {
|
2021-07-30 12:02:22 -04:00
|
|
|
//% "Unpin a previous message first"
|
|
|
|
return qsTrId("unpin-a-previous-message-first")
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
//% "%1 messages"
|
|
|
|
return nbMessages > 1 ? qsTrId("-1-messages").arg(nbMessages) :
|
|
|
|
//% "%1 message"
|
|
|
|
qsTrId("-1-message").arg(nbMessages)
|
|
|
|
}
|
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
|
2021-07-16 22:22:50 +02:00
|
|
|
//% "Pinned messages will appear here."
|
|
|
|
text: qsTrId("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
|
|
|
|
}
|
|
|
|
|
2021-05-25 15:38:18 -04:00
|
|
|
ListView {
|
|
|
|
id: pinnedMessageListView
|
2021-10-22 23:49:47 +03:00
|
|
|
model: popup.rootStore.chatsModelInst.messageView.pinnedMessagesList
|
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
|
|
|
|
clip: true
|
2021-08-16 15:35:24 +03: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
|
2021-10-01 18:58:36 +03:00
|
|
|
rootStore: popup.rootStore
|
|
|
|
messageStore: popup.messageStore
|
|
|
|
/////////////TODO Remove
|
2021-07-26 13:27:09 -04:00
|
|
|
fromAuthor: model.fromAuthor
|
|
|
|
chatId: model.chatId
|
|
|
|
userName: model.userName
|
|
|
|
alias: model.alias
|
|
|
|
localName: model.localName
|
|
|
|
message: model.message
|
|
|
|
plainText: model.plainText
|
|
|
|
identicon: model.identicon
|
|
|
|
isCurrentUser: model.isCurrentUser
|
|
|
|
timestamp: model.timestamp
|
|
|
|
sticker: model.sticker
|
|
|
|
contentType: model.contentType
|
|
|
|
outgoingStatus: model.outgoingStatus
|
|
|
|
responseTo: model.responseTo
|
|
|
|
imageClick: imagePopup.openPopup.bind(imagePopup)
|
|
|
|
messageId: model.messageId
|
|
|
|
emojiReactions: model.emojiReactions
|
|
|
|
linkUrls: model.linkUrls
|
|
|
|
communityId: model.communityId
|
|
|
|
hasMention: model.hasMention
|
|
|
|
stickerPackId: model.stickerPackId
|
|
|
|
timeout: model.timeout
|
2021-07-22 10:47:15 +03:00
|
|
|
pinnedMessage: true
|
2021-07-26 13:27:09 -04:00
|
|
|
pinnedBy: model.pinnedBy
|
|
|
|
forceHoverHandler: !messageToPin
|
|
|
|
activityCenterMessage: false
|
|
|
|
isEdited: model.isEdited
|
|
|
|
showEdit: false
|
2021-10-01 18:58:36 +03:00
|
|
|
messageContextMenu: msgContextMenu
|
|
|
|
Component.onCompleted: {
|
|
|
|
messageStore.fromAuthor = model.fromAuthor;
|
|
|
|
messageStore.chatId = model.chatId;
|
|
|
|
messageStore.userName = model.userName;
|
|
|
|
messageStore.alias = model.alias;
|
|
|
|
messageStore.localName = model.localName;
|
|
|
|
messageStore.message = model.message;
|
|
|
|
messageStore.plainText = model.plainText;
|
|
|
|
messageStore.identicon = model.identicon;
|
|
|
|
messageStore.isCurrentUser = model.isCurrentUser;
|
|
|
|
messageStore.timestamp = model.timestamp;
|
|
|
|
messageStore.sticker = model.sticker;
|
|
|
|
messageStore.contentType = model.contentType;
|
|
|
|
messageStore.outgoingStatus = model.outgoingStatus;
|
|
|
|
messageStore.responseTo = model.responseTo;
|
|
|
|
messageStore.imageClick = imagePopup.openPopup.bind(imagePopup);
|
|
|
|
messageStore.messageId = model.messageId;
|
|
|
|
messageStore.emojiReactions = model.emojiReactions;
|
|
|
|
messageStore.linkUrls = model.linkUrls;
|
|
|
|
messageStore.communityId = model.communityId;
|
|
|
|
messageStore.hasMention = model.hasMention;
|
|
|
|
messageStore.stickerPackId = model.stickerPackId;
|
|
|
|
messageStore.timeout = model.timeout;
|
|
|
|
messageStore.pinnedMessage = true;
|
|
|
|
messageStore.pinnedBy = model.pinnedBy;
|
|
|
|
messageStore.forceHoverHandler = !messageToPin;
|
|
|
|
messageStore.activityCenterMessage = false;
|
|
|
|
messageStore.isEdited = model.isEdited;
|
|
|
|
messageStore.showEdit = false;
|
|
|
|
messageStore.messageContextMenu = msgContextMenu;
|
|
|
|
}
|
2021-07-26 13:27:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
enabled: !!messageToPin
|
|
|
|
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
|
|
|
|
visible: !!messageToPin
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: 18
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
ButtonGroup.group: pinButtonGroup
|
|
|
|
function toggle() {
|
|
|
|
radio.checked = !radio.checked
|
|
|
|
if (radio.checked) {
|
|
|
|
messageToUnpin = model.messageId
|
|
|
|
}
|
2021-07-22 10:47:15 +03:00
|
|
|
}
|
|
|
|
}
|
2021-05-25 15:38:18 -04:00
|
|
|
}
|
2021-11-02 20:58:48 +01:00
|
|
|
}
|
|
|
|
MessageContextMenuView {
|
|
|
|
id: msgContextMenu
|
|
|
|
pinnedPopup: true
|
|
|
|
pinnedMessage: true
|
|
|
|
store: popup.rootStore
|
|
|
|
reactionModel: popup.rootStore.emojiReactionsModel
|
|
|
|
onShouldCloseParentPopup: {
|
|
|
|
popup.close()
|
|
|
|
}
|
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
|
|
|
|
visible: !!messageToPin
|
|
|
|
enabled: !!messageToUnpin
|
2021-07-30 12:02:22 -04:00
|
|
|
//% "Unpin"
|
|
|
|
text: qsTrId("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-10-22 23:49:47 +03:00
|
|
|
const chatId = popup.rootStore.chatsModelInst.channelView.activeChannel.id
|
|
|
|
popup.rootStore.chatsModelInst.messageView.unPinMessage(messageToUnpin, chatId)
|
|
|
|
popup.rootStore.chatsModelInst.messageView.pinMessage(messageToPin, chatId)
|
2021-07-26 13:27:09 -04:00
|
|
|
messageToUnpin = messageToPin = ""
|
|
|
|
popup.close()
|
|
|
|
}
|
|
|
|
}
|
2021-05-25 15:34:46 -04:00
|
|
|
}
|
|
|
|
}
|