From: Peter Penz Date: Fri, 19 Dec 2008 06:41:26 +0000 (+0000) Subject: Don't request the focus for the view because of a completed directory lister, instead... X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/commitdiff_plain/426a57997b111e76d7b74a69e9b4aedf7f463a35?ds=inline Don't request the focus for the view because of a completed directory lister, instead directly request it when we know that the user has entered a new URL. This prevents that the focus gets stolen from the Terminal when somebody types "touch foo". BUG: 178070 svn path=/trunk/KDE/kdebase/apps/; revision=898819 --- diff --git a/src/dolphinviewcontainer.cpp b/src/dolphinviewcontainer.cpp index 8b3def9f3..1b64f9803 100644 --- a/src/dolphinviewcontainer.cpp +++ b/src/dolphinviewcontainer.cpp @@ -271,10 +271,6 @@ void DolphinViewContainer::slotDirListerCompleted() KonqFileItemCapabilities capabilities(KFileItemList() << item); createNew->setEnabled(capabilities.supportsWriting()); } - - if (isActive()) { - m_view->setFocus(); - } } void DolphinViewContainer::showItemInfo(const KFileItem& item) @@ -386,6 +382,17 @@ void DolphinViewContainer::restoreView(const KUrl& url) } else { showErrorMessage(i18nc("@info:status", "Invalid protocol")); } + + if (isActive()) { + // When an URL has been entered, the view should get the focus. + // The focus must be requested asynchronously, as changing the URL might create + // a new view widget. Using QTimer::singleShow() works reliable, however + // QMetaObject::invokeMethod() with a queued connection does not work, which might + // indicate that we should pass a hint to DolphinView::updateView() + // regarding the focus instead. To test: Enter an URL and press CTRL+Enter. + // Expected result: The view should get the focus. + QTimer::singleShot(0, this, SLOT(requestFocus())); + } } void DolphinViewContainer::saveRootUrl(const KUrl& url) @@ -408,6 +415,11 @@ void DolphinViewContainer::redirect(const KUrl& oldUrl, const KUrl& newUrl) m_urlNavigator->blockSignals(block); } +void DolphinViewContainer::requestFocus() +{ + m_view->setFocus(); +} + void DolphinViewContainer::slotItemTriggered(const KFileItem& item) { KUrl url = item.targetUrl(); diff --git a/src/dolphinviewcontainer.h b/src/dolphinviewcontainer.h index d2adb5ed7..eb70c37e1 100644 --- a/src/dolphinviewcontainer.h +++ b/src/dolphinviewcontainer.h @@ -229,6 +229,9 @@ private slots: */ void redirect(const KUrl& oldUrl, const KUrl& newUrl); + /** Requests the focus for the view \a m_view. */ + void requestFocus(); + private: bool m_showProgress;