summaryrefslogtreecommitdiffstats
path: root/webkit/glue/editor_client_impl.cc
diff options
context:
space:
mode:
authorjcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-25 01:15:03 +0000
committerjcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-25 01:15:03 +0000
commit94b09c1bb66d640e54c571a6ab31d610fe318c53 (patch)
treed678067b4142b20ee5da363e09ac36d0d1c2a596 /webkit/glue/editor_client_impl.cc
parent9bd916052afca35014953ec65bb090fc8dfd0f94 (diff)
downloadchromium_src-94b09c1bb66d640e54c571a6ab31d610fe318c53.zip
chromium_src-94b09c1bb66d640e54c571a6ab31d610fe318c53.tar.gz
chromium_src-94b09c1bb66d640e54c571a6ab31d610fe318c53.tar.bz2
When in a form text field, pressing the up/down arrow keys should bring up the autofill popup.
Pressing up would not trigger that behavior. This happened because the default processing of the up arrow key is to move the caret to the beginning of the text input. Showing the autofill is done as a posted task. Because the caret was not at the end of the text-field by the time that task got executed, the popup would not show. The fix is to not default process the up/down arrow key messages when an autofill popup will be shown. Also fixed the WebViewImpl::HideAutoCompletePopup (harmless bug, calling it twice would cause it to hide the already hidden popup). BUG=6437 TEST=Make sure up/down arrow keys trigger the autofill menu correctly (especially when there is already text in the text-field). Make sure autofill still works as expected. Review URL: http://codereview.chromium.org/53017 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@12428 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue/editor_client_impl.cc')
-rw-r--r--webkit/glue/editor_client_impl.cc22
1 files changed, 15 insertions, 7 deletions
diff --git a/webkit/glue/editor_client_impl.cc b/webkit/glue/editor_client_impl.cc
index 670bee0..6f2bdf1 100644
--- a/webkit/glue/editor_client_impl.cc
+++ b/webkit/glue/editor_client_impl.cc
@@ -634,7 +634,13 @@ void EditorClientImpl::handleKeyboardEvent(WebCore::KeyboardEvent* evt) {
if (evt->keyCode() == WebCore::VKEY_DOWN ||
evt->keyCode() == WebCore::VKEY_UP) {
DCHECK(evt->target()->toNode());
- ShowAutofillForNode(evt->target()->toNode());
+ if (ShowAutofillForNode(evt->target()->toNode())) {
+ // We will show an autofill popup. Let's return so we don't handle the
+ // event. The handling could change the caret position, preventing the
+ // popup from showing (since the actual showing is delayed, see
+ // DoAutofill).
+ return;
+ }
}
if (handleEditingKeyboardEvent(evt))
@@ -664,14 +670,15 @@ void EditorClientImpl::textDidChangeInTextField(WebCore::Element* element) {
Autofill(static_cast<WebCore::HTMLInputElement*>(element), false);
}
-void EditorClientImpl::ShowAutofillForNode(WebCore::Node* node) {
+bool EditorClientImpl::ShowAutofillForNode(WebCore::Node* node) {
WebCore::HTMLInputElement* input_element =
webkit_glue::NodeToHTMLInputElement(node);
if (input_element)
- Autofill(input_element, true);
+ return Autofill(input_element, true);
+ return false;
}
-void EditorClientImpl::Autofill(WebCore::HTMLInputElement* input_element,
+bool EditorClientImpl::Autofill(WebCore::HTMLInputElement* input_element,
bool autofill_on_empty_value) {
// Cancel any pending DoAutofill calls.
autofill_factory_.RevokeAll();
@@ -679,16 +686,16 @@ void EditorClientImpl::Autofill(WebCore::HTMLInputElement* input_element,
// Let's try to trigger autofill for that field, if applicable.
if (!input_element->isEnabled() || !input_element->isTextField() ||
input_element->isPasswordField() || !input_element->autoComplete()) {
- return;
+ return false;
}
std::wstring name = AutofillForm::GetNameForInputElement(input_element);
if (name.empty()) // If the field has no name, then we won't have values.
- return;
+ return false;
// Don't attempt to autofill with values that are too large.
if (input_element->value().length() > kMaximumTextSizeForAutofill)
- return;
+ return false;
// We post a task for doing the autofill as the caret position is not set
// properly at this point ( http://bugs.webkit.org/show_bug.cgi?id=16976)
@@ -700,6 +707,7 @@ void EditorClientImpl::Autofill(WebCore::HTMLInputElement* input_element,
input_element,
autofill_on_empty_value,
backspace_pressed_));
+ return true;
}
void EditorClientImpl::DoAutofill(WebCore::HTMLInputElement* input_element,