mirror of https://github.com/Nheko-Reborn/nheko
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
112 lines
3.2 KiB
112 lines
3.2 KiB
4 years ago
|
import QtQuick 2.12
|
||
|
import QtQuick.Controls 2.12
|
||
|
import QtQuick.Layouts 1.12
|
||
|
import QtQuick.Window 2.12
|
||
|
import im.nheko 1.0
|
||
|
|
||
|
ApplicationWindow {
|
||
|
id: roomMembersRoot
|
||
|
|
||
|
property string roomName: Rooms.currentRoom.roomName
|
||
|
property MemberList members
|
||
|
|
||
|
title: qsTr("Members of ") + roomName
|
||
|
x: MainWindow.x + (MainWindow.width / 2) - (width / 2)
|
||
|
y: MainWindow.y + (MainWindow.height / 2) - (height / 2)
|
||
|
height: 650
|
||
|
width: 420
|
||
|
minimumHeight: 420
|
||
|
|
||
|
Shortcut {
|
||
|
sequence: StandardKey.Cancel
|
||
|
onActivated: roomMembersRoot.close()
|
||
|
}
|
||
|
|
||
|
ColumnLayout {
|
||
|
anchors.fill: parent
|
||
|
anchors.margins: 10
|
||
|
spacing: 10
|
||
|
|
||
|
Avatar {
|
||
|
id: roomAvatar
|
||
|
|
||
|
width: 130
|
||
|
height: width
|
||
|
displayName: members.roomName
|
||
|
Layout.alignment: Qt.AlignHCenter
|
||
|
url: members.avatarUrl.replace("mxc://", "image://MxcImage/")
|
||
|
onClicked: TimelineManager.timeline.openRoomSettings(members.roomId)
|
||
|
}
|
||
|
|
||
|
Label {
|
||
|
font.pixelSize: 24
|
||
|
text: members.memberCount + (members.memberCount === 1 ? qsTr(" person in ") : qsTr(" people in ")) + roomName
|
||
|
Layout.alignment: Qt.AlignHCenter
|
||
|
}
|
||
|
|
||
|
ScrollView {
|
||
|
clip: false
|
||
|
palette: colors
|
||
|
padding: 10
|
||
|
ScrollBar.horizontal.visible: false
|
||
|
Layout.fillHeight: true
|
||
|
Layout.minimumHeight: 200
|
||
|
Layout.fillWidth: true
|
||
|
|
||
|
ListView {
|
||
|
id: memberList
|
||
|
|
||
|
clip: true
|
||
|
spacing: 8
|
||
|
boundsBehavior: Flickable.StopAtBounds
|
||
|
model: members
|
||
|
|
||
|
ScrollHelper {
|
||
|
flickable: parent
|
||
|
anchors.fill: parent
|
||
|
enabled: !Settings.mobileMode
|
||
|
}
|
||
|
|
||
|
delegate: RowLayout {
|
||
|
spacing: 10
|
||
|
|
||
|
Avatar {
|
||
|
width: avatarSize
|
||
|
height: avatarSize
|
||
|
userid: model.mxid
|
||
|
url: model.avatarUrl.replace("mxc://", "image://MxcImage/")
|
||
|
displayName: model.displayName
|
||
|
onClicked: TimelineManager.timeline.openUserProfile(model.mxid)
|
||
|
}
|
||
|
|
||
|
ColumnLayout {
|
||
|
spacing: 5
|
||
|
|
||
|
Label {
|
||
|
text: model.displayName
|
||
|
color: TimelineManager.userColor(model ? model.mxid : "", colors.window)
|
||
|
font.pointSize: 12
|
||
|
}
|
||
|
|
||
|
Label {
|
||
|
text: model.mxid
|
||
|
color: colors.buttonText
|
||
|
font.pointSize: 10
|
||
|
}
|
||
|
|
||
|
Item {
|
||
|
Layout.fillHeight: true
|
||
|
Layout.fillWidth: true
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
footer: DialogButtonBox {
|
||
|
standardButtons: DialogButtonBox.Ok
|
||
|
onAccepted: roomMembersRoot.close()
|
||
|
}
|
||
|
}
|