Refactor SidePane ListView in a flat way
Also adjust some colors (accentBackground) TODO: Repair Filter rooms field
This commit is contained in:
129
src/qml/SidePane/DelegateRoom.qml
Normal file
129
src/qml/SidePane/DelegateRoom.qml
Normal file
@@ -0,0 +1,129 @@
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import "../Base"
|
||||
import "../utils.js" as Utils
|
||||
|
||||
HInteractiveRectangle {
|
||||
id: roomDelegate
|
||||
color: theme.sidePane.room.background
|
||||
|
||||
readonly property bool collapsed:
|
||||
! accountRoomList.forceExpand &&
|
||||
window.uiState.collapseAccounts[model.user_id] || false
|
||||
|
||||
visible: height > 0
|
||||
height: collapsed ? 0 : rowLayout.height
|
||||
Behavior on height { HNumberAnimation {} }
|
||||
|
||||
opacity: model.data.left ? theme.sidePane.room.leftRoomOpacity : 1
|
||||
Behavior on opacity { HNumberAnimation {} }
|
||||
|
||||
checked: isCurrent
|
||||
readonly property bool isCurrent:
|
||||
window.uiState.page == "Chat/Chat.qml" &&
|
||||
window.uiState.pageProperties.userId == model.user_id &&
|
||||
window.uiState.pageProperties.roomId == model.data.room_id
|
||||
|
||||
function activate() {
|
||||
pageStack.showRoom(model.user_id, model.data.room_id)
|
||||
print(model.user_id, model.data.room_id)
|
||||
}
|
||||
|
||||
TapHandler { onTapped: activate() }
|
||||
|
||||
HRowLayout {
|
||||
id: rowLayout
|
||||
spacing: sidePane.currentSpacing
|
||||
x: spacing
|
||||
width: parent.width - spacing * 1.75
|
||||
height: roomName.height + subtitle.height + spacing
|
||||
|
||||
HRoomAvatar {
|
||||
id: roomAvatar
|
||||
displayName: model.data.display_name
|
||||
avatarUrl: model.data.avatar_url
|
||||
}
|
||||
|
||||
HColumnLayout {
|
||||
Layout.fillWidth: true
|
||||
|
||||
HRowLayout {
|
||||
spacing: rowLayout.spacing
|
||||
|
||||
HLabel {
|
||||
id: roomName
|
||||
color: theme.sidePane.room.name
|
||||
text: model.data.display_name || "<i>Empty room</i>"
|
||||
textFormat:
|
||||
model.data.display_name?
|
||||
Text.PlainText : Text.StyledText
|
||||
elide: Text.ElideRight
|
||||
verticalAlignment: Qt.AlignVCenter
|
||||
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
|
||||
HIcon {
|
||||
svgName: "invite-received"
|
||||
|
||||
visible: Layout.maximumWidth > 0
|
||||
Layout.maximumWidth:
|
||||
model.data.inviter_id && ! model.data.left ?
|
||||
implicitWidth : 0
|
||||
Behavior on Layout.maximumWidth { HNumberAnimation {} }
|
||||
}
|
||||
|
||||
HLabel {
|
||||
readonly property var evDate:
|
||||
model.data.last_event ?
|
||||
model.data.last_event.date : null
|
||||
|
||||
id: lastEventDate
|
||||
font.pixelSize: theme.fontSize.small
|
||||
color: theme.sidePane.room.lastEventDate
|
||||
|
||||
text: ! evDate ? "" :
|
||||
|
||||
Utils.dateIsToday(evDate) ?
|
||||
Utils.formatTime(evDate, false) : // no seconds
|
||||
|
||||
evDate.getFullYear() == new Date().getFullYear() ?
|
||||
Qt.formatDate(evDate, "d MMM") : // e.g. "5 Dec"
|
||||
|
||||
evDate.getFullYear()
|
||||
|
||||
visible: Layout.maximumWidth > 0
|
||||
Layout.maximumWidth:
|
||||
text && roomDelegate.width >= 200 ? implicitWidth : 0
|
||||
Behavior on Layout.maximumWidth { HNumberAnimation {} }
|
||||
}
|
||||
}
|
||||
|
||||
HRichLabel {
|
||||
id: subtitle
|
||||
color: theme.sidePane.room.subtitle
|
||||
visible: Boolean(text)
|
||||
textFormat: Text.StyledText
|
||||
font.pixelSize: theme.fontSize.small
|
||||
elide: Text.ElideRight
|
||||
|
||||
text: {
|
||||
if (! model.data.last_event) { return "" }
|
||||
|
||||
let ev = model.data.last_event
|
||||
|
||||
if (ev.event_type === "RoomMessageEmote" ||
|
||||
! ev.event_type.startsWith("RoomMessage")) {
|
||||
return Utils.processedEventText(ev)
|
||||
}
|
||||
|
||||
return Utils.coloredNameHtml(
|
||||
ev.sender_name, ev.sender_id
|
||||
) + ": " + ev.inline_content
|
||||
}
|
||||
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user