2020-07-15 17:04:14 -04:00
|
|
|
import QtQuick 2.3
|
|
|
|
import "../../../../../imports"
|
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
property int chatVerticalPadding: 12
|
|
|
|
property int chatHorizontalPadding: 12
|
2020-09-30 16:01:08 +02:00
|
|
|
signal clicked(string source)
|
2020-07-15 17:04:14 -04:00
|
|
|
|
|
|
|
id: imageChatBox
|
|
|
|
height: {
|
2020-09-30 14:45:45 -04:00
|
|
|
let h = appSettings.compactMode ? 0 : chatVerticalPadding
|
2020-07-15 17:04:14 -04:00
|
|
|
for (let i = 0; i < imageRepeater.count; i++) {
|
2020-07-23 12:23:20 -04:00
|
|
|
h += imageRepeater.itemAt(i).height
|
2020-07-15 17:04:14 -04:00
|
|
|
}
|
|
|
|
return h + chatVerticalPadding * imageRepeater.count
|
|
|
|
}
|
|
|
|
color: isCurrentUser ? Style.current.blue : Style.current.lightBlue
|
|
|
|
border.color: "transparent"
|
2020-07-23 14:20:57 -04:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2020-07-15 17:04:14 -04:00
|
|
|
radius: 16
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: imageRepeater
|
2020-07-20 11:38:24 -04:00
|
|
|
model: {
|
|
|
|
if (!imageUrls) {
|
|
|
|
return []
|
|
|
|
}
|
|
|
|
|
|
|
|
return imageUrls.split(" ")
|
|
|
|
}
|
2020-07-15 17:04:14 -04:00
|
|
|
|
2020-07-23 14:20:57 -04:00
|
|
|
ImageLoader {
|
|
|
|
verticalPadding: imageChatBox.chatVerticalPadding
|
|
|
|
anchors.top: (index === 0) ? parent.top: parent.children[index-1].bottom
|
|
|
|
anchors.topMargin: verticalPadding
|
2020-08-12 11:01:03 -04:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2020-07-23 14:20:57 -04:00
|
|
|
source: modelData
|
2020-09-30 16:01:08 +02:00
|
|
|
onClicked: {
|
|
|
|
imageChatBox.clicked(source)
|
|
|
|
}
|
2020-07-15 17:04:14 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-16 10:51:12 -04:00
|
|
|
RectangleCorner {}
|
2020-07-15 17:04:14 -04:00
|
|
|
}
|