diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml index 454fe9ffa8..0b0f1bb05e 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatImage.qml @@ -9,29 +9,19 @@ Rectangle { property string imageSource: "" id: imageChatBox - height: imageMessage.paintedHeight - width: imageMessage.paintedWidth + 2 * chatHorizontalPadding + height: imageMessage.height + width: imageMessage.width + 2 * chatHorizontalPadding radius: 16 visible: isImage color: "transparent" - Image { + + ImageLoader { id: imageMessage - source: imageSource - anchors.horizontalCenter: parent.horizontalCenter + verticalPadding: imageChatBox.chatVerticalPadding anchors.top: parent.top anchors.topMargin: imageChatBox.chatVerticalPadding - fillMode: Image.PreserveAspectFit - width: sourceSize.width > imageWidth ? imageWidth : sourceSize.width - onStatusChanged: { - if (imageMessage.status == Image.Error) { - imageMessage.height = 0 - imageMessage.visible = false - imageChatBox.height = 0 - imageChatBox.visible = false - } else if (imageMessage.status == Image.Ready) { - messageItem.scrollToBottom(true, messageItem) - } - } + source: imageSource + imageWidth: imageChatBox.imageWidth } } diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml index cf74935f02..70fe120c33 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml @@ -62,6 +62,8 @@ Item { active: isImage sourceComponent: chatImageComponent anchors.left: chatImage.right + anchors.leftMargin: 8 + anchors.top: chatReply.bottom } Component { diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageLoader.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageLoader.qml new file mode 100644 index 0000000000..453744d0a1 --- /dev/null +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageLoader.qml @@ -0,0 +1,49 @@ +import QtQuick 2.3 +import "../../../../../shared" +import "../../../../../imports" + +Item { + property int verticalPadding: 0 + property int imageWidth: 350 + property url source + + id: imageContainer + width: loadingImage.visible ? loadingImage.width : imageMessage.width + height: loadingImage.visible ? loadingImage.height : imageMessage.paintedHeight + + Rectangle { + id: loadingImage + property bool hasError: false + width: hasError ? 200 : imageContainer.imageWidth + height: hasError ? 75 : imageContainer.imageWidth + border.width: 1 + border.color: Style.current.border + radius: Style.current.radius + + StyledText { + text: loadingImage.hasError ? qsTr("Error loading the image") : qsTr("Loading image...") + color: loadingImage.hasError ? Style.current.red : Style.current.textColor + font.pixelSize: 15 + anchors.verticalCenter: parent.verticalCenter + anchors.horizontalCenter: parent.horizontalCenter + } + } + + Image { + id: imageMessage + width: sourceSize.width > imageWidth ? imageWidth : sourceSize.width + fillMode: Image.PreserveAspectFit + source: imageContainer.source + onStatusChanged: { + if (imageMessage.status === Image.Error) { + loadingImage.hasError = true + imageMessage.height = 0 + imageMessage.source = "" + imageMessage.visible = false + } else if (imageMessage.status === Image.Ready) { + loadingImage.visible = false + scrollToBottom(true, messageItem) + } + } + } +} diff --git a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageMessage.qml b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageMessage.qml index bf7376e8a5..8f3a07601d 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageMessage.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageMessage.qml @@ -5,7 +5,6 @@ import "../../../../../imports" Rectangle { property int chatVerticalPadding: 12 property int chatHorizontalPadding: 12 - property int imageWidth: 350 id: imageChatBox height: { @@ -17,7 +16,16 @@ Rectangle { } color: isCurrentUser ? Style.current.blue : Style.current.lightBlue border.color: "transparent" - width: imageWidth + 2 * chatHorizontalPadding + width: { + let w = 0 + for (let i = 0; i < imageRepeater.count; i++) { + if (imageRepeater.itemAt(i).width > w) { + w = imageRepeater.itemAt(i).width + } + } + return w + 2 * chatHorizontalPadding + } + radius: 16 Repeater { @@ -30,47 +38,11 @@ Rectangle { return imageUrls.split(" ") } - Item { - id: imageContainer - width: loadingImage.visible ? loadingImage.width : imageMessage.width - height: loadingImage.visible ? loadingImage.height : imageMessage.paintedHeight - anchors.top: (index == 0) ? parent.top: parent.children[index-1].bottom - anchors.topMargin: imageChatBox.chatVerticalPadding - - Rectangle { - id: loadingImage - property bool hasError: false - width: hasError ? 200 : 400 - height: hasError ? 75 : 400 - border.width: 1 - border.color: Style.current.border - radius: Style.current.radius - - StyledText { - text: loadingImage.hasError ? qsTr("Error loading the image") : qsTr("Loading image...") - color: loadingImage.hasError ? Style.current.red : Style.current.textColor - font.pixelSize: 15 - anchors.verticalCenter: parent.verticalCenter - anchors.horizontalCenter: parent.horizontalCenter - } - } - - Image { - id: imageMessage - sourceSize.width: imageChatBox.imageWidth - source: modelData - onStatusChanged: { - if (imageMessage.status === Image.Error) { - loadingImage.hasError = true - imageMessage.height = 0 - imageMessage.source = "" - imageMessage.visible = false - } else if (imageMessage.status === Image.Ready) { - loadingImage.visible = false - scrollToBottom(true, messageItem) - } - } - } + ImageLoader { + verticalPadding: imageChatBox.chatVerticalPadding + anchors.top: (index === 0) ? parent.top: parent.children[index-1].bottom + anchors.topMargin: verticalPadding + source: modelData } } diff --git a/ui/nim-status-client.pro b/ui/nim-status-client.pro index 6eb54a0843..a3ba431fc5 100644 --- a/ui/nim-status-client.pro +++ b/ui/nim-status-client.pro @@ -123,6 +123,7 @@ DISTFILES += \ app/AppLayouts/Chat/ChatColumn/MessageComponents/ChatTime.qml \ app/AppLayouts/Chat/ChatColumn/MessageComponents/CompactMessage.qml \ app/AppLayouts/Chat/ChatColumn/MessageComponents/DateGroup.qml \ + app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageLoader.qml \ app/AppLayouts/Chat/ChatColumn/MessageComponents/ImageMessage.qml \ app/AppLayouts/Chat/ChatColumn/MessageComponents/MessageMouseArea.qml \ app/AppLayouts/Chat/ChatColumn/MessageComponents/NormalMessage.qml \