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-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-04-21 07:36:21 +10:00
|
|
|
function getPreviousItem() {
|
2019-04-29 04:34:29 +10:00
|
|
|
return index < roomEventListView.model.count - 1 ?
|
|
|
|
roomEventListView.model.get(index + 1) : null
|
2019-04-20 17:29:24 +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
|
|
|
|
Component.onCompleted:
|
|
|
|
senderInfo = models.users.getUser(chatPage.userId, senderId)
|
2019-04-15 02:56:30 +10:00
|
|
|
|
2019-07-03 03:59:52 +10:00
|
|
|
readonly property bool isOwn: chatPage.userId === senderId
|
2019-03-22 14:28:14 +11:00
|
|
|
|
2019-07-03 12:22:29 +10:00
|
|
|
readonly property bool isFirstEvent: model.event_type == "RoomCreateEvent"
|
2019-03-22 14:28:14 +11:00
|
|
|
|
|
|
|
readonly property bool combine:
|
2019-04-20 17:29:24 +10:00
|
|
|
previousItem &&
|
2019-04-18 06:43:18 +10:00
|
|
|
! talkBreak &&
|
|
|
|
! dayBreak &&
|
2019-07-03 03:59:52 +10:00
|
|
|
previousItem.senderId === senderId &&
|
|
|
|
minsBetween(previousItem.date, model.date) <= 5
|
2019-03-22 14:28:14 +11:00
|
|
|
|
|
|
|
readonly property bool dayBreak:
|
2019-04-20 17:29:24 +10:00
|
|
|
isFirstEvent ||
|
|
|
|
previousItem &&
|
2019-07-03 03:59:52 +10:00
|
|
|
model.date.getDate() != previousItem.date.getDate()
|
2019-03-22 14:28:14 +11:00
|
|
|
|
|
|
|
readonly property bool talkBreak:
|
2019-04-20 17:29:24 +10:00
|
|
|
previousItem &&
|
2019-03-22 14:28:14 +11:00
|
|
|
! dayBreak &&
|
2019-07-03 03:59:52 +10:00
|
|
|
minsBetween(previousItem.date, model.date) >= 20
|
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:22:29 +10:00
|
|
|
MessageContent {
|
2019-04-29 04:48:59 +10:00
|
|
|
anchors.right: isOwn ? parent.right : undefined
|
|
|
|
}
|
2019-03-22 14:28:14 +11:00
|
|
|
}
|