Newer
Older
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);
}
padding: 0
onAboutToShow: currentIndex = -1
Connections {
onTimelineChanged: completer = null
target: TimelineManager
}
ColumnLayout {
anchors.fill: parent
spacing: 0
Repeater {
id: repeater
model: completer
delegate: Rectangle {
color: model.index == popup.currentIndex ? colors.window : colors.alternateBase
height: chooser.childrenRect.height + 4
width: chooser.childrenRect.width + 4
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
}
}
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
}
}
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
}
}
}
}
}
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.alternateBase
implicitHeight: popup.contentHeight
implicitWidth: popup.contentWidth
}
}