nheko/resources/qml/QuickSwitcher.qml

74 lines
1.7 KiB
QML

import QtQuick 2.9
import QtQuick.Controls 2.3
import im.nheko 1.0
Popup {
id: quickSwitcher
x: parent.width / 2 - width / 2
y: parent.height / 4 - height / 2
width: parent.width / 2
modal: true
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutside
parent: Overlay.overlay
Overlay.modal: Rectangle {
color: "#aa1E1E1E"
}
TextInput {
id: roomTextInput
focus: true
anchors.fill: parent
color: colors.text
onTextEdited: {
completerPopup.completer.setSearchString(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;
}
}
}
Completer {
id: completerPopup
x: roomTextInput.x
y: roomTextInput.y + parent.height
width: parent.width
completerName: "room"
bottomToTop: true
fullWidth: true
closePolicy: Popup.NoAutoClose
}
onOpened: {
completerPopup.open()
roomTextInput.forceActiveFocus()
}
onClosed: {
completerPopup.close()
}
Connections {
onCompletionSelected: {
console.log(id)
TimelineManager.setHistoryView(id)
TimelineManager.highlightRoom(id)
quickSwitcher.close()
}
target: completerPopup
}
}