2023-02-21 23:48:49 +01:00
// SPDX-FileCopyrightText: Nheko Contributors
2021-03-07 05:57:56 +01:00
//
2021-03-05 00:35:15 +01:00
// SPDX-License-Identifier: GPL-3.0-or-later
2021-09-25 05:27:57 +02:00
import ".."
import "../ui"
2021-02-23 05:24:34 +01:00
import Qt . labs . platform 1.1 as Platform
2021-07-21 16:08:04 +02:00
import QtQuick 2.15
2021-02-09 18:41:39 +01:00
import QtQuick . Controls 2.3
import QtQuick . Layouts 1.2
2021-08-04 02:27:50 +02:00
import QtQuick . Window 2.13
2021-02-09 18:41:39 +01:00
import im . nheko 1.0
ApplicationWindow {
2021-02-20 02:53:14 +01:00
id: roomSettingsDialog
2021-02-09 18:41:39 +01:00
property var roomSettings
2022-02-25 21:57:19 +01:00
minimumWidth: 340
2022-03-02 10:02:01 +01:00
minimumHeight: 450
2022-02-25 22:05:35 +01:00
width: 450
height: 680
2023-06-02 01:29:05 +02:00
color: palette . window
2021-05-22 14:31:38 +02:00
modality: Qt . NonModal
2021-08-19 16:55:54 +02:00
flags: Qt . Dialog | Qt . WindowCloseButtonHint | Qt . WindowTitleHint
2021-04-17 20:40:31 +02:00
title: qsTr ( "Room Settings" )
2021-02-09 18:41:39 +01:00
Shortcut {
sequence: StandardKey . Cancel
onActivated: roomSettingsDialog . close ( )
}
2023-06-02 01:36:01 +02:00
2022-02-25 21:57:19 +01:00
Flickable {
id: flickable
boundsBehavior: Flickable . StopAtBounds
anchors.fill: parent
clip: true
flickableDirection: Flickable . VerticalFlick
2022-03-02 10:02:01 +01:00
contentWidth: roomSettingsDialog . width
2022-02-25 21:57:19 +01:00
contentHeight: contentLayout1 . height
2022-02-25 21:59:01 +01:00
ColumnLayout {
id: contentLayout1
2022-03-02 10:02:01 +01:00
width: parent . width
2022-02-25 21:59:01 +01:00
spacing: Nheko . paddingMedium
Avatar {
2022-08-22 01:01:20 +02:00
id: displayAvatar
2022-02-25 21:59:01 +01:00
Layout.topMargin: Nheko . paddingMedium
url: roomSettings . roomAvatarUrl . replace ( "mxc://" , "image://MxcImage/" )
roomid: roomSettings . roomId
displayName: roomSettings . roomName
2023-10-26 16:43:09 +02:00
Layout.preferredHeight: 130
Layout.preferredWidth: 130
2022-02-25 21:59:01 +01:00
Layout.alignment: Qt . AlignHCenter
2022-08-22 01:01:20 +02:00
onClicked: TimelineManager . openImageOverlay ( null , roomSettings . roomAvatarUrl , "" , 0 , 0 )
ImageButton {
hoverEnabled: true
ToolTip.visible: hovered
ToolTip.text: qsTr ( "Change room avatar." )
anchors.left: displayAvatar . left
anchors.top: displayAvatar . top
anchors.leftMargin: Nheko . paddingMedium
anchors.topMargin: Nheko . paddingMedium
visible: roomSettings . canChangeAvatar
image: ":/icons/icons/ui/edit.svg"
onClicked: {
2022-02-25 21:59:01 +01:00
roomSettings . updateAvatar ( ) ;
2022-08-22 01:01:20 +02:00
}
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
}
2021-02-11 19:09:11 +01:00
}
2022-02-25 21:59:01 +01:00
Spinner {
Layout.alignment: Qt . AlignHCenter
visible: roomSettings . isLoading
2023-06-02 01:29:05 +02:00
foreground: palette . mid
2022-02-25 21:59:01 +01:00
running: roomSettings . isLoading
}
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
Text {
id: errorText
2021-02-11 19:09:11 +01:00
2022-02-25 21:59:01 +01:00
color: "red"
visible: opacity > 0
opacity: 0
Layout.alignment: Qt . AlignHCenter
wrapMode: Text . Wrap // somehow still doesn't wrap
2022-03-02 10:02:01 +01:00
Layout.fillWidth: true
2022-02-25 21:59:01 +01:00
}
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
SequentialAnimation {
id: hideErrorAnimation
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
running: false
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
PauseAnimation {
duration: 4000
}
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
NumberAnimation {
target: errorText
property: 'opacity'
to: 0
duration: 1000
}
2021-02-11 19:09:11 +01:00
}
2022-02-25 21:59:01 +01:00
Connections {
target: roomSettings
function onDisplayError ( errorMessage ) {
errorText . text = errorMessage ;
errorText . opacity = 1 ;
hideErrorAnimation . restart ( ) ;
}
2021-02-09 18:41:39 +01:00
}
2022-03-30 06:45:31 +02:00
TextEdit {
id: roomName
property bool isNameEditingAllowed: false
readOnly: ! isNameEditingAllowed
textFormat: isNameEditingAllowed ? TextEdit.PlainText : TextEdit . RichText
text: isNameEditingAllowed ? roomSettings.plainRoomName : roomSettings . roomName
font.pixelSize: fontMetrics . font . pixelSize * 2
2023-06-02 01:29:05 +02:00
color: palette . text
2022-03-30 06:45:31 +02:00
Layout.alignment: Qt . AlignHCenter
Layout.maximumWidth: parent . width - ( Nheko . paddingSmall * 2 ) - nameChangeButton . anchors . leftMargin - ( nameChangeButton . width * 2 )
horizontalAlignment: TextEdit . AlignHCenter
wrapMode: TextEdit . Wrap
selectByMouse: true
Keys.onShortcutOverride: event . key === Qt . Key_Enter
Keys.onPressed: {
if ( event . matches ( StandardKey . InsertLineSeparator ) || event . matches ( StandardKey . InsertParagraphSeparator ) ) {
roomSettings . changeName ( roomName . text ) ;
roomName . isNameEditingAllowed = false ;
event . accepted = true ;
}
}
ImageButton {
id: nameChangeButton
visible: roomSettings . canChangeName
anchors.leftMargin: Nheko . paddingSmall
anchors.left: roomName . right
anchors.verticalCenter: roomName . verticalCenter
hoverEnabled: true
ToolTip.visible: hovered
ToolTip.text: qsTr ( "Change name of this room" )
ToolTip.delay: Nheko . tooltipDelay
image: roomName . isNameEditingAllowed ? ":/icons/icons/ui/checkmark.svg" : ":/icons/icons/ui/edit.svg"
onClicked: {
if ( roomName . isNameEditingAllowed ) {
roomSettings . changeName ( roomName . text ) ;
roomName . isNameEditingAllowed = false ;
} else {
roomName . isNameEditingAllowed = true ;
roomName . focus = true ;
roomName . selectAll ( ) ;
}
}
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
2022-03-30 06:45:31 +02:00
}
2022-04-24 00:53:22 +02:00
RowLayout {
spacing: Nheko . paddingMedium
Layout.alignment: Qt . AlignHCenter
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "%n member(s)" , "" , roomSettings . memberCount )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-04-24 00:53:22 +02:00
}
2021-07-21 16:08:04 +02:00
2022-04-24 00:53:22 +02:00
ImageButton {
image: ":/icons/icons/ui/people.svg"
hoverEnabled: true
ToolTip.visible: hovered
ToolTip.text: qsTr ( "View members of %1" ) . arg ( roomSettings . roomName )
onClicked: TimelineManager . openRoomMembers ( Rooms . getRoomById ( roomSettings . roomId ) )
2021-07-21 16:08:04 +02:00
}
2022-04-24 00:53:22 +02:00
}
2022-02-25 21:59:01 +01:00
TextArea {
2022-03-02 10:02:01 +01:00
id: roomTopic
property bool cut: implicitHeight > 100
2022-03-30 06:45:31 +02:00
property bool showMore: false
2022-03-02 10:02:01 +01:00
clip: true
2022-03-04 11:19:58 +01:00
Layout.maximumHeight: showMore ? Number.POSITIVE_INFINITY : 100
Layout.preferredHeight: implicitHeight
2022-02-25 21:59:01 +01:00
Layout.alignment: Qt . AlignHCenter
Layout.fillWidth: true
Layout.leftMargin: Nheko . paddingLarge
Layout.rightMargin: Nheko . paddingLarge
2021-02-13 14:38:52 +01:00
2022-03-30 06:45:31 +02:00
property bool isTopicEditingAllowed: false
readOnly: ! isTopicEditingAllowed
textFormat: isTopicEditingAllowed ? TextEdit.PlainText : TextEdit . RichText
2022-06-02 21:57:46 +02:00
text: isTopicEditingAllowed
? roomSettings . plainRoomTopic
: ( roomSettings . plainRoomTopic === "" ? ( "<i>" + qsTr ( "No topic set" ) + "</i>" ) : roomSettings . roomTopic )
2021-02-23 05:24:34 +01:00
wrapMode: TextEdit . WordWrap
2021-02-13 16:16:40 +01:00
background: null
2023-06-02 01:29:05 +02:00
color: palette . text
2021-02-23 05:24:34 +01:00
horizontalAlignment: TextEdit . AlignHCenter
2021-05-13 08:52:02 +02:00
onLinkActivated: Nheko . openLink ( link )
2021-02-22 21:35:11 +01:00
2023-06-19 01:38:40 +02:00
NhekoCursorShape {
2021-02-23 05:24:34 +01:00
anchors.fill: parent
cursorShape: parent . hoveredLink ? Qt.PointingHandCursor : Qt . ArrowCursor
}
2021-02-22 21:35:11 +01:00
2022-02-25 21:59:01 +01:00
}
2022-03-30 06:45:31 +02:00
ImageButton {
id: topicChangeButton
Layout.alignment: Qt . AlignHCenter
visible: roomSettings . canChangeTopic
hoverEnabled: true
ToolTip.visible: hovered
ToolTip.text: qsTr ( "Change topic of this room" )
ToolTip.delay: Nheko . tooltipDelay
image: roomTopic . isTopicEditingAllowed ? ":/icons/icons/ui/checkmark.svg" : ":/icons/icons/ui/edit.svg"
onClicked: {
if ( roomTopic . isTopicEditingAllowed ) {
roomSettings . changeTopic ( roomTopic . text ) ;
roomTopic . isTopicEditingAllowed = false ;
} else {
roomTopic . isTopicEditingAllowed = true ;
roomTopic . showMore = true ;
roomTopic . focus = true ;
//roomTopic.selectAll();
}
}
}
2022-03-02 10:02:01 +01:00
Item {
Layout.alignment: Qt . AlignHCenter
id: showMorePlaceholder
Layout.preferredHeight: showMoreButton . height
Layout.preferredWidth: showMoreButton . width
visible: roomTopic . cut
}
2021-02-09 18:41:39 +01:00
2022-02-25 21:59:01 +01:00
GridLayout {
columns: 2
rowSpacing: Nheko . paddingMedium
Layout.margins: Nheko . paddingMedium
2022-03-02 10:02:01 +01:00
Layout.fillWidth: true
2021-02-09 18:41:39 +01:00
2022-02-25 21:59:01 +01:00
Label {
2023-06-28 17:07:49 +02:00
text: qsTr ( "NOTIFICATIONS" )
2022-02-25 21:59:01 +01:00
font.bold: true
2023-06-02 01:29:05 +02:00
color: palette . text
2023-06-28 17:07:49 +02:00
Layout.columnSpan: 2
2022-02-25 21:59:01 +01:00
Layout.fillWidth: true
2023-06-28 17:07:49 +02:00
Layout.topMargin: Nheko . paddingLarge
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "Notifications" )
Layout.fillWidth: true
2023-06-02 01:29:05 +02:00
color: palette . text
2022-02-25 21:59:01 +01:00
}
2021-02-14 06:56:10 +01:00
2022-02-25 21:59:01 +01:00
ComboBox {
model: [ qsTr ( "Muted" ) , qsTr ( "Mentions only" ) , qsTr ( "All messages" ) ]
currentIndex: roomSettings . notifications
onActivated: {
roomSettings . changeNotifications ( index ) ;
}
Layout.fillWidth: true
2022-03-02 10:02:01 +01:00
WheelHandler { } // suppress scrolling changing values
2021-02-11 15:24:09 +01:00
}
2021-02-09 18:41:39 +01:00
2023-06-28 17:07:49 +02:00
Label {
text: qsTr ( "ENTRY PERMISSIONS" )
font.bold: true
color: palette . text
Layout.columnSpan: 2
Layout.fillWidth: true
Layout.topMargin: Nheko . paddingLarge
}
2022-02-25 21:59:01 +01:00
Label {
2022-09-19 21:39:37 +02:00
text: qsTr ( "Anyone can join" )
2022-02-25 21:59:01 +01:00
Layout.fillWidth: true
2023-06-02 01:29:05 +02:00
color: palette . text
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
2022-09-19 21:39:37 +02:00
ToggleButton {
id: publicRoomButton
2022-02-25 21:59:01 +01:00
enabled: roomSettings . canChangeJoinRules
2022-09-19 21:39:37 +02:00
checked: ! roomSettings . privateAccess
Layout.alignment: Qt . AlignRight
}
2021-08-17 23:31:25 +02:00
2022-09-19 21:39:37 +02:00
Label {
text: qsTr ( "Allow knocking" )
Layout.fillWidth: true
2023-06-02 01:29:05 +02:00
color: palette . text
2022-09-19 21:39:37 +02:00
visible: knockingButton . visible
}
2021-08-17 23:31:25 +02:00
2022-09-19 21:39:37 +02:00
ToggleButton {
id: knockingButton
2022-06-18 00:17:24 +02:00
2022-09-19 21:39:37 +02:00
visible: ! publicRoomButton . checked
enabled: roomSettings . canChangeJoinRules && roomSettings . supportsKnocking
checked: roomSettings . knockingEnabled
onCheckedChanged: {
if ( checked && ! roomSettings . supportsKnockRestricted ) restrictedButton . checked = false ;
2022-02-25 21:59:01 +01:00
}
2022-09-19 21:39:37 +02:00
Layout.alignment: Qt . AlignRight
}
Label {
text: qsTr ( "Allow joining via other rooms" )
Layout.fillWidth: true
2023-06-02 01:29:05 +02:00
color: palette . text
2022-09-19 21:39:37 +02:00
visible: restrictedButton . visible
}
ToggleButton {
id: restrictedButton
visible: ! publicRoomButton . checked
enabled: roomSettings . canChangeJoinRules && roomSettings . supportsRestricted
checked: roomSettings . restrictedEnabled
onCheckedChanged: {
if ( checked && ! roomSettings . supportsKnockRestricted ) knockingButton . checked = false ;
2022-02-25 21:59:01 +01:00
}
2022-09-19 21:39:37 +02:00
Layout.alignment: Qt . AlignRight
}
Label {
text: qsTr ( "Rooms to join via" )
Layout.fillWidth: true
2023-06-02 01:29:05 +02:00
color: palette . text
2022-09-19 21:39:37 +02:00
visible: allowedRoomsButton . visible
}
Button {
id: allowedRoomsButton
visible: restrictedButton . checked && restrictedButton . visible
enabled: roomSettings . canChangeJoinRules && roomSettings . supportsRestricted
text: qsTr ( "Change" )
ToolTip.text: qsTr ( "Change the list of rooms users can join this room via. Usually this is the official community of this room." )
onClicked: timelineRoot . showAllowedRoomsEditor ( roomSettings )
Layout.alignment: Qt . AlignRight
}
Label {
text: qsTr ( "Allow guests to join" )
Layout.fillWidth: true
2023-06-02 01:29:05 +02:00
color: palette . text
2022-09-19 21:39:37 +02:00
}
ToggleButton {
id: guestAccessButton
enabled: roomSettings . canChangeJoinRules
checked: roomSettings . guestAccess
Layout.alignment: Qt . AlignRight
}
Button {
visible: publicRoomButton . checked == roomSettings . privateAccess || knockingButton . checked != roomSettings . knockingEnabled || restrictedButton . checked != roomSettings . restrictedEnabled || guestAccessButton . checked != roomSettings . guestAccess || roomSettings . allowedRoomsModified
enabled: roomSettings . canChangeJoinRules
text: qsTr ( "Apply access rules" )
onClicked: roomSettings . changeAccessRules ( ! publicRoomButton . checked , guestAccessButton . checked , knockingButton . checked , restrictedButton . checked )
Layout.columnSpan: 2
2022-02-25 21:59:01 +01:00
Layout.fillWidth: true
2021-02-11 15:24:09 +01:00
}
2021-02-09 18:41:39 +01:00
2023-06-24 01:04:54 +02:00
Label {
2023-06-28 17:07:49 +02:00
text: qsTr ( "MESSAGE VISIBILITY" )
font.bold: true
color: palette . text
Layout.columnSpan: 2
Layout.fillWidth: true
Layout.topMargin: Nheko . paddingLarge
}
Label {
text: qsTr ( "Allow viewing history without joining" )
2023-06-24 01:04:54 +02:00
Layout.fillWidth: true
color: palette . text
2023-06-28 17:07:49 +02:00
ToolTip.text: qsTr ( "This is useful to see previews of the room or view it on public websites." )
ToolTip.visible: publicHistoryHover . hovered
ToolTip.delay: Nheko . tooltipDelay
HoverHandler {
id: publicHistoryHover
}
2023-06-24 01:04:54 +02:00
}
2023-06-28 17:07:49 +02:00
ToggleButton {
id: publicHistoryButton
enabled: roomSettings . canChangeHistoryVisibility
checked: roomSettings . historyVisibility == RoomSettings . WorldReadable
Layout.alignment: Qt . AlignRight
}
Label {
visible: ! publicHistoryButton . checked
text: qsTr ( "Members can see messages since" )
Layout.fillWidth: true
color: palette . text
Layout.alignment: Qt . AlignTop | Qt . AlignLeft
ToolTip.text: qsTr ( "How much of the history is visible to joined members. Changing this won't affect the visibility of already sent messages. It only applies to new messages." )
ToolTip.visible: privateHistoryHover . hovered
ToolTip.delay: Nheko . tooltipDelay
HoverHandler {
id: privateHistoryHover
2023-06-24 01:04:54 +02:00
}
2023-06-28 17:07:49 +02:00
}
ColumnLayout {
2023-06-24 01:04:54 +02:00
Layout.fillWidth: true
2023-06-28 17:07:49 +02:00
visible: ! publicHistoryButton . checked
2023-06-24 01:04:54 +02:00
enabled: roomSettings . canChangeHistoryVisibility
2023-06-28 17:07:49 +02:00
Layout.alignment: Qt . AlignTop | Qt . AlignRight
2023-06-24 01:04:54 +02:00
2023-06-28 17:07:49 +02:00
RadioButton {
id: sharedHistory
checked: roomSettings . historyVisibility == RoomSettings . Shared
text: qsTr ( "Everything" )
ToolTip.text: qsTr ( "As long as the user joined, they can see all previous messages." )
ToolTip.visible: hovered
ToolTip.delay: Nheko . tooltipDelay
}
RadioButton {
id: invitedHistory
checked: roomSettings . historyVisibility == RoomSettings . Invited
text: qsTr ( "They got invited" )
ToolTip.text: qsTr ( "Members can only see messages from when they got invited going forward." )
2023-06-24 01:04:54 +02:00
ToolTip.visible: hovered
ToolTip.delay: Nheko . tooltipDelay
}
2023-06-28 17:07:49 +02:00
RadioButton {
id: joinedHistory
checked: roomSettings . historyVisibility == RoomSettings . Joined || roomSettings . historyVisibility == RoomSettings . WorldReadable
text: qsTr ( "They joined" )
ToolTip.text: qsTr ( "Members can only see messages since after they joined." )
ToolTip.visible: hovered
ToolTip.delay: Nheko . tooltipDelay
}
}
2023-06-24 01:04:54 +02:00
2023-06-28 17:07:49 +02:00
Button {
visible: roomSettings . historyVisibility != selectedVisibility
enabled: roomSettings . canChangeHistoryVisibility
text: qsTr ( "Apply visibility changes" )
property int selectedVisibility: {
if ( publicHistoryButton . checked )
return RoomSettings . WorldReadable ;
else if ( sharedHistory . checked )
return RoomSettings . Shared ;
else if ( invitedHistory . checked )
return RoomSettings . Invited ;
return RoomSettings . Joined ;
}
onClicked: roomSettings . changeHistoryVisibility ( selectedVisibility )
Layout.columnSpan: 2
Layout.fillWidth: true
}
Label {
text: qsTr ( "Locally hidden events" )
color: palette . text
}
HiddenEventsDialog {
id: hiddenEventsDialog
roomid: roomSettings . roomId
roomName: roomSettings . roomName
}
Button {
text: qsTr ( "Configure" )
ToolTip.text: qsTr ( "Select events to hide in this room" )
onClicked: hiddenEventsDialog . show ( )
Layout.alignment: Qt . AlignRight
}
2023-07-05 00:08:37 +02:00
Label {
text: qsTr ( "Automatic event deletion" )
color: palette . text
}
EventExpirationDialog {
id: eventExpirationDialog
roomid: roomSettings . roomId
roomName: roomSettings . roomName
}
Button {
text: qsTr ( "Configure" )
ToolTip.text: qsTr ( "Select if your events get automatically deleted in this room." )
onClicked: eventExpirationDialog . show ( )
Layout.alignment: Qt . AlignRight
}
2023-06-28 17:07:49 +02:00
Label {
text: qsTr ( "GENERAL SETTINGS" )
font.bold: true
color: palette . text
Layout.columnSpan: 2
Layout.fillWidth: true
Layout.topMargin: Nheko . paddingLarge
2023-06-24 01:04:54 +02:00
}
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "Encryption" )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
2022-02-25 21:59:01 +01:00
ToggleButton {
id: encryptionToggle
2021-02-11 15:24:09 +01:00
2022-02-25 21:59:01 +01:00
checked: roomSettings . isEncryptionEnabled
onCheckedChanged: {
if ( roomSettings . isEncryptionEnabled ) {
checked = true ;
return ;
}
2023-03-01 20:39:16 +01:00
if ( checked === true )
confirmEncryptionDialog . open ( ) ;
2021-02-11 15:24:09 +01:00
}
2022-02-25 21:59:01 +01:00
Layout.alignment: Qt . AlignRight
2021-02-11 15:24:09 +01:00
}
2022-02-25 21:59:01 +01:00
Platform . MessageDialog {
id: confirmEncryptionDialog
2021-02-20 02:53:14 +01:00
2022-02-25 21:59:01 +01:00
title: qsTr ( "End-to-End Encryption" )
2023-10-26 01:51:45 +02:00
text: qsTr ( ` Encryption is currently experimental and things might break unexpectedly . < br >
Please take note that it can ' t be disabled afterwards . ` )
2022-02-25 21:59:01 +01:00
modality: Qt . NonModal
onAccepted: {
if ( roomSettings . isEncryptionEnabled )
return ;
2021-02-11 15:24:09 +01:00
2022-02-25 21:59:01 +01:00
roomSettings . enableEncryption ( ) ;
}
onRejected: {
encryptionToggle . checked = false ;
}
buttons: Platform . MessageDialog . Ok | Platform . MessageDialog . Cancel
2021-02-11 15:24:09 +01:00
}
2022-02-25 21:59:01 +01:00
2022-05-27 16:31:54 +02:00
Label {
text: qsTr ( "Permission" )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-05-27 16:31:54 +02:00
}
Button {
text: qsTr ( "Configure" )
ToolTip.text: qsTr ( "View and change the permissions in this room" )
onClicked: timelineRoot . showPLEditor ( roomSettings )
Layout.alignment: Qt . AlignRight
2022-07-08 17:28:28 +02:00
}
Label {
2022-07-16 13:04:35 +02:00
text: qsTr ( "Aliases" )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-07-08 17:28:28 +02:00
}
Button {
text: qsTr ( "Configure" )
ToolTip.text: qsTr ( "View and change the addresses/aliases of this room" )
onClicked: timelineRoot . showAliasEditor ( roomSettings )
Layout.alignment: Qt . AlignRight
2022-05-27 16:31:54 +02:00
}
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "Sticker & Emote Settings" )
2023-06-02 01:29:05 +02:00
color: palette . text
2021-02-11 15:24:09 +01:00
}
2022-02-25 21:59:01 +01:00
Button {
text: qsTr ( "Change" )
2022-09-30 06:23:39 +02:00
ToolTip.text: qsTr ( "Change what packs are enabled, remove packs, or create new ones" )
2022-02-25 21:59:01 +01:00
onClicked: TimelineManager . openImagePackSettings ( roomSettings . roomId )
Layout.alignment: Qt . AlignRight
}
2021-07-21 13:37:57 +02:00
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "INFO" )
font.bold: true
2023-06-02 01:29:05 +02:00
color: palette . text
2023-06-28 17:07:49 +02:00
Layout.columnSpan: 2
Layout.topMargin: Nheko . paddingLarge
2022-02-25 21:59:01 +01:00
Layout.fillWidth: true
}
2021-02-09 18:41:39 +01:00
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "Internal ID" )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
2022-03-03 21:51:26 +01:00
AbstractButton { // AbstractButton does not allow setting text color
2022-02-25 21:59:01 +01:00
Layout.alignment: Qt . AlignRight
2022-03-02 10:02:01 +01:00
Layout.fillWidth: true
2022-03-03 21:51:26 +01:00
Layout.preferredHeight: idLabel . height
Label { // TextEdit does not trigger onClicked
id: idLabel
text: roomSettings . roomId
font.pixelSize: Math . floor ( fontMetrics . font . pixelSize * 0.8 )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-03-03 21:51:26 +01:00
width: parent . width
2022-03-04 13:40:44 +01:00
horizontalAlignment: Text . AlignRight
2022-03-03 21:51:26 +01:00
wrapMode: Text . WrapAnywhere
ToolTip.text: qsTr ( "Copied to clipboard" )
ToolTip.visible: toolTipTimer . running
}
TextEdit { // label does not allow selection
id: textEdit
visible: false
text: roomSettings . roomId
}
onClicked: {
textEdit . selectAll ( )
textEdit . copy ( )
toolTipTimer . start ( )
}
Timer {
id: toolTipTimer
}
2022-02-25 21:59:01 +01:00
}
2021-02-14 06:56:10 +01:00
2022-02-25 21:59:01 +01:00
Label {
text: qsTr ( "Room Version" )
2023-06-02 01:29:05 +02:00
color: palette . text
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
2022-02-25 21:59:01 +01:00
Label {
text: roomSettings . roomVersion
font.pixelSize: fontMetrics . font . pixelSize
Layout.alignment: Qt . AlignRight
2023-06-02 01:29:05 +02:00
color: palette . text
2022-02-25 21:59:01 +01:00
}
2021-02-09 18:41:39 +01:00
}
}
2022-02-25 21:57:19 +01:00
}
2022-03-02 10:02:01 +01:00
Button {
id: showMoreButton
2022-03-04 11:19:58 +01:00
anchors.horizontalCenter: flickable . horizontalCenter
y: Math . min ( showMorePlaceholder . y + contentLayout1 . y - flickable . contentY , flickable . height - height )
2022-03-02 10:02:01 +01:00
visible: roomTopic . cut
2022-03-08 11:31:54 +01:00
text: roomTopic . showMore ? qsTr ( "show less" ) : qsTr ( "show more" )
2022-03-02 10:02:01 +01:00
onClicked: { roomTopic . showMore = ! roomTopic . showMore
console . log ( flickable . visibleArea )
}
}
2022-02-25 21:57:19 +01:00
footer: DialogButtonBox {
standardButtons: DialogButtonBox . Ok
onAccepted: close ( )
2021-02-09 18:41:39 +01:00
}
2021-02-20 02:53:14 +01:00
}