diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml index 8b853306bd..52f4f9624f 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml @@ -1,26 +1,12 @@ import QtQuick 2.3 import "../../../../../imports" -Rectangle { +ImageLoader { property int chatVerticalPadding: 12 property int chatHorizontalPadding: 12 - property int imageWidth: 250 property string imageSource: "" - id: imageChatBox - height: imageMessage.height + imageChatBox.chatVerticalPadding - width: imageMessage.width + 2 * chatHorizontalPadding - radius: 16 - visible: isImage - color: "transparent" - - - ImageLoader { - id: imageMessage - verticalPadding: imageChatBox.chatVerticalPadding - anchors.top: parent.top - anchors.topMargin: imageChatBox.chatVerticalPadding - source: imageSource - imageWidth: imageChatBox.imageWidth - } + id: imageMessage + verticalPadding: chatVerticalPadding + source: imageSource } diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatReply.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatReply.qml index c8481cfcd0..f88903ed7d 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatReply.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatReply.qml @@ -2,61 +2,71 @@ import QtQuick 2.3 import "../../../../../shared" import "../../../../../imports" -Rectangle { - property alias textField: lblReplyMessage +Loader { + property int textFieldWidth: item ? item.textField.width : 0 property bool longReply: false property color elementsColor: isCurrentUser ? Style.current.chatReplyCurrentUser : Style.current.secondaryText - id: chatReply - visible: responseTo != "" && replyMessageIndex > -1 - // childrenRect.height shows a binding loop for soem reason, so we use heights instead - height: this.visible ? lblReplyAuthor.height + ((repliedMessageType === Constants.imageType ? imgReplyImage.height : lblReplyMessage.height) + 5 + 8) : 0 - color: Style.current.transparent + id: root + active: responseTo != "" && replyMessageIndex > -1 - StyledTextEdit { - id: lblReplyAuthor - text: "↳" + repliedMessageAuthor - color: chatReply.elementsColor - readOnly: true - selectByMouse: true - wrapMode: Text.Wrap - anchors.left: parent.left - anchors.right: parent.right - } + sourceComponent: Component { + Rectangle { + property alias textField: lblReplyMessage - ChatImage { - id: imgReplyImage - visible: repliedMessageType == Constants.imageType - imageWidth: 50 - imageSource: repliedMessageImage - anchors.top: lblReplyAuthor.bottom - anchors.topMargin: 5 - anchors.left: parent.left - chatHorizontalPadding: 0 - } + id: chatReply + visible: responseTo != "" && replyMessageIndex > -1 + // childrenRect.height shows a binding loop for soem reason, so we use heights instead + height: this.visible ? lblReplyAuthor.height + ((repliedMessageType === Constants.imageType ? imgReplyImage.height : lblReplyMessage.height) + 5 + 8) : 0 + color: Style.current.transparent - StyledTextEdit { - id: lblReplyMessage - visible: repliedMessageType != Constants.imageType - anchors.top: lblReplyAuthor.bottom - anchors.topMargin: 5 - text: Emoji.parse(Utils.linkifyAndXSS(repliedMessageContent), "26x26"); - textFormat: Text.RichText - color: chatReply.elementsColor - readOnly: true - selectByMouse: true - wrapMode: Text.Wrap - anchors.left: parent.left - anchors.right: chatReply.longReply ? parent.right : undefined - z: 51 - } + StyledTextEdit { + id: lblReplyAuthor + text: "↳" + repliedMessageAuthor + color: root.elementsColor + readOnly: true + selectByMouse: true + wrapMode: Text.Wrap + anchors.left: parent.left + anchors.right: parent.right + } - Separator { - anchors.top: repliedMessageType == Constants.imageType ? imgReplyImage.bottom : lblReplyMessage.bottom - anchors.topMargin: repliedMessageType == Constants.imageType ? 15 : 8 - anchors.left: lblReplyMessage.left - anchors.right: lblReplyMessage.right - anchors.rightMargin: chatTextItem.chatHorizontalPadding - color: chatReply.elementsColor + ChatImage { + id: imgReplyImage + visible: repliedMessageType == Constants.imageType + imageWidth: 50 + imageSource: repliedMessageImage + anchors.top: lblReplyAuthor.bottom + anchors.topMargin: 5 + anchors.left: parent.left + chatHorizontalPadding: 0 + } + + StyledTextEdit { + id: lblReplyMessage + visible: repliedMessageType != Constants.imageType + anchors.top: lblReplyAuthor.bottom + anchors.topMargin: 5 + text: Emoji.parse(Utils.linkifyAndXSS(repliedMessageContent), "26x26"); + textFormat: Text.RichText + color: root.elementsColor + readOnly: true + selectByMouse: true + wrapMode: Text.Wrap + anchors.left: parent.left + anchors.right: root.longReply ? parent.right : undefined + z: 51 + } + + Separator { + anchors.top: repliedMessageType == Constants.imageType ? imgReplyImage.bottom : lblReplyMessage.bottom + anchors.topMargin: repliedMessageType == Constants.imageType ? 15 : 8 + anchors.left: lblReplyMessage.left + anchors.right: lblReplyMessage.right + anchors.rightMargin: chatTextItem.chatHorizontalPadding + color: root.elementsColor + } + } } } + diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml index 582b460eab..f4b9586a75 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml @@ -159,7 +159,7 @@ Item { active: emojiReactions !== "" anchors.top: chatText.bottom anchors.left: chatText.left - anchors.topMargin: 2 + anchors.topMargin: active ? 2 : 0 sourceComponent: Component { EmojiReactions {} diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/NormalMessage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/NormalMessage.qml index 129aadd101..2532e3e5bb 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/NormalMessage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/NormalMessage.qml @@ -61,7 +61,7 @@ Item { return h; } width: { - switch(contentType){ + switch(contentType) { case Constants.stickerType: return stickerId.width + (2 * chatBox.chatHorizontalPadding); case Constants.imageType: @@ -71,8 +71,8 @@ Item { return 400; } let baseWidth = chatText.width; - if (chatReply.visible && chatText.width < chatReply.textField.width) { - baseWidth = chatReply.textField.width + if (chatReply.visible && chatText.width < chatReply.textFieldWidth) { + baseWidth = chatReply.textFieldWidth } return baseWidth + 2 * chatHorizontalPadding } @@ -113,15 +113,22 @@ Item { Loader { id: chatImageContent - active: isImage - sourceComponent: chatImageComponent - } + active: isImage && !!image + anchors.top: parent.top + anchors.topMargin: Style.current.smallPadding + anchors.left: parent.left + anchors.leftMargin: chatBox.chatHorizontalPadding - Component { - id: chatImageComponent - ChatImage { - imageSource: image - imageWidth: 250 + sourceComponent: Component { + Item { + width: chatImageComponent.width + 2 * chatBox.chatHorizontalPadding + height: chatImageComponent.height + ChatImage { + id: chatImageComponent + imageSource: image + imageWidth: 250 + } + } } } diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/UserImage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/UserImage.qml index 6ac6f1c6a2..363f402608 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/UserImage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/UserImage.qml @@ -2,31 +2,37 @@ import QtQuick 2.3 import "../../../../../shared" import "../../../../../imports" -Rectangle { - id: chatImage - visible: isMessage && authorCurrentMsg != authorPrevMsg - width: identiconImage.width - height: identiconImage.height - border.width: 1 - border.color: Style.current.border - radius: 50 +Loader { + active: isMessage && authorCurrentMsg !== authorPrevMsg + height: active ? item.height : 0 - Image { - id: identiconImage - width: 36 - height: chatImage.visible ? 36 : 0 - fillMode: Image.PreserveAspectFit - source: !isCurrentUser ? identicon : profileModel.profile.identicon - mipmap: true - smooth: false - antialiasing: true + sourceComponent: Component { + Rectangle { + id: chatImage + width: identiconImage.width + height: identiconImage.height + border.width: 1 + border.color: Style.current.border + radius: 50 - MouseArea { - cursorShape: Qt.PointingHandCursor - acceptedButtons: Qt.LeftButton | Qt.RightButton - anchors.fill: parent - onClicked: { - clickMessage(true) + Image { + id: identiconImage + width: 36 + height: 36 + fillMode: Image.PreserveAspectFit + source: !isCurrentUser ? identicon : profileModel.profile.identicon + mipmap: true + smooth: false + antialiasing: true + + MouseArea { + cursorShape: Qt.PointingHandCursor + acceptedButtons: Qt.LeftButton | Qt.RightButton + anchors.fill: parent + onClicked: { + clickMessage(true) + } + } } } }