X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatviewsearchbar.cpp;h=5dcc11243c16a0209039b0c567732515ed07666c;hp=add0f3e29ab6d53c4a764722bf7779acaec943c6;hb=326a0d0783c8ecffb6a7bae02fd74f66bd4242fa;hpb=f824db0e31b54969e0b7fa0b5405b1e9173d482c diff --git a/src/qtui/chatviewsearchbar.cpp b/src/qtui/chatviewsearchbar.cpp index add0f3e2..5dcc1124 100644 --- a/src/qtui/chatviewsearchbar.cpp +++ b/src/qtui/chatviewsearchbar.cpp @@ -32,6 +32,7 @@ ChatViewSearchBar::ChatViewSearchBar(QWidget *parent) ui.hideButton->setIcon(BarIcon("dialog-close")); ui.searchUpButton->setIcon(SmallIcon("go-up")); ui.searchDownButton->setIcon(SmallIcon("go-down")); + _searchDelayTimer.setSingleShot(true); layout()->setContentsMargins(0, 0, 0, 0); @@ -47,6 +48,8 @@ ChatViewSearchBar::ChatViewSearchBar(QWidget *parent) hideSearchBar->setShortcut(Qt::Key_Escape); connect(ui.hideButton, SIGNAL(clicked()), toggleSearchBar, SLOT(toggle())); + connect(ui.searchEditLine, SIGNAL(textChanged(const QString &)), this, SLOT(delaySearch())); + connect(&_searchDelayTimer, SIGNAL(timeout()), this, SLOT(search())); } void ChatViewSearchBar::setVisible(bool visible) { @@ -55,6 +58,16 @@ void ChatViewSearchBar::setVisible(bool visible) { // a resize event which can lead to strange side effects. ui.searchEditLine->clear(); QWidget::setVisible(visible); - if(visible) ui.searchEditLine->setFocus(); + if(visible) + ui.searchEditLine->setFocus(); + else + emit hidden(); } +void ChatViewSearchBar::delaySearch() { + _searchDelayTimer.start(300); +} + +void ChatViewSearchBar::search() { + emit searchChanged(ui.searchEditLine->text()); +}