2021-02-21 18:40:21 +01:00
|
|
|
import QtQuick 2.9
|
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
import im.nheko 1.0
|
|
|
|
|
|
|
|
Popup {
|
2021-02-22 18:38:42 +01:00
|
|
|
id: quickSwitcher
|
2021-02-23 17:06:21 +01:00
|
|
|
|
2021-03-06 19:48:24 +01:00
|
|
|
property int textHeight: 32
|
2021-02-24 15:02:13 +01:00
|
|
|
property int textMargin: 8
|
2021-02-23 17:06:21 +01:00
|
|
|
|
2021-02-21 18:40:21 +01:00
|
|
|
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
|
2021-02-23 17:37:45 +01:00
|
|
|
palette: colors
|
2021-02-21 18:40:21 +01:00
|
|
|
|
2021-02-22 19:48:31 +01:00
|
|
|
Overlay.modal: Rectangle {
|
|
|
|
color: "#aa1E1E1E"
|
|
|
|
}
|
|
|
|
|
2021-02-23 17:06:21 +01:00
|
|
|
MatrixTextField {
|
2021-02-21 18:40:21 +01:00
|
|
|
id: roomTextInput
|
|
|
|
|
2021-02-21 19:31:50 +01:00
|
|
|
anchors.fill: parent
|
2021-02-26 07:09:51 +01:00
|
|
|
font.pixelSize: quickSwitcher.textHeight * 0.6
|
2021-02-24 15:02:13 +01:00
|
|
|
padding: textMargin
|
2021-02-23 17:37:45 +01:00
|
|
|
color: colors.text
|
2021-02-21 18:40:21 +01:00
|
|
|
|
|
|
|
onTextEdited: {
|
|
|
|
completerPopup.completer.setSearchString(text)
|
|
|
|
}
|
2021-02-22 18:38:42 +01:00
|
|
|
|
|
|
|
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();
|
2021-02-22 19:48:31 +01:00
|
|
|
} else if (event.matches(StandardKey.InsertParagraphSeparator)) {
|
|
|
|
completerPopup.finishCompletion()
|
|
|
|
event.accepted = true;
|
2021-02-22 18:38:42 +01:00
|
|
|
}
|
|
|
|
}
|
2021-02-21 18:40:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Completer {
|
|
|
|
id: completerPopup
|
|
|
|
|
2021-03-06 19:48:24 +01:00
|
|
|
x: roomTextInput.x
|
|
|
|
y: roomTextInput.y + roomTextInput.height + textMargin
|
|
|
|
width: parent.width
|
2021-02-21 18:40:21 +01:00
|
|
|
completerName: "room"
|
2021-02-26 07:09:51 +01:00
|
|
|
bottomToTop: false
|
2021-02-21 19:31:50 +01:00
|
|
|
fullWidth: true
|
2021-02-26 07:09:51 +01:00
|
|
|
avatarHeight: textHeight
|
|
|
|
avatarWidth: textHeight
|
2021-02-24 09:08:01 +01:00
|
|
|
centerRowContent: false
|
2021-02-24 15:02:13 +01:00
|
|
|
rowMargin: 8
|
|
|
|
rowSpacing: 6
|
2021-02-21 19:31:50 +01:00
|
|
|
|
|
|
|
closePolicy: Popup.NoAutoClose
|
2021-02-21 18:40:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
onOpened: {
|
|
|
|
completerPopup.open()
|
2021-02-23 17:06:21 +01:00
|
|
|
delay(200, function() {
|
|
|
|
roomTextInput.forceActiveFocus()
|
|
|
|
})
|
2021-02-21 19:31:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
onClosed: {
|
|
|
|
completerPopup.close()
|
2021-02-21 18:40:21 +01:00
|
|
|
}
|
2021-02-22 18:38:42 +01:00
|
|
|
|
|
|
|
Connections {
|
|
|
|
onCompletionSelected: {
|
|
|
|
TimelineManager.setHistoryView(id)
|
2021-02-22 19:48:31 +01:00
|
|
|
TimelineManager.highlightRoom(id)
|
2021-02-22 18:38:42 +01:00
|
|
|
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();
|
|
|
|
}
|
2021-02-21 18:40:21 +01:00
|
|
|
}
|