nheko/resources/qml/RoomList.qml

786 lines
29 KiB
QML
Raw Normal View History

// SPDX-FileCopyrightText: Nheko Contributors
2021-05-14 23:35:34 +02:00
//
// SPDX-License-Identifier: GPL-3.0-or-later
2022-04-22 00:26:25 +02:00
import "./components"
2021-05-28 17:25:46 +02:00
import "./dialogs"
import "./ui"
2021-05-22 15:19:44 +02:00
import Qt.labs.platform 1.1 as Platform
2021-06-13 01:48:11 +02:00
import QtQml 2.12
import QtQuick 2.15
import QtQuick.Controls 2.15
2021-05-14 23:35:34 +02:00
import QtQuick.Layouts 1.3
import im.nheko 1.0
Page {
2021-06-05 23:36:08 +02:00
//leftPadding: Nheko.paddingSmall
//rightPadding: Nheko.paddingSmall
2021-06-08 22:18:51 +02:00
property int avatarSize: Math.ceil(fontMetrics.lineSpacing * 2.3)
property bool collapsed: false
2021-06-05 23:36:08 +02:00
2023-06-02 01:45:24 +02:00
background: Rectangle {
color: Nheko.theme.sidebarBackground
}
footer: ColumnLayout {
spacing: 0
Rectangle {
Layout.fillWidth: true
color: Nheko.theme.separator
height: 1
}
Pane {
Layout.alignment: Qt.AlignBottom
Layout.fillWidth: true
Layout.minimumHeight: 40
horizontalPadding: Nheko.paddingMedium
verticalPadding: 0
background: Rectangle {
color: palette.window
}
contentItem: RowLayout {
id: buttonRow
ImageButton {
Layout.fillWidth: true
Layout.margins: Nheko.paddingMedium
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: qsTr("Start a new chat")
ToolTip.visible: hovered
height: 22
hoverEnabled: true
image: ":/icons/icons/ui/add-square-button.svg"
width: 22
onClicked: roomJoinCreateMenu.open(parent)
Platform.Menu {
id: roomJoinCreateMenu
Platform.MenuItem {
text: qsTr("Join a room")
onTriggered: Nheko.openJoinRoomDialog()
}
Platform.MenuItem {
text: qsTr("Create a new room")
onTriggered: {
var createRoom = createRoomComponent.createObject(timelineRoot);
createRoom.show();
timelineRoot.destroyOnClose(createRoom);
}
}
Platform.MenuItem {
text: qsTr("Start a direct chat")
onTriggered: {
var createDirect = createDirectComponent.createObject(timelineRoot);
createDirect.show();
timelineRoot.destroyOnClose(createDirect);
}
}
Platform.MenuItem {
text: qsTr("Create a new community")
onTriggered: {
var createRoom = createRoomComponent.createObject(timelineRoot, {
"space": true
});
createRoom.show();
timelineRoot.destroyOnClose(createRoom);
}
}
}
}
ImageButton {
Layout.fillWidth: true
Layout.margins: Nheko.paddingMedium
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: qsTr("Room directory")
ToolTip.visible: hovered
height: 22
hoverEnabled: true
image: ":/icons/icons/ui/room-directory.svg"
visible: !collapsed
width: 22
onClicked: {
var win = roomDirectoryComponent.createObject(timelineRoot);
win.show();
timelineRoot.destroyOnClose(win);
}
}
ImageButton {
Layout.fillWidth: true
Layout.margins: Nheko.paddingMedium
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: qsTr("Search rooms (Ctrl+K)")
ToolTip.visible: hovered
height: 22
hoverEnabled: true
image: ":/icons/icons/ui/search.svg"
ripple: false
visible: !collapsed
width: 22
onClicked: {
var component = Qt.createComponent("qrc:/qml/QuickSwitcher.qml");
if (component.status == Component.Ready) {
var quickSwitch = component.createObject(timelineRoot);
quickSwitch.open();
destroyOnClosed(quickSwitch);
} else {
console.error("Failed to create component: " + component.errorString());
}
}
}
ImageButton {
Layout.fillWidth: true
Layout.margins: Nheko.paddingMedium
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: qsTr("User settings")
ToolTip.visible: hovered
height: 22
hoverEnabled: true
image: ":/icons/icons/ui/settings.svg"
ripple: false
visible: !collapsed
width: 22
onClicked: mainWindow.push(userSettingsPage)
}
}
}
}
header: ColumnLayout {
spacing: 0
Pane {
id: userInfoPanel
function openUserProfile() {
Nheko.updateUserProfile();
var component = Qt.createComponent("qrc:/qml/dialogs/UserProfile.qml");
if (component.status == Component.Ready) {
var userProfile = component.createObject(timelineRoot, {
"profile": Nheko.currentUser
});
userProfile.show();
timelineRoot.destroyOnClose(userProfile);
} else {
console.error("Failed to create component: " + component.errorString());
}
}
Layout.alignment: Qt.AlignBottom
Layout.fillWidth: true
Layout.minimumHeight: 40
//Layout.preferredHeight: userInfoGrid.implicitHeight + 2 * Nheko.paddingMedium
padding: Nheko.paddingMedium
background: Rectangle {
color: palette.window
}
contentItem: RowLayout {
id: userInfoGrid
property var profile: Nheko.currentUser
spacing: Nheko.paddingMedium
Avatar {
id: avatar
Layout.alignment: Qt.AlignVCenter
Layout.preferredHeight: fontMetrics.lineSpacing * 2
Layout.preferredWidth: fontMetrics.lineSpacing * 2
displayName: userInfoGrid.profile ? userInfoGrid.profile.displayName : ""
enabled: false
url: (userInfoGrid.profile ? userInfoGrid.profile.avatarUrl : "").replace("mxc://", "image://MxcImage/")
userid: userInfoGrid.profile ? userInfoGrid.profile.userid : ""
}
ColumnLayout {
id: col
Layout.alignment: Qt.AlignLeft
Layout.fillWidth: true
Layout.preferredWidth: parent.width - avatar.width - logoutButton.width - Nheko.paddingMedium * 2
spacing: 0
visible: !collapsed
width: parent.width - avatar.width - logoutButton.width - Nheko.paddingMedium * 2
ElidedLabel {
Layout.alignment: Qt.AlignBottom
elideWidth: col.width
font.pointSize: fontMetrics.font.pointSize * 1.1
font.weight: Font.DemiBold
fullText: userInfoGrid.profile ? userInfoGrid.profile.displayName : ""
}
ElidedLabel {
Layout.alignment: Qt.AlignTop
color: palette.buttonText
elideWidth: col.width
font.pointSize: fontMetrics.font.pointSize * 0.9
fullText: userInfoGrid.profile ? userInfoGrid.profile.userid : ""
}
}
Item {
}
ImageButton {
id: logoutButton
Layout.alignment: Qt.AlignVCenter
Layout.preferredHeight: fontMetrics.lineSpacing * 2
Layout.preferredWidth: fontMetrics.lineSpacing * 2
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: qsTr("Logout")
ToolTip.visible: hovered
image: ":/icons/icons/ui/power-off.svg"
visible: !collapsed
onClicked: Nheko.openLogoutDialog()
}
}
InputDialog {
id: statusDialog
prompt: qsTr("Enter your status message:")
title: qsTr("Status Message")
onAccepted: function (text) {
Nheko.setStatusMessage(text);
}
}
Platform.Menu {
id: userInfoMenu
Platform.MenuItem {
text: qsTr("Profile settings")
onTriggered: userInfoPanel.openUserProfile()
}
Platform.MenuItem {
text: qsTr("Set status message")
onTriggered: statusDialog.show()
}
}
TapHandler {
acceptedButtons: Qt.LeftButton
gesturePolicy: TapHandler.ReleaseWithinBounds
margin: -Nheko.paddingSmall
onLongPressed: userInfoMenu.open()
onSingleTapped: userInfoPanel.openUserProfile()
}
TapHandler {
acceptedButtons: Qt.RightButton
gesturePolicy: TapHandler.ReleaseWithinBounds
margin: -Nheko.paddingSmall
onSingleTapped: userInfoMenu.open()
}
}
Rectangle {
Layout.fillWidth: true
color: Nheko.theme.separator
height: 2
}
Rectangle {
id: unverifiedStuffBubble
Layout.fillWidth: true
color: Qt.lighter(Nheko.theme.orange, verifyButtonHovered.hovered ? 1.2 : 1)
implicitHeight: explanation.height + Nheko.paddingMedium * 2
visible: SelfVerificationStatus.status != SelfVerificationStatus.AllVerified
RowLayout {
id: unverifiedStuffBubbleContainer
height: explanation.height + Nheko.paddingMedium * 2
spacing: 0
width: parent.width
Label {
id: explanation
Layout.fillWidth: true
Layout.margins: Nheko.paddingMedium
Layout.rightMargin: Nheko.paddingSmall
color: palette.buttonText
text: {
switch (SelfVerificationStatus.status) {
case SelfVerificationStatus.NoMasterKey:
//: Cross-signing setup has not run yet.
return qsTr("Encryption not set up");
case SelfVerificationStatus.UnverifiedMasterKey:
//: The user just signed in with this device and hasn't verified their master key.
return qsTr("Unverified login");
case SelfVerificationStatus.UnverifiedDevices:
//: There are unverified devices signed in to this account.
return qsTr("Please verify your other devices");
default:
return "";
}
}
textFormat: Text.PlainText
wrapMode: Text.Wrap
}
ImageButton {
id: closeUnverifiedBubble
Layout.alignment: Qt.AlignRight | Qt.AlignVCenter
Layout.rightMargin: Nheko.paddingMedium
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: qsTr("Close")
ToolTip.visible: closeUnverifiedBubble.hovered
height: fontMetrics.font.pixelSize
hoverEnabled: true
image: ":/icons/icons/ui/dismiss.svg"
width: fontMetrics.font.pixelSize
onClicked: unverifiedStuffBubble.visible = false
}
}
HoverHandler {
id: verifyButtonHovered
acceptedDevices: PointerDevice.Mouse | PointerDevice.Stylus | PointerDevice.TouchPad
enabled: !closeUnverifiedBubble.hovered
}
TapHandler {
acceptedButtons: Qt.LeftButton
enabled: !closeUnverifiedBubble.hovered
onSingleTapped: {
if (SelfVerificationStatus.status == SelfVerificationStatus.UnverifiedDevices)
SelfVerificationStatus.verifyUnverifiedDevices();
else
SelfVerificationStatus.statusChanged();
}
}
}
Rectangle {
Layout.fillWidth: true
color: Nheko.theme.separator
height: 1
visible: unverifiedStuffBubble.visible
}
}
// HACK: https://bugreports.qt.io/browse/QTBUG-83972, qtwayland cannot auto hide menu
Connections {
function onHideMenu() {
2023-06-02 01:45:24 +02:00
userInfoMenu.close();
roomContextMenu.close();
}
2023-06-02 01:45:24 +02:00
target: MainWindow
}
Component {
id: roomDirectoryComponent
RoomDirectory {
}
}
2022-03-25 22:30:19 +01:00
Component {
id: createRoomComponent
CreateRoom {
}
}
2022-03-26 17:28:44 +01:00
Component {
id: createDirectComponent
CreateDirect {
}
}
2021-05-19 19:34:10 +02:00
ListView {
2021-05-21 21:19:03 +02:00
id: roomlist
2021-05-19 19:34:10 +02:00
anchors.left: parent.left
anchors.right: parent.right
height: parent.height
model: Rooms
2023-06-02 01:45:24 +02:00
//reuseItems: true
ScrollBar.vertical: ScrollBar {
id: scrollbar
2022-08-10 00:20:44 +02:00
2023-06-02 01:45:24 +02:00
parent: !collapsed && Settings.scrollbarsInRoomlist ? roomlist : null
2021-05-28 17:25:46 +02:00
}
delegate: ItemDelegate {
2021-05-21 21:19:03 +02:00
id: roomItem
2023-06-02 01:45:24 +02:00
required property string avatarUrl
property color backgroundColor: palette.window
property color bubbleBackground: palette.highlight
property color bubbleText: palette.highlightedText
2023-06-02 01:45:24 +02:00
required property string directChatOtherUserId
required property bool hasLoudNotification
required property bool hasUnreadMessages
2023-06-02 01:45:24 +02:00
property color importantText: palette.text
2021-08-31 02:08:47 +02:00
required property bool isDirect
2023-06-02 01:45:24 +02:00
required property bool isInvite
required property bool isSpace
required property string lastMessage
required property int notificationCount
required property string roomId
required property string roomName
required property var tags
required property string time
property color unimportantText: palette.buttonText
ToolTip.delay: Nheko.tooltipDelay
ToolTip.text: roomName
2023-06-02 01:45:24 +02:00
ToolTip.visible: hovered && collapsed
height: avatarSize + 2 * Nheko.paddingMedium
state: "normal"
width: ListView.view.width - ((scrollbar.interactive && scrollbar.visible && scrollbar.parent) ? scrollbar.width : 0)
2023-06-02 01:45:24 +02:00
background: Rectangle {
color: backgroundColor
}
2021-05-21 21:19:03 +02:00
states: [
State {
name: "highlight"
when: roomItem.hovered && !((Rooms.currentRoom && roomId == Rooms.currentRoom.roomId) || Rooms.currentRoomPreview.roomid == roomId)
2021-05-21 21:19:03 +02:00
PropertyChanges {
backgroundColor: palette.dark
bubbleBackground: palette.highlight
bubbleText: palette.highlightedText
2023-06-02 01:45:24 +02:00
importantText: palette.brightText
target: roomItem
unimportantText: palette.brightText
2021-05-21 21:19:03 +02:00
}
},
State {
name: "selected"
2021-07-17 22:16:02 +02:00
when: (Rooms.currentRoom && roomId == Rooms.currentRoom.roomId) || Rooms.currentRoomPreview.roomid == roomId
2021-05-21 21:19:03 +02:00
PropertyChanges {
backgroundColor: palette.highlight
bubbleBackground: palette.highlightedText
bubbleText: palette.highlight
2023-06-02 01:45:24 +02:00
importantText: palette.highlightedText
target: roomItem
unimportantText: palette.highlightedText
2021-05-21 21:19:03 +02:00
}
}
]
2021-05-19 19:34:10 +02:00
2023-06-02 01:45:24 +02:00
onClicked: {
console.log("tapped " + roomId);
if (!Rooms.currentRoom || Rooms.currentRoom.roomId !== roomId)
Rooms.setCurrentRoom(roomId);
else
Rooms.resetCurrentRoom();
}
onPressAndHold: {
if (!isInvite)
roomContextMenu.show(roomId, tags);
}
Ripple {
color: Qt.rgba(palette.dark.r, palette.dark.g, palette.dark.b, 0.5)
}
// NOTE(Nico): We want to prevent the touch areas from overlapping. For some reason we need to add 1px of padding for that...
Item {
anchors.fill: parent
anchors.margins: 1
TapHandler {
acceptedButtons: Qt.RightButton
2023-06-02 01:45:24 +02:00
acceptedDevices: PointerDevice.Mouse | PointerDevice.Stylus | PointerDevice.TouchPad
gesturePolicy: TapHandler.ReleaseWithinBounds
onSingleTapped: {
if (!TimelineManager.isInvite)
roomContextMenu.show(roomId, tags);
}
}
2021-05-21 21:19:03 +02:00
}
RowLayout {
2021-05-19 19:34:10 +02:00
anchors.fill: parent
anchors.margins: Nheko.paddingMedium
2023-06-02 01:45:24 +02:00
spacing: Nheko.paddingMedium
2021-05-19 19:34:10 +02:00
Avatar {
id: avatar
Layout.alignment: Qt.AlignVCenter
2023-06-02 01:45:24 +02:00
displayName: roomName
enabled: false
2021-06-08 22:18:51 +02:00
height: avatarSize
2023-06-02 01:45:24 +02:00
roomid: roomId
url: avatarUrl.replace("mxc://", "image://MxcImage/")
2021-09-05 02:53:33 +02:00
userid: isDirect ? directChatOtherUserId : ""
2023-06-02 01:45:24 +02:00
width: avatarSize
2021-06-08 22:18:51 +02:00
2022-04-22 00:26:25 +02:00
NotificationBubble {
2021-06-08 22:18:51 +02:00
id: collapsedNotificationBubble
anchors.bottom: parent.bottom
anchors.margins: -Nheko.paddingSmall
2023-06-02 01:45:24 +02:00
anchors.right: parent.right
bubbleBackgroundColor: roomItem.bubbleBackground
bubbleTextColor: roomItem.bubbleText
hasLoudNotification: roomItem.hasLoudNotification
2022-06-06 18:07:25 +02:00
mayBeVisible: collapsed && (isSpace ? Settings.spaceNotifications : true)
2023-06-02 01:45:24 +02:00
notificationCount: roomItem.notificationCount
2021-06-08 22:18:51 +02:00
}
2021-05-19 19:34:10 +02:00
}
ColumnLayout {
id: textContent
Layout.alignment: Qt.AlignLeft
Layout.fillWidth: true
Layout.minimumWidth: 100
Layout.preferredWidth: parent.width - avatar.width
2022-02-26 16:06:20 +01:00
height: avatar.height
spacing: Nheko.paddingSmall
2023-06-02 01:45:24 +02:00
visible: !collapsed
width: parent.width - avatar.width
2021-05-19 19:34:10 +02:00
2022-04-22 00:26:25 +02:00
NotificationBubble {
2022-04-20 05:18:11 +02:00
id: notificationBubble
2022-04-22 00:26:25 +02:00
Layout.alignment: Qt.AlignRight
Layout.leftMargin: Nheko.paddingSmall
Layout.preferredHeight: implicitHeight
2023-06-02 01:45:24 +02:00
Layout.preferredWidth: implicitWidth
bubbleBackgroundColor: roomItem.bubbleBackground
bubbleTextColor: roomItem.bubbleText
hasLoudNotification: roomItem.hasLoudNotification
2022-06-06 18:07:25 +02:00
mayBeVisible: !collapsed && (isSpace ? Settings.spaceNotifications : true)
2023-06-02 01:45:24 +02:00
notificationCount: roomItem.notificationCount
parent: isSpace ? titleRow : subtextRow
2022-04-20 05:18:11 +02:00
}
2021-05-19 19:34:10 +02:00
RowLayout {
2022-04-20 05:18:11 +02:00
id: titleRow
2022-02-26 16:06:20 +01:00
Layout.alignment: Qt.AlignTop
2021-05-19 19:34:10 +02:00
Layout.fillWidth: true
spacing: Nheko.paddingSmall
2021-05-19 19:34:10 +02:00
ElidedLabel {
id: rN
2023-06-02 01:45:24 +02:00
Layout.alignment: Qt.AlignBaseline
2023-06-02 01:45:24 +02:00
Layout.fillWidth: true
2021-05-21 21:19:03 +02:00
color: roomItem.importantText
elideWidth: width
2023-01-07 02:03:04 +01:00
fullText: TimelineManager.htmlEscape(roomName)
2021-05-22 10:16:42 +02:00
textFormat: Text.RichText
2021-05-19 19:34:10 +02:00
}
Label {
id: timestamp
2021-06-18 16:22:06 +02:00
Layout.alignment: Qt.AlignRight | Qt.AlignBaseline
2021-05-21 21:19:03 +02:00
color: roomItem.unimportantText
2023-06-02 01:45:24 +02:00
font.pixelSize: fontMetrics.font.pixelSize * 0.9
text: time
2023-06-02 01:45:24 +02:00
visible: !isInvite && !isSpace
width: visible ? 0 : undefined
2021-05-19 19:34:10 +02:00
}
}
RowLayout {
2022-04-20 05:18:11 +02:00
id: subtextRow
2023-06-02 01:45:24 +02:00
Layout.alignment: Qt.AlignBottom
2021-05-19 19:34:10 +02:00
Layout.fillWidth: true
2023-06-02 01:45:24 +02:00
height: visible ? 0 : undefined
2021-05-19 19:34:10 +02:00
spacing: 0
visible: !isSpace
2021-05-19 19:34:10 +02:00
ElidedLabel {
2023-06-02 01:45:24 +02:00
Layout.fillWidth: true
2021-05-21 21:19:03 +02:00
color: roomItem.unimportantText
elideWidth: width
2023-06-02 01:45:24 +02:00
font.pixelSize: fontMetrics.font.pixelSize * 0.9
2023-01-18 19:20:32 +01:00
fullText: TimelineManager.htmlEscape(lastMessage)
2021-05-22 10:16:42 +02:00
textFormat: Text.RichText
2021-05-19 19:34:10 +02:00
}
}
}
}
Rectangle {
anchors.left: parent.left
anchors.verticalCenter: parent.verticalCenter
color: palette.highlight
2023-06-02 01:45:24 +02:00
height: parent.height - Nheko.paddingSmall * 2
visible: hasUnreadMessages
2023-06-02 01:45:24 +02:00
width: 3
2021-05-19 19:34:10 +02:00
}
2021-05-14 23:35:34 +02:00
}
2023-06-02 01:45:24 +02:00
Connections {
function onCurrentRoomChanged() {
if (Rooms.currentRoom)
roomlist.positionViewAtIndex(Rooms.roomidToIndex(Rooms.currentRoom.roomId), ListView.Contain);
}
2023-06-02 01:45:24 +02:00
target: Rooms
}
Component {
id: roomWindowComponent
2023-06-02 01:45:24 +02:00
ApplicationWindow {
id: roomWindowW
property var room: null
property var roomPreview: null
color: palette.window
height: 650
minimumHeight: 150
minimumWidth: 150
title: room.plainRoomName
width: 420
Component.onCompleted: {
MainWindow.addPerRoomWindow(room.roomId || roomPreview.roomid, roomWindowW);
Nheko.setTransientParent(roomWindowW, null);
}
Component.onDestruction: MainWindow.removePerRoomWindow(room.roomId || roomPreview.roomid, roomWindowW)
onActiveChanged: {
room.lastReadIdOnWindowFocus();
}
2023-06-02 01:45:24 +02:00
//flags: Qt.Window | Qt.WindowCloseButtonHint | Qt.WindowTitleHint
Shortcut {
sequence: StandardKey.Cancel
2023-06-02 01:45:24 +02:00
onActivated: roomWindowW.close()
}
TimelineView {
id: timeline
2023-06-02 01:45:24 +02:00
anchors.fill: parent
privacyScreen: privacyScreen
room: roomWindowW.room
roomPreview: roomWindowW.roomPreview.roomid ? roomWindowW.roomPreview : null
}
PrivacyScreen {
id: privacyScreen
2023-06-02 01:45:24 +02:00
anchors.fill: parent
screenTimeout: Settings.privacyScreenTimeout
timelineRoot: timeline
visible: Settings.privacyScreen
windowTarget: roomWindowW
}
}
}
2023-06-02 01:45:24 +02:00
Component {
id: nestedSpaceMenuLevel
2023-06-02 01:45:24 +02:00
SpaceMenuLevel {
childMenu: rootSpaceMenu.childMenu
roomid: roomContextMenu.roomid
}
}
2023-06-02 01:45:24 +02:00
Platform.Menu {
id: roomContextMenu
2023-06-02 01:45:24 +02:00
property string roomid
property var tags
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
function show(roomid_, tags_) {
roomid = roomid_;
tags = tags_;
open();
}
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
InputDialog {
id: newTag
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
prompt: qsTr("Enter the tag you want to use:")
title: qsTr("New tag")
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
onAccepted: function (text) {
Rooms.toggleTag(roomContextMenu.roomid, "u." + text, true);
}
}
Platform.MenuItem {
text: qsTr("Open separately")
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
onTriggered: {
var roomWindow = roomWindowComponent.createObject(null, {
"room": Rooms.getRoomById(roomContextMenu.roomid),
"roomPreview": Rooms.getRoomPreviewById(roomContextMenu.roomid)
});
roomWindow.showNormal();
destroyOnClose(roomWindow);
}
}
Platform.MenuItem {
text: qsTr("Room settings")
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
onTriggered: TimelineManager.openRoomSettings(roomContextMenu.roomid)
}
Platform.MenuItem {
text: qsTr("Leave room")
2021-05-30 12:41:44 +02:00
2023-06-02 01:45:24 +02:00
onTriggered: TimelineManager.openLeaveRoomDialog(roomContextMenu.roomid)
}
Platform.MenuItem {
text: qsTr("Copy room link")
2021-05-30 12:41:44 +02:00
2023-06-02 01:45:24 +02:00
onTriggered: Rooms.copyLink(roomContextMenu.roomid)
}
Platform.Menu {
id: tagsMenu
2021-05-30 12:41:44 +02:00
2023-06-02 01:45:24 +02:00
title: qsTr("Tag room as:")
2021-05-30 12:41:44 +02:00
2023-06-02 01:45:24 +02:00
Instantiator {
model: Communities.tagsWithDefault
2022-03-26 17:28:44 +01:00
2023-06-02 01:45:24 +02:00
delegate: Platform.MenuItem {
property string t: modelData
checkable: true
checked: roomContextMenu.tags !== undefined && roomContextMenu.tags.includes(t)
text: {
switch (t) {
case "m.favourite":
return qsTr("Favourite");
case "m.lowpriority":
return qsTr("Low priority");
case "m.server_notice":
return qsTr("Server notice");
default:
return t.substring(2);
2022-09-05 02:00:20 +02:00
}
}
2023-06-02 01:45:24 +02:00
onTriggered: Rooms.toggleTag(roomContextMenu.roomid, t, checked)
2021-05-30 12:41:44 +02:00
}
2023-06-02 01:45:24 +02:00
onObjectAdded: (index, object) => tagsMenu.insertItem(index, object)
onObjectRemoved: (index, object) => tagsMenu.removeItem(object)
2021-05-14 23:35:34 +02:00
}
2023-06-02 01:45:24 +02:00
Platform.MenuItem {
text: qsTr("Create new tag...")
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
onTriggered: newTag.show()
2021-05-14 23:35:34 +02:00
}
}
2023-06-02 01:45:24 +02:00
SpaceMenuLevel {
id: rootSpaceMenu
2021-05-14 23:35:34 +02:00
2023-06-02 01:45:24 +02:00
childMenu: nestedSpaceMenuLevel
position: -1
roomid: roomContextMenu.roomid
title: qsTr("Add or remove from community...")
}
2021-05-14 23:35:34 +02:00
}
}
}