2019-03-22 14:28:14 +11:00
|
|
|
import QtQuick 2.7
|
2019-04-29 05:45:42 +10:00
|
|
|
import QtQuick.Layouts 1.3
|
2019-04-29 05:18:36 +10:00
|
|
|
import "../../Base"
|
2019-07-04 14:24:21 +10:00
|
|
|
import "../../utils.js" as Utils
|
2019-03-22 14:28:14 +11:00
|
|
|
|
|
|
|
Column {
|
2019-04-29 04:34:29 +10:00
|
|
|
id: roomEventDelegate
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-04-21 07:36:21 +10:00
|
|
|
function minsBetween(date1, date2) {
|
2019-03-22 14:28:14 +11:00
|
|
|
return Math.round((((date2 - date1) % 86400000) % 3600000) / 60000)
|
|
|
|
}
|
|
|
|
|
2019-07-03 13:32:39 +10:00
|
|
|
function getPreviousItem(nth) {
|
|
|
|
// Remember, index 0 = newest bottomest message
|
|
|
|
nth = nth || 1
|
2019-07-04 11:20:49 +10:00
|
|
|
return roomEventListView.model.count - 1 > model.index + nth ?
|
|
|
|
roomEventListView.model.get(model.index + nth) : null
|
2019-07-03 13:32:39 +10:00
|
|
|
}
|
|
|
|
|
2019-04-21 07:36:21 +10:00
|
|
|
property var previousItem: getPreviousItem()
|
2019-04-20 17:29:24 +10:00
|
|
|
signal reloadPreviousItem()
|
2019-04-21 07:36:21 +10:00
|
|
|
onReloadPreviousItem: previousItem = getPreviousItem()
|
2019-04-18 06:43:18 +10:00
|
|
|
|
2019-07-03 03:59:52 +10:00
|
|
|
property var senderInfo: null
|
2019-07-04 14:24:21 +10:00
|
|
|
Component.onCompleted: senderInfo = models.users.getUser(model.senderId)
|
2019-04-15 02:56:30 +10:00
|
|
|
|
2019-07-03 13:32:39 +10:00
|
|
|
readonly property bool isOwn: chatPage.userId === model.senderId
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-07-03 13:32:39 +10:00
|
|
|
readonly property bool isFirstEvent: model.eventType == "RoomCreateEvent"
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-07-04 11:20:49 +10:00
|
|
|
// Item roles may not be loaded yet, reason for all these checks
|
|
|
|
readonly property bool combine: Boolean(
|
|
|
|
model.date &&
|
|
|
|
previousItem && previousItem.eventType && previousItem.date &&
|
2019-07-04 14:24:21 +10:00
|
|
|
Utils.eventIsMessage(previousItem) == Utils.eventIsMessage(model) &&
|
2019-04-18 06:43:18 +10:00
|
|
|
! talkBreak &&
|
|
|
|
! dayBreak &&
|
2019-07-03 13:32:39 +10:00
|
|
|
previousItem.senderId === model.senderId &&
|
2019-07-03 03:59:52 +10:00
|
|
|
minsBetween(previousItem.date, model.date) <= 5
|
2019-07-04 11:20:49 +10:00
|
|
|
)
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-07-04 11:20:49 +10:00
|
|
|
readonly property bool dayBreak: Boolean(
|
2019-04-20 17:29:24 +10:00
|
|
|
isFirstEvent ||
|
2019-07-04 11:20:49 +10:00
|
|
|
model.date && previousItem && previousItem.date &&
|
2019-07-03 03:59:52 +10:00
|
|
|
model.date.getDate() != previousItem.date.getDate()
|
2019-07-04 11:20:49 +10:00
|
|
|
)
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-07-04 11:20:49 +10:00
|
|
|
readonly property bool talkBreak: Boolean(
|
|
|
|
model.date && previousItem && previousItem.date &&
|
2019-03-22 14:28:14 +11:00
|
|
|
! dayBreak &&
|
2019-07-03 03:59:52 +10:00
|
|
|
minsBetween(previousItem.date, model.date) >= 20
|
2019-07-04 11:20:49 +10:00
|
|
|
)
|
2019-03-22 14:28:14 +11:00
|
|
|
|
|
|
|
|
2019-04-18 06:43:18 +10:00
|
|
|
property int standardSpacing: 16
|
2019-05-16 07:01:58 +10:00
|
|
|
property int horizontalPadding: 6
|
|
|
|
property int verticalPadding: 4
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-04-20 17:29:24 +10:00
|
|
|
ListView.onAdd: {
|
2019-04-29 04:34:29 +10:00
|
|
|
var nextDelegate = roomEventListView.contentItem.children[index]
|
2019-04-21 07:36:21 +10:00
|
|
|
if (nextDelegate) { nextDelegate.reloadPreviousItem() }
|
2019-04-20 17:29:24 +10:00
|
|
|
}
|
|
|
|
|
2019-03-22 14:28:14 +11:00
|
|
|
width: parent.width
|
2019-04-20 17:29:24 +10:00
|
|
|
|
2019-03-22 14:28:14 +11:00
|
|
|
topPadding:
|
2019-04-20 17:29:24 +10:00
|
|
|
isFirstEvent ? 0 :
|
2019-04-29 01:01:38 +10:00
|
|
|
dayBreak ? standardSpacing * 2 :
|
2019-04-18 06:43:18 +10:00
|
|
|
talkBreak ? standardSpacing * 3 :
|
|
|
|
combine ? standardSpacing / 4 :
|
|
|
|
standardSpacing
|
|
|
|
|
2019-04-29 04:48:59 +10:00
|
|
|
Loader {
|
|
|
|
source: dayBreak ? "Daybreak.qml" : ""
|
|
|
|
width: roomEventDelegate.width
|
|
|
|
}
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-07-03 12:22:29 +10:00
|
|
|
Item { // TODO: put this in Daybreak.qml?
|
2019-04-29 01:01:38 +10:00
|
|
|
visible: dayBreak
|
|
|
|
width: parent.width
|
|
|
|
height: topPadding
|
|
|
|
}
|
|
|
|
|
2019-07-03 12:29:09 +10:00
|
|
|
EventContent {
|
2019-04-29 04:48:59 +10:00
|
|
|
anchors.right: isOwn ? parent.right : undefined
|
|
|
|
}
|
2019-03-22 14:28:14 +11:00
|
|
|
}
|