fix: fix chat height being too high in compact mode
This commit is contained in:
parent
fe3995bb3d
commit
261460f8fb
|
@ -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
|
||||
}
|
||||
|
|
|
@ -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
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -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 {}
|
||||
|
|
|
@ -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
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -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)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue