diff options
author | Andrea Diamantini <adjam7@gmail.com> | 2011-01-09 11:40:43 +0100 |
---|---|---|
committer | Andrea Diamantini <adjam7@gmail.com> | 2011-01-09 11:42:23 +0100 |
commit | 527756748468ddd3d5e7fa1bafcb2e32bf02144b (patch) | |
tree | f1f9a34722932e30d8341ec8299cda07b18cfc15 /src/urlbar/completionwidget.cpp | |
parent | Should fix rekonq compilation against KDE SC 4.5... (diff) | |
download | rekonq-527756748468ddd3d5e7fa1bafcb2e32bf02144b.tar.xz |
Update the completion list when the user switches search engine on the fly.
Lionel Chauvin's work.
Reviewed by me :)
Diffstat (limited to 'src/urlbar/completionwidget.cpp')
-rw-r--r-- | src/urlbar/completionwidget.cpp | 72 |
1 files changed, 32 insertions, 40 deletions
diff --git a/src/urlbar/completionwidget.cpp b/src/urlbar/completionwidget.cpp index 087a10a6..0d2026af 100644 --- a/src/urlbar/completionwidget.cpp +++ b/src/urlbar/completionwidget.cpp @@ -66,26 +66,20 @@ CompletionWidget::CompletionWidget(QWidget *parent) } -void CompletionWidget::insertSearchList(const UrlSearchList &list, const QString& text) +void CompletionWidget::insertItems(const UrlSearchList &list, const QString& text, int offset) { - if (!isVisible()) - { - UrlResolver::setSearchEngine(SearchEngine::defaultEngine()); - } - - _list = list; - int i = 0; - foreach(const UrlSearchItem &item, _list) + Q_FOREACH(const UrlSearchItem &item, list) { ListItem *suggestion = ListItemFactory::create(item, text, this); - suggestion->setBackgroundRole(i % 2 ? QPalette::AlternateBase : QPalette::Base); - connect(suggestion, - SIGNAL(itemClicked(ListItem *, Qt::MouseButton, Qt::KeyboardModifiers)), - this, + suggestion->setBackgroundRole(offset % 2 ? QPalette::AlternateBase : QPalette::Base); + connect(suggestion, + SIGNAL(itemClicked(ListItem *, Qt::MouseButton, Qt::KeyboardModifiers)), + this, SLOT(itemChosen(ListItem *, Qt::MouseButton, Qt::KeyboardModifiers))); + connect(suggestion, SIGNAL(updateList()), this, SLOT(updateList())); connect(this, SIGNAL(nextItemSubChoice()), suggestion, SLOT(nextItemSubChoice())); - - suggestion->setObjectName(QString::number(i++)); + + suggestion->setObjectName(QString::number(offset++)); layout()->addWidget(suggestion); } } @@ -99,29 +93,16 @@ void CompletionWidget::updateSearchList(const UrlSearchList &list, const QString if(_hasSuggestions || _typedString != text) return; _hasSuggestions = true; - + if (_resList.count() > 0) { clear(); - insertSearchList(_resList, text); - - UrlSearchList sugList = list.mid(0,4); - // add new suggestions to the list - int offset = _list.count(); - Q_FOREACH(const UrlSearchItem &item, sugList) - { - ListItem *suggestion = ListItemFactory::create(item, text, this); - suggestion->setBackgroundRole(offset % 2 ? QPalette::AlternateBase : QPalette::Base); - connect(suggestion, - SIGNAL(itemClicked(ListItem *, Qt::MouseButton, Qt::KeyboardModifiers)), - this, - SLOT(itemChosen(ListItem *, Qt::MouseButton, Qt::KeyboardModifiers))); - connect(this, SIGNAL(nextItemSubChoice()), suggestion, SLOT(nextItemSubChoice())); - - suggestion->setObjectName(QString::number(offset++)); - layout()->addWidget(suggestion); - } + insertItems(_resList, text); + _list = _resList; + + UrlSearchList sugList = list.mid(0,4); + insertItems(sugList, text, _list.count()); _list.append(sugList); popup(); } @@ -239,7 +220,7 @@ bool CompletionWidget::eventFilter(QObject *obj, QEvent *ev) { ListItem *child; UrlBar *w; - + if (type == QEvent::KeyPress) { QKeyEvent *kev = static_cast<QKeyEvent *>(ev); @@ -307,12 +288,12 @@ bool CompletionWidget::eventFilter(QObject *obj, QEvent *ev) host += append; url.setHost(host); } - + emit chosenUrl(url, Rekonq::CurrentTab); } } - + if( _currentIndex == -1) _currentIndex = 0; child = findChild<ListItem *>(QString::number(_currentIndex)); @@ -320,7 +301,7 @@ bool CompletionWidget::eventFilter(QObject *obj, QEvent *ev) { kDebug() << "USING LISTITEM URL: " << child->url(); kDebug() << "USING LISTITEM TITLE: " << child->text(); - + //we can use the url of the listitem emit chosenUrl(child->url(), Rekonq::CurrentTab); } @@ -332,7 +313,7 @@ bool CompletionWidget::eventFilter(QObject *obj, QEvent *ev) kev->accept(); hide(); return true; - + case Qt::Key_Escape: hide(); return true; @@ -375,10 +356,16 @@ void CompletionWidget::itemChosen(ListItem *item, Qt::MouseButton button, Qt::Ke } +void CompletionWidget::updateList() +{ + suggestUrls(_typedString); +} + + void CompletionWidget::suggestUrls(const QString &text) { _typedString = text; - + QWidget *w = qobject_cast<QWidget *>(parent()); if (!w->hasFocus()) return; @@ -389,6 +376,11 @@ void CompletionWidget::suggestUrls(const QString &text) return; } + if (!isVisible()) + { + UrlResolver::setSearchEngine(SearchEngine::defaultEngine()); + } + UrlResolver *res = new UrlResolver(text); connect(res, SIGNAL(suggestionsReady(const UrlSearchList &, const QString &)), this, SLOT(updateSearchList(const UrlSearchList &, const QString &))); _resList = res->orderedSearchItems(); |