From 4743583e3852d616daf7a7ade480ac5d04295474 Mon Sep 17 00:00:00 2001 From: Johannes Troscher Date: Sun, 21 Aug 2011 18:15:06 +0200 Subject: Fix vi-like navigation shortcuts This patch introduces a check on input/textarea elements to be sure we are NOT stealing focus there.. ;) It also introduces a check to let the feature being optional (just to be completely sure... ) CCBUG: 238761 REVIEW: 102255 REVIEWED-BY: adjam,elproxy --- src/rekonq.kcfg | 3 +++ src/settings/settings_general.ui | 17 ++++++++++++----- src/webview.cpp | 29 +++++++++++++++++++++++++++++ 3 files changed, 44 insertions(+), 5 deletions(-) diff --git a/src/rekonq.kcfg b/src/rekonq.kcfg index 4050c4a0..2d19b723 100644 --- a/src/rekonq.kcfg +++ b/src/rekonq.kcfg @@ -97,6 +97,9 @@ true + + false + diff --git a/src/settings/settings_general.ui b/src/settings/settings_general.ui index d0c31655..3f7c0675 100644 --- a/src/settings/settings_general.ui +++ b/src/settings/settings_general.ui @@ -194,6 +194,13 @@ + + + + Enable Vi-like navigation shortcuts + + + @@ -213,16 +220,16 @@ - - KLineEdit - QLineEdit -
klineedit.h
-
KComboBox QComboBox
kcombobox.h
+ + KLineEdit + QLineEdit +
klineedit.h
+
diff --git a/src/webview.cpp b/src/webview.cpp index d8325543..8dfcc051 100644 --- a/src/webview.cpp +++ b/src/webview.cpp @@ -643,6 +643,35 @@ void WebView::keyPressEvent(QKeyEvent *event) } } + // vi-like navigation + if (ReKonfig::enableViShortcuts()) + { + const QString tagName = page()->mainFrame()->evaluateJavaScript("document.activeElement.tagName").toString(); + if (tagName != QL1S("INPUT") && tagName != QL1S("TEXTAREA") && event->modifiers() == Qt::NoModifier) + { + switch (event->key()) + { + case Qt::Key_J: + event->accept(); + event = new QKeyEvent(QEvent::KeyPress, Qt::Key_Down, Qt::NoModifier); + break; + case Qt::Key_K: + event->accept(); + event = new QKeyEvent(QEvent::KeyPress, Qt::Key_Up, Qt::NoModifier); + break; + case Qt::Key_L: + event->accept(); + event = new QKeyEvent(QEvent::KeyPress, Qt::Key_Right, Qt::NoModifier); + break; + case Qt::Key_H: + event->accept(); + event = new QKeyEvent(QEvent::KeyPress, Qt::Key_Left, Qt::NoModifier); + break; + default: + break; + } + } + } KWebView::keyPressEvent(event); } -- cgit v1.2.1