2020-11-20 01:22:36 +01:00
|
|
|
import QtQuick 2.9
|
|
|
|
import QtQuick.Controls 2.3
|
|
|
|
import QtQuick.Layouts 1.2
|
|
|
|
import im.nheko 1.0
|
|
|
|
|
|
|
|
Popup {
|
|
|
|
id: popup
|
|
|
|
|
|
|
|
property int currentIndex: -1
|
|
|
|
property string completerName
|
|
|
|
property var completer
|
|
|
|
|
|
|
|
function up() {
|
|
|
|
currentIndex = currentIndex - 1;
|
|
|
|
if (currentIndex == -2)
|
|
|
|
currentIndex = repeater.count - 1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function down() {
|
|
|
|
currentIndex = currentIndex + 1;
|
|
|
|
if (currentIndex >= repeater.count)
|
|
|
|
currentIndex = -1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function currentCompletion() {
|
|
|
|
if (currentIndex > -1 && currentIndex < repeater.count)
|
|
|
|
return completer.completionAt(currentIndex);
|
|
|
|
else
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
onCompleterNameChanged: {
|
|
|
|
if (completerName)
|
|
|
|
completer = TimelineManager.timeline.input.completerFor(completerName);
|
2020-11-20 02:38:08 +01:00
|
|
|
else
|
|
|
|
completer = undefined;
|
2020-11-20 01:22:36 +01:00
|
|
|
}
|
|
|
|
padding: 0
|
|
|
|
onAboutToShow: currentIndex = -1
|
|
|
|
|
2020-11-20 02:38:08 +01:00
|
|
|
Connections {
|
|
|
|
onTimelineChanged: completer = null
|
|
|
|
target: TimelineManager
|
|
|
|
}
|
|
|
|
|
2020-11-20 01:22:36 +01:00
|
|
|
ColumnLayout {
|
|
|
|
anchors.fill: parent
|
|
|
|
spacing: 0
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
id: repeater
|
|
|
|
|
|
|
|
model: completer
|
|
|
|
|
|
|
|
delegate: Rectangle {
|
|
|
|
color: model.index == popup.currentIndex ? colors.window : colors.base
|
2020-11-20 04:33:11 +01:00
|
|
|
height: chooser.childrenRect.height + 4
|
|
|
|
width: chooser.childrenRect.width + 4
|
2020-11-20 01:22:36 +01:00
|
|
|
|
2020-11-20 04:33:11 +01:00
|
|
|
DelegateChooser {
|
|
|
|
id: chooser
|
2020-11-20 01:22:36 +01:00
|
|
|
|
2020-11-20 04:33:11 +01:00
|
|
|
roleValue: popup.completerName
|
2020-11-20 01:22:36 +01:00
|
|
|
anchors.centerIn: parent
|
|
|
|
|
2020-11-20 04:33:11 +01:00
|
|
|
DelegateChoice {
|
|
|
|
roleValue: "user"
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
id: del
|
|
|
|
|
|
|
|
anchors.centerIn: parent
|
|
|
|
|
|
|
|
Avatar {
|
|
|
|
height: 24
|
|
|
|
width: 24
|
|
|
|
displayName: model.displayName
|
|
|
|
url: model.avatarUrl.replace("mxc://", "image://MxcImage/")
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
text: model.displayName
|
|
|
|
color: colors.text
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-11-20 01:22:36 +01:00
|
|
|
}
|
|
|
|
|
2020-11-20 04:33:11 +01:00
|
|
|
DelegateChoice {
|
|
|
|
roleValue: "emoji"
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
id: del
|
|
|
|
|
|
|
|
anchors.centerIn: parent
|
|
|
|
|
|
|
|
Label {
|
|
|
|
text: model.unicode
|
|
|
|
color: colors.text
|
|
|
|
font: Settings.emojiFont
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
text: model.shortName
|
|
|
|
color: colors.text
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-11-20 01:22:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
enter: Transition {
|
|
|
|
NumberAnimation {
|
|
|
|
property: "opacity"
|
|
|
|
from: 0
|
|
|
|
to: 1
|
|
|
|
duration: 100
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
exit: Transition {
|
|
|
|
NumberAnimation {
|
|
|
|
property: "opacity"
|
|
|
|
from: 1
|
|
|
|
to: 0
|
|
|
|
duration: 100
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
background: Rectangle {
|
|
|
|
color: colors.base
|
|
|
|
implicitHeight: popup.contentHeight
|
|
|
|
implicitWidth: popup.contentWidth
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|