nheko/resources/qml/QuickSwitcher.qml

92 lines
2.1 KiB
QML
Raw Normal View History

import QtQuick 2.9
import QtQuick.Controls 2.3
import im.nheko 1.0
Popup {
id: quickSwitcher
2021-02-23 17:06:21 +01:00
property int textWidth: 48
x: parent.width / 2 - width / 2
y: parent.height / 4 - height / 2
width: parent.width / 2
2021-02-23 17:06:21 +01:00
height: textWidth
modal: true
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutside
parent: Overlay.overlay
Overlay.modal: Rectangle {
color: "#aa1E1E1E"
}
2021-02-23 17:06:21 +01:00
MatrixTextField {
id: roomTextInput
anchors.fill: parent
2021-02-23 17:06:21 +01:00
font.pixelSize: quickSwitcher.textWidth - 12
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
2021-02-23 17:06:21 +01:00
x: roomTextInput.x - 5
y: roomTextInput.y + roomTextInput.height + 5
width: parent.width + 10
completerName: "room"
bottomToTop: true
fullWidth: true
2021-02-23 17:06:21 +01:00
avatarHeight: textWidth
avatarWidth: textWidth
closePolicy: Popup.NoAutoClose
}
onOpened: {
completerPopup.open()
2021-02-23 17:06:21 +01:00
delay(200, function() {
roomTextInput.forceActiveFocus()
})
}
onClosed: {
completerPopup.close()
}
Connections {
onCompletionSelected: {
console.log(id)
TimelineManager.setHistoryView(id)
TimelineManager.highlightRoom(id)
quickSwitcher.close()
}
target: completerPopup
}
2021-02-23 17:06:21 +01:00
Timer {
id: timer
}
function delay(delayTime, cb) {
timer.interval = delayTime;
timer.repeat = false;
timer.triggered.connect(cb);
timer.start();
}
}