100 lines
2.2 KiB
QML
100 lines
2.2 KiB
QML
// SPDX-License-Identifier: LGPL-3.0-or-later
|
|
|
|
import QtQuick 2.12
|
|
import QtQuick.Layouts 1.12
|
|
import "../../Base"
|
|
import "Banners"
|
|
import "Timeline"
|
|
import "FileTransfer"
|
|
|
|
HColumnPage {
|
|
id: chatPage
|
|
leftPadding: 0
|
|
rightPadding: 0
|
|
|
|
onLoadEventListChanged: if (loadEventList) loadedOnce = true
|
|
Component.onDestruction: if (loadMembersFuture) loadMembersFuture.cancel()
|
|
|
|
|
|
property bool loadedOnce: false
|
|
property var loadMembersFuture: null
|
|
|
|
readonly property alias composer: composer
|
|
readonly property bool loadEventList:
|
|
mainUI.mainPane.collapse ?
|
|
! mainUI.mainPane.visible : ! pageLoader.appearAnimation.running
|
|
|
|
|
|
Timer {
|
|
interval: 200
|
|
running: true
|
|
onTriggered: loadMembersFuture = py.callClientCoro(
|
|
chat.userId,
|
|
"load_all_room_members",
|
|
[chat.roomId],
|
|
() => { loadMembersFuture = null },
|
|
)
|
|
}
|
|
|
|
RoomHeader {
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
HLoader {
|
|
id: eventListLoader
|
|
opacity: loadEventList ? 1 : 0
|
|
sourceComponent:
|
|
loadedOnce || loadEventList ? evListComponent : placeholder
|
|
|
|
Layout.fillWidth: true
|
|
Layout.fillHeight: true
|
|
|
|
Behavior on opacity { HNumberAnimation {} }
|
|
|
|
Component {
|
|
id: placeholder
|
|
Item {}
|
|
}
|
|
|
|
Component {
|
|
id: evListComponent
|
|
EventList {}
|
|
}
|
|
}
|
|
|
|
TypingMembersBar {
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
TransferList {
|
|
Layout.fillWidth: true
|
|
Layout.minimumHeight: implicitHeight
|
|
Layout.preferredHeight: implicitHeight * transferCount
|
|
Layout.maximumHeight: chatPage.height / 6
|
|
|
|
Behavior on Layout.preferredHeight { HNumberAnimation {} }
|
|
}
|
|
|
|
InviteBanner {
|
|
id: inviteBanner
|
|
visible: ! chat.roomInfo.left && inviterId
|
|
inviterId: chat.roomInfo.inviter_id
|
|
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
LeftBanner {
|
|
id: leftBanner
|
|
visible: chat.roomInfo.left
|
|
Layout.fillWidth: true
|
|
}
|
|
|
|
Composer {
|
|
id: composer
|
|
eventList: loadEventList ? eventListLoader.item.eventList : null
|
|
visible:
|
|
! chat.roomInfo.left && ! chat.roomInfo.inviter_id
|
|
}
|
|
|
|
}
|