From c4d8b6a4d5907def9538b024030dc0980cc4182b Mon Sep 17 00:00:00 2001 From: Maximilian Güntner Date: Sat, 2 Nov 2013 17:04:18 +0100 Subject: Fix the inconsistent behaviour of QCompleter MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit The TagWidget behaves now similiar to a QLineEdit. Pressing Enter/Return will now close the completion widget. Signed-off-by: Maximilian Güntner --- qt-ui/tagwidget.cpp | 34 +++++++++++++++++++++++++++++++++- qt-ui/tagwidget.h | 2 ++ 2 files changed, 35 insertions(+), 1 deletion(-) diff --git a/qt-ui/tagwidget.cpp b/qt-ui/tagwidget.cpp index bcefe5704..673242cfa 100644 --- a/qt-ui/tagwidget.cpp +++ b/qt-ui/tagwidget.cpp @@ -1,10 +1,12 @@ #include "tagwidget.h" #include #include +#include TagWidget::TagWidget(QWidget *parent) : GroupedLineEdit(parent), m_completer(NULL) { connect(this, SIGNAL(cursorPositionChanged()), this, SLOT(reparse())); + connect(this, SIGNAL(textChanged()), this, SLOT(reparse())); addColor(QColor(0x00, 0xAE, 0xFF)); addColor(QColor(0x00, 0x78, 0xB0)); @@ -15,6 +17,7 @@ void TagWidget::setCompleter(QCompleter *completer) m_completer = completer; m_completer->setWidget(this); connect(m_completer, SIGNAL(activated(QString)), this, SLOT(completionSelected(QString))); + connect(m_completer, SIGNAL(highlighted(QString)), this, SLOT(completionSelected(QString))); } QPair TagWidget::getCursorTagPosition() { @@ -98,7 +101,18 @@ void TagWidget::reparse() currentText = ""; if (m_completer) { m_completer->setCompletionPrefix(currentText); - m_completer->complete(); + if (m_completer->completionCount() == 1) { + if (m_completer->currentCompletion() == currentText) { + QAbstractItemView *popup = m_completer->popup(); + if (popup) + popup->hide(); + } + else + m_completer->complete(); + + } else { + m_completer->complete(); + } } } @@ -133,3 +147,21 @@ void TagWidget::clear() { GroupedLineEdit::clear(); blockSignals(false); } + +void TagWidget::keyPressEvent(QKeyEvent *e) { + switch (e->key()) { + case Qt::Key_Return: + case Qt::Key_Enter: + /* + * Fake the QLineEdit behaviour by simply + * closing the QAbstractViewitem + */ + if (m_completer) { + QAbstractItemView *popup = m_completer->popup(); + if (popup) + popup->hide(); + } + } + GroupedLineEdit::keyPressEvent(e); +} + diff --git a/qt-ui/tagwidget.h b/qt-ui/tagwidget.h index ff19d7283..b9c1619f9 100644 --- a/qt-ui/tagwidget.h +++ b/qt-ui/tagwidget.h @@ -19,6 +19,8 @@ public: public slots: void reparse(); void completionSelected(QString); +protected: + void keyPressEvent(QKeyEvent *e); private: QCompleter *m_completer; }; -- cgit v1.2.3-70-g09d2