fix: fix chat height being too high in compact mode

This commit is contained in:
Jonathan Rainville 2020-09-30 16:40:54 -04:00 committed by Iuri Matias
parent fe3995bb3d
commit 261460f8fb
5 changed files with 111 additions and 102 deletions

View File

@ -1,26 +1,12 @@
import QtQuick 2.3 import QtQuick 2.3
import "../../../../../imports" import "../../../../../imports"
Rectangle { ImageLoader {
property int chatVerticalPadding: 12 property int chatVerticalPadding: 12
property int chatHorizontalPadding: 12 property int chatHorizontalPadding: 12
property int imageWidth: 250
property string imageSource: "" property string imageSource: ""
id: imageChatBox id: imageMessage
height: imageMessage.height + imageChatBox.chatVerticalPadding verticalPadding: chatVerticalPadding
width: imageMessage.width + 2 * chatHorizontalPadding source: imageSource
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
}
} }

View File

@ -2,61 +2,71 @@ import QtQuick 2.3
import "../../../../../shared" import "../../../../../shared"
import "../../../../../imports" import "../../../../../imports"
Rectangle { Loader {
property alias textField: lblReplyMessage property int textFieldWidth: item ? item.textField.width : 0
property bool longReply: false property bool longReply: false
property color elementsColor: isCurrentUser ? Style.current.chatReplyCurrentUser : Style.current.secondaryText property color elementsColor: isCurrentUser ? Style.current.chatReplyCurrentUser : Style.current.secondaryText
id: chatReply id: root
visible: responseTo != "" && replyMessageIndex > -1 active: 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 { sourceComponent: Component {
id: lblReplyAuthor Rectangle {
text: "↳" + repliedMessageAuthor property alias textField: lblReplyMessage
color: chatReply.elementsColor
readOnly: true
selectByMouse: true
wrapMode: Text.Wrap
anchors.left: parent.left
anchors.right: parent.right
}
ChatImage { id: chatReply
id: imgReplyImage visible: responseTo != "" && replyMessageIndex > -1
visible: repliedMessageType == Constants.imageType // childrenRect.height shows a binding loop for soem reason, so we use heights instead
imageWidth: 50 height: this.visible ? lblReplyAuthor.height + ((repliedMessageType === Constants.imageType ? imgReplyImage.height : lblReplyMessage.height) + 5 + 8) : 0
imageSource: repliedMessageImage color: Style.current.transparent
anchors.top: lblReplyAuthor.bottom
anchors.topMargin: 5
anchors.left: parent.left
chatHorizontalPadding: 0
}
StyledTextEdit { StyledTextEdit {
id: lblReplyMessage id: lblReplyAuthor
visible: repliedMessageType != Constants.imageType text: "↳" + repliedMessageAuthor
anchors.top: lblReplyAuthor.bottom color: root.elementsColor
anchors.topMargin: 5 readOnly: true
text: Emoji.parse(Utils.linkifyAndXSS(repliedMessageContent), "26x26"); selectByMouse: true
textFormat: Text.RichText wrapMode: Text.Wrap
color: chatReply.elementsColor anchors.left: parent.left
readOnly: true anchors.right: parent.right
selectByMouse: true }
wrapMode: Text.Wrap
anchors.left: parent.left
anchors.right: chatReply.longReply ? parent.right : undefined
z: 51
}
Separator { ChatImage {
anchors.top: repliedMessageType == Constants.imageType ? imgReplyImage.bottom : lblReplyMessage.bottom id: imgReplyImage
anchors.topMargin: repliedMessageType == Constants.imageType ? 15 : 8 visible: repliedMessageType == Constants.imageType
anchors.left: lblReplyMessage.left imageWidth: 50
anchors.right: lblReplyMessage.right imageSource: repliedMessageImage
anchors.rightMargin: chatTextItem.chatHorizontalPadding anchors.top: lblReplyAuthor.bottom
color: chatReply.elementsColor 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
}
}
} }
} }

View File

@ -159,7 +159,7 @@ Item {
active: emojiReactions !== "" active: emojiReactions !== ""
anchors.top: chatText.bottom anchors.top: chatText.bottom
anchors.left: chatText.left anchors.left: chatText.left
anchors.topMargin: 2 anchors.topMargin: active ? 2 : 0
sourceComponent: Component { sourceComponent: Component {
EmojiReactions {} EmojiReactions {}

View File

@ -61,7 +61,7 @@ Item {
return h; return h;
} }
width: { width: {
switch(contentType){ switch(contentType) {
case Constants.stickerType: case Constants.stickerType:
return stickerId.width + (2 * chatBox.chatHorizontalPadding); return stickerId.width + (2 * chatBox.chatHorizontalPadding);
case Constants.imageType: case Constants.imageType:
@ -71,8 +71,8 @@ Item {
return 400; return 400;
} }
let baseWidth = chatText.width; let baseWidth = chatText.width;
if (chatReply.visible && chatText.width < chatReply.textField.width) { if (chatReply.visible && chatText.width < chatReply.textFieldWidth) {
baseWidth = chatReply.textField.width baseWidth = chatReply.textFieldWidth
} }
return baseWidth + 2 * chatHorizontalPadding return baseWidth + 2 * chatHorizontalPadding
} }
@ -113,15 +113,22 @@ Item {
Loader { Loader {
id: chatImageContent id: chatImageContent
active: isImage active: isImage && !!image
sourceComponent: chatImageComponent anchors.top: parent.top
} anchors.topMargin: Style.current.smallPadding
anchors.left: parent.left
anchors.leftMargin: chatBox.chatHorizontalPadding
Component { sourceComponent: Component {
id: chatImageComponent Item {
ChatImage { width: chatImageComponent.width + 2 * chatBox.chatHorizontalPadding
imageSource: image height: chatImageComponent.height
imageWidth: 250 ChatImage {
id: chatImageComponent
imageSource: image
imageWidth: 250
}
}
} }
} }

View File

@ -2,31 +2,37 @@ import QtQuick 2.3
import "../../../../../shared" import "../../../../../shared"
import "../../../../../imports" import "../../../../../imports"
Rectangle { Loader {
id: chatImage active: isMessage && authorCurrentMsg !== authorPrevMsg
visible: isMessage && authorCurrentMsg != authorPrevMsg height: active ? item.height : 0
width: identiconImage.width
height: identiconImage.height
border.width: 1
border.color: Style.current.border
radius: 50
Image { sourceComponent: Component {
id: identiconImage Rectangle {
width: 36 id: chatImage
height: chatImage.visible ? 36 : 0 width: identiconImage.width
fillMode: Image.PreserveAspectFit height: identiconImage.height
source: !isCurrentUser ? identicon : profileModel.profile.identicon border.width: 1
mipmap: true border.color: Style.current.border
smooth: false radius: 50
antialiasing: true
MouseArea { Image {
cursorShape: Qt.PointingHandCursor id: identiconImage
acceptedButtons: Qt.LeftButton | Qt.RightButton width: 36
anchors.fill: parent height: 36
onClicked: { fillMode: Image.PreserveAspectFit
clickMessage(true) 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)
}
}
} }
} }
} }