nheko/resources/qml/ForwardCompleter.qml

108 lines
2.9 KiB
QML
Raw Normal View History

2021-04-13 19:01:49 +02:00
// SPDX-FileCopyrightText: 2021 Nheko Contributors
//
// SPDX-License-Identifier: GPL-3.0-or-later
import "./delegates/"
2021-04-13 19:01:49 +02:00
import QtQuick 2.9
import QtQuick.Controls 2.3
import im.nheko 1.0
2021-04-15 18:51:25 +02:00
Popup {
2021-04-13 19:01:49 +02:00
id: forwardMessagePopup
2021-04-15 18:51:25 +02:00
palette: colors
parent: Overlay.overlay
modal: true
2021-04-13 19:01:49 +02:00
x: 400
2021-04-15 18:51:25 +02:00
y: 200
2021-04-13 19:01:49 +02:00
2021-04-15 18:51:25 +02:00
width: implicitWidth >= 300 ? implicitWidth : 300
height: implicitHeight + completerPopup.height + padding * 2
leftPadding: 10
rightPadding: 10
2021-04-13 19:01:49 +02:00
property var mid
onOpened: {
completerPopup.open();
roomTextInput.forceActiveFocus();
}
onClosed: {
completerPopup.close();
}
function setMessageEventId(mid_in) {
mid = mid_in;
}
2021-04-15 18:51:25 +02:00
Column {
id: forwardColumn
spacing: 5
2021-04-15 18:51:25 +02:00
Label {
id: titleLabel
text: qsTr("Forward Message")
font.bold: true
bottomPadding: 10
}
2021-04-13 19:01:49 +02:00
2021-04-15 18:51:25 +02:00
Reply {
id: replyPreview
modelData: TimelineManager.timeline ? TimelineManager.timeline.getDump(mid, "") : {
}
userColor: TimelineManager.userColor(modelData.userId, colors.window)
}
2021-04-13 19:01:49 +02:00
2021-04-15 18:51:25 +02:00
MatrixTextField {
id: roomTextInput
2021-04-15 18:51:25 +02:00
width: forwardMessagePopup.width - forwardMessagePopup.leftPadding * 2
color: colors.text
onTextEdited: {
completerPopup.completer.searchString = text;
}
Keys.onPressed: {
if (event.key == Qt.Key_Up && completerPopup.opened) {
event.accepted = true;
completerPopup.up();
} else if (event.key == Qt.Key_Down && completerPopup.opened) {
event.accepted = true;
completerPopup.down();
} else if (event.matches(StandardKey.InsertParagraphSeparator)) {
completerPopup.finishCompletion();
event.accepted = true;
}
2021-04-13 19:01:49 +02:00
}
}
}
Completer {
id: completerPopup
2021-04-15 18:51:25 +02:00
y: titleLabel.height + replyPreview.height + roomTextInput.height + roomTextInput.bottomPadding + forwardColumn.spacing * 3
2021-04-13 19:01:49 +02:00
width: forwardMessagePopup.width - forwardMessagePopup.leftPadding * 2
completerName: "room"
2021-04-15 18:51:25 +02:00
fullWidth: true
centerRowContent: false
2021-04-13 19:01:49 +02:00
avatarHeight: 24
avatarWidth: 24
bottomToTop: false
closePolicy: Popup.NoAutoClose
}
Connections {
onCompletionSelected: {
TimelineManager.timeline.forwardMessage(messageContextMenu.eventId, id);
forwardMessagePopup.close();
}
onCountChanged: {
if (completerPopup.count > 0 && (completerPopup.currentIndex < 0 || completerPopup.currentIndex >= completerPopup.count))
completerPopup.currentIndex = 0;
}
target: completerPopup
}
2021-04-15 18:51:25 +02:00
Overlay.modal: Rectangle {
color: "#aa1E1E1E"
}
2021-04-13 19:01:49 +02:00
}