2020-12-04 10:38:22 +00:00
|
|
|
import QtQuick 2.13
|
2021-01-25 20:50:42 +00:00
|
|
|
import QtGraphicalEffects 1.13
|
2020-07-15 21:04:14 +00:00
|
|
|
import "../../../../../shared"
|
2021-01-25 20:50:42 +00:00
|
|
|
import "../../../../../shared/status"
|
2020-07-15 21:04:14 +00:00
|
|
|
import "../../../../../imports"
|
|
|
|
|
|
|
|
Item {
|
|
|
|
property var clickMessage: function () {}
|
2021-02-01 18:40:55 +00:00
|
|
|
property int chatHorizontalPadding: Style.current.halfPadding
|
2020-07-15 21:04:14 +00:00
|
|
|
property int chatVerticalPadding: 7
|
2020-12-07 23:38:53 +00:00
|
|
|
property string linkUrls: ""
|
|
|
|
property int contentType: 2
|
2020-12-16 20:50:54 +00:00
|
|
|
property var container
|
feat: whitelist gifs (no url extension needed)
Fixes #1377.
Fixes #1479.
Two sites have been added to the whitelist: giphy.com and tenor.com.
`imageUrls` in its entirety has been removed and instead all links are being handle through the message `linkUrls`. This prevents double-handling of urls that may or may not be images.
The logic to automatically show links previews works like this:
1. If the setting "display chat images" is enabled, all links that *contain* ".png", ".jpg", ".jpeg", ".svg", ".gif" will be automatically shown. If the URL doesn't contain the extension, we are not downloading it. This was meant to be somewhat of a security compromise as we do not want to download each and every link posted in a message just to find out its true content type.
2. If the above setting is *disabled*, then we follow the whitelist settings for tenor and giphy. This allows us to preview gifs that do not have a file extension in their url.
feat: bump status-go to the commit that supports the new whitelist (https://github.com/status-im/status-go/pull/2094), and also lets us get link preview data from urls in the whitelist. NOTE: this commit was branched off status-go `develop`, so once it is merged, and we update this PR to the new commit, we will effectively be getting status-go develop changes. We *could* base that status-go PR off of master if it makes things easier.
fix: height on settings update issue
feat: move date/time of message below links
fix: layout issues when changing setting `neverAskAboutUnfurlingAgain`
feat: Add MessageBorder component to aid in showing rounded corners with different radius
2020-12-11 00:53:44 +00:00
|
|
|
property bool isCurrentUser: false
|
2021-01-25 20:50:42 +00:00
|
|
|
property bool isHovered: false
|
|
|
|
property bool isMessageActive: false
|
2021-04-06 14:59:59 +00:00
|
|
|
property bool headerRepeatCondition: (authorCurrentMsg !== authorPrevMsg || shouldRepeatHeader || dateGroupLbl.visible)
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2020-12-07 23:38:53 +00:00
|
|
|
id: root
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2021-01-25 20:50:42 +00:00
|
|
|
width: parent.width
|
2021-01-26 20:29:33 +00:00
|
|
|
height: messageContainer.height + messageContainer.anchors.topMargin
|
|
|
|
+ (dateGroupLbl.visible ? dateGroupLbl.height + dateGroupLbl.anchors.topMargin : 0)
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2021-01-25 20:50:42 +00:00
|
|
|
MouseArea {
|
2021-02-02 17:04:49 +00:00
|
|
|
enabled: !placeholderMessage
|
2021-01-25 20:50:42 +00:00
|
|
|
anchors.fill: messageContainer
|
2021-03-30 14:13:20 +00:00
|
|
|
acceptedButtons: Qt.RightButton
|
|
|
|
onClicked: messageMouseArea.clicked(mouse)
|
2020-07-15 21:04:14 +00:00
|
|
|
}
|
|
|
|
|
2021-01-25 20:50:42 +00:00
|
|
|
ChatButtons {
|
2021-03-24 17:30:15 +00:00
|
|
|
contentType: root.contentType
|
2021-01-25 20:50:42 +00:00
|
|
|
parentIsHovered: root.isHovered
|
|
|
|
onHoverChanged: root.isHovered = hovered
|
2020-07-15 21:04:14 +00:00
|
|
|
anchors.right: parent.right
|
2021-01-25 20:50:42 +00:00
|
|
|
anchors.rightMargin: 20
|
2021-02-01 19:05:34 +00:00
|
|
|
anchors.top: messageContainer.top
|
2021-01-25 20:50:42 +00:00
|
|
|
// This is not exactly like the design because the hover becomes messed up with the buttons on top of another Message
|
|
|
|
anchors.topMargin: -Style.current.halfPadding
|
2020-07-15 21:04:14 +00:00
|
|
|
}
|
|
|
|
|
2020-07-20 17:34:20 +00:00
|
|
|
Loader {
|
2021-01-25 20:50:42 +00:00
|
|
|
active: typeof messageContextMenu !== "undefined"
|
2020-09-30 18:16:16 +00:00
|
|
|
sourceComponent: Component {
|
2021-01-25 20:50:42 +00:00
|
|
|
Connections {
|
|
|
|
enabled: root.isMessageActive
|
|
|
|
target: messageContextMenu
|
|
|
|
onClosed: root.isMessageActive = false
|
2020-09-30 18:16:16 +00:00
|
|
|
}
|
2020-07-20 17:34:20 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-26 20:29:33 +00:00
|
|
|
DateGroup {
|
|
|
|
id: dateGroupLbl
|
|
|
|
}
|
|
|
|
|
2021-01-25 20:50:42 +00:00
|
|
|
Rectangle {
|
|
|
|
property alias chatText: chatText
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2021-01-25 20:50:42 +00:00
|
|
|
id: messageContainer
|
2021-01-26 20:29:33 +00:00
|
|
|
anchors.top: dateGroupLbl.visible ? dateGroupLbl.bottom : parent.top
|
|
|
|
anchors.topMargin: dateGroupLbl.visible ? Style.current.padding : 0
|
2021-02-22 19:47:32 +00:00
|
|
|
height: childrenRect.height
|
|
|
|
+ (chatName.visible || emojiReactionLoader.active ? Style.current.smallPadding : 0)
|
2021-02-01 18:40:55 +00:00
|
|
|
+ (chatName.visible && emojiReactionLoader.active ? 5 : 0)
|
|
|
|
+ (emojiReactionLoader.active ? emojiReactionLoader.height: 0)
|
|
|
|
+ (retry.visible && !chatTime.visible ? Style.current.smallPadding : 0)
|
2021-01-25 20:50:42 +00:00
|
|
|
width: parent.width
|
|
|
|
|
2021-02-18 19:07:23 +00:00
|
|
|
color: root.isHovered || isMessageActive ? (hasMention ? Style.current.mentionMessageHoverColor : Style.current.backgroundHoverLight) :
|
2021-02-01 18:40:55 +00:00
|
|
|
(hasMention ? Style.current.mentionMessageColor : Style.current.transparent)
|
2021-01-25 20:50:42 +00:00
|
|
|
|
|
|
|
UserImage {
|
|
|
|
id: chatImage
|
2021-04-06 14:59:59 +00:00
|
|
|
active: isMessage && headerRepeatCondition
|
2021-01-25 20:50:42 +00:00
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: Style.current.smallPadding
|
|
|
|
}
|
|
|
|
|
|
|
|
UsernameLabel {
|
|
|
|
id: chatName
|
2021-04-06 14:59:59 +00:00
|
|
|
visible: isMessage && headerRepeatCondition
|
2021-01-25 20:50:42 +00:00
|
|
|
anchors.leftMargin: root.chatHorizontalPadding
|
|
|
|
anchors.top: chatImage.top
|
|
|
|
anchors.left: chatImage.right
|
|
|
|
}
|
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
ChatTime {
|
|
|
|
id: chatTime
|
2021-04-06 14:59:59 +00:00
|
|
|
visible: headerRepeatCondition
|
2021-02-01 18:40:55 +00:00
|
|
|
anchors.verticalCenter: chatName.verticalCenter
|
|
|
|
anchors.left: chatName.right
|
|
|
|
anchors.leftMargin: 4
|
|
|
|
color: Style.current.secondaryText
|
|
|
|
}
|
|
|
|
|
|
|
|
Item {
|
|
|
|
id: messageContent
|
|
|
|
height: childrenRect.height + Style.current.halfPadding
|
2021-01-25 20:50:42 +00:00
|
|
|
anchors.top: chatName.visible ? chatName.bottom : parent.top
|
|
|
|
anchors.left: chatImage.right
|
|
|
|
anchors.leftMargin: root.chatHorizontalPadding
|
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: root.chatHorizontalPadding
|
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
ChatReply {
|
|
|
|
id: chatReply
|
2021-02-08 18:46:20 +00:00
|
|
|
longReply: active && textFieldImplicitWidth > width
|
2021-02-01 18:40:55 +00:00
|
|
|
container: root.container
|
|
|
|
chatHorizontalPadding: root.chatHorizontalPadding
|
2021-02-08 18:46:20 +00:00
|
|
|
width: parent.width
|
2021-02-01 18:40:55 +00:00
|
|
|
}
|
2021-01-25 20:50:42 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
ChatText {
|
|
|
|
readonly property int leftPadding: chatImage.anchors.leftMargin + chatImage.width + root.chatHorizontalPadding
|
|
|
|
id: chatText
|
|
|
|
anchors.top: chatReply.active ? chatReply.bottom : parent.top
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
// using a padding instead of a margin let's us select text more easily
|
|
|
|
anchors.leftMargin: -leftPadding
|
|
|
|
textField.leftPadding: leftPadding
|
|
|
|
textField.rightPadding: Style.current.bigPadding
|
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: chatImageContent
|
|
|
|
active: isImage
|
|
|
|
anchors.top: chatReply.bottom
|
|
|
|
z: 51
|
|
|
|
|
|
|
|
sourceComponent: Component {
|
|
|
|
ChatImage {
|
|
|
|
imageSource: image
|
|
|
|
imageWidth: 200
|
|
|
|
onClicked: root.clickMessage(false, false, true, image)
|
|
|
|
container: root.container
|
|
|
|
}
|
2020-09-30 18:01:20 +00:00
|
|
|
}
|
|
|
|
}
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
Loader {
|
|
|
|
id: stickerLoader
|
|
|
|
active: contentType === Constants.stickerType
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: active ? Style.current.halfPadding : 0
|
|
|
|
sourceComponent: Component {
|
|
|
|
Rectangle {
|
|
|
|
id: stickerContainer
|
|
|
|
color: Style.current.transparent
|
|
|
|
border.color: root.isHovered ? Qt.darker(Style.current.darkGrey, 1.1) : Style.current.grey
|
|
|
|
border.width: 1
|
|
|
|
radius: 16
|
|
|
|
width: stickerId.width + 2 * root.chatVerticalPadding
|
|
|
|
height: stickerId.height + 2 * root.chatVerticalPadding
|
|
|
|
|
|
|
|
Sticker {
|
|
|
|
id: stickerId
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: root.chatVerticalPadding
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: root.chatVerticalPadding
|
|
|
|
contentType: root.contentType
|
|
|
|
container: root.container
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
MessageMouseArea {
|
|
|
|
id: messageMouseArea
|
|
|
|
anchors.fill: stickerLoader.active ? stickerLoader : chatText
|
|
|
|
}
|
|
|
|
|
|
|
|
Loader {
|
|
|
|
id: linksLoader
|
|
|
|
active: !!root.linkUrls
|
|
|
|
anchors.top: chatText.bottom
|
|
|
|
anchors.topMargin: active ? Style.current.halfPadding : 0
|
|
|
|
|
|
|
|
sourceComponent: Component {
|
|
|
|
LinksMessage {
|
|
|
|
linkUrls: root.linkUrls
|
2021-01-25 20:50:42 +00:00
|
|
|
container: root.container
|
2021-02-01 18:40:55 +00:00
|
|
|
isCurrentUser: root.isCurrentUser
|
2021-01-25 20:50:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
Loader {
|
|
|
|
id: audioPlayerLoader
|
|
|
|
active: isAudio
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: active ? Style.current.halfPadding : 0
|
2020-07-15 21:04:14 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
sourceComponent: Component {
|
|
|
|
AudioPlayer {
|
|
|
|
audioSource: audio
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-07-16 14:51:12 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
Loader {
|
|
|
|
id: transactionBubbleLoader
|
|
|
|
active: contentType === Constants.transactionType
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: active ? (chatName.visible ? 4 : 6) : 0
|
|
|
|
sourceComponent: Component {
|
|
|
|
TransactionBubble {}
|
|
|
|
}
|
|
|
|
}
|
2021-01-25 20:50:42 +00:00
|
|
|
}
|
2020-07-14 15:35:21 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
|
2021-01-25 20:50:42 +00:00
|
|
|
Retry {
|
|
|
|
id: retry
|
2021-02-01 18:40:55 +00:00
|
|
|
anchors.left: chatTime.visible ? chatTime.right : messageContent.left
|
|
|
|
anchors.leftMargin: chatTime.visible ? chatHorizontalPadding : 0
|
|
|
|
anchors.top: chatTime.visible ? undefined : messageContent.bottom
|
|
|
|
anchors.topMargin: chatTime.visible ? 0 : -4
|
|
|
|
anchors.verticalCenter: chatTime.visible ? chatTime.verticalCenter : undefined
|
2020-10-23 19:46:44 +00:00
|
|
|
}
|
2021-02-01 18:40:55 +00:00
|
|
|
}
|
2020-10-23 19:46:44 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
Loader {
|
|
|
|
active: hasMention
|
|
|
|
height: messageContainer.height
|
|
|
|
anchors.left: messageContainer.left
|
2020-07-30 16:07:41 +00:00
|
|
|
|
2021-02-01 18:40:55 +00:00
|
|
|
sourceComponent: Component {
|
|
|
|
Rectangle {
|
|
|
|
id: mentionBorder
|
|
|
|
color: Style.current.mentionColor
|
|
|
|
width: 2
|
|
|
|
height: parent.height
|
2020-09-30 18:45:45 +00:00
|
|
|
}
|
2020-07-30 16:07:41 +00:00
|
|
|
}
|
|
|
|
}
|
2020-08-12 15:01:03 +00:00
|
|
|
|
2021-02-09 20:40:39 +00:00
|
|
|
HoverHandler {
|
2021-04-07 13:59:42 +00:00
|
|
|
enabled: !messageContextMenu.opened && !profilePopupOpened && !popupOpened
|
2021-02-09 20:40:39 +00:00
|
|
|
onHoveredChanged: {
|
|
|
|
root.isHovered = hovered;
|
2021-01-25 20:50:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 15:01:03 +00:00
|
|
|
Loader {
|
|
|
|
id: emojiReactionLoader
|
2021-02-01 20:37:50 +00:00
|
|
|
active: emojiReactionsModel.length
|
2021-01-25 20:50:42 +00:00
|
|
|
anchors.bottom: messageContainer.bottom
|
|
|
|
anchors.bottomMargin: Style.current.smallPadding
|
|
|
|
anchors.left: messageContainer.left
|
|
|
|
anchors.leftMargin: messageContainer.chatText.textField.leftPadding
|
2020-08-12 15:01:03 +00:00
|
|
|
|
2020-09-30 18:45:45 +00:00
|
|
|
sourceComponent: Component {
|
2021-01-25 20:50:42 +00:00
|
|
|
EmojiReactions {
|
|
|
|
onHoverChanged: root.isHovered = hovered
|
|
|
|
}
|
2020-09-30 18:45:45 +00:00
|
|
|
}
|
2020-08-12 15:01:03 +00:00
|
|
|
}
|
2020-07-15 21:04:14 +00:00
|
|
|
}
|