1 /* 2 * Copyright (C) 2010 Google Inc. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions are 6 * met: 7 * 8 * * Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * * Redistributions in binary form must reproduce the above 11 * copyright notice, this list of conditions and the following disclaimer 12 * in the documentation and/or other materials provided with the 13 * distribution. 14 * * Neither the name of Google Inc. nor the names of its 15 * contributors may be used to endorse or promote products derived from 16 * this software without specific prior written permission. 17 * 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 29 */ 30 31 #ifndef WebAutofillClient_h 32 #define WebAutofillClient_h 33 34 namespace blink { 35 36 class WebFormElement; 37 class WebFrame; 38 class WebInputElement; 39 class WebKeyboardEvent; 40 class WebNode; 41 class WebString; 42 43 template <typename T> class WebVector; 44 45 class WebAutofillClient { 46 public: 47 enum { 48 MenuItemIDAutocompleteEntry = 0, 49 MenuItemIDWarningMessage = -1, 50 MenuItemIDPasswordEntry = -2, 51 MenuItemIDSeparator = -3, 52 MenuItemIDClearForm = -4, 53 MenuItemIDAutofillOptions = -5, 54 MenuItemIDDataListEntry = -6 55 }; 56 57 // Informs the browser that the user has accepted an Autofill suggestion for 58 // a WebNode. A positive |itemID| is a unique id used to identify the set 59 // of Autofill profiles. If it is AutocompleteEntryMenuItemID, then the 60 // suggestion is an Autocomplete suggestion; and |value| stores the 61 // suggested text. |index| is an index of the selected suggestion in the 62 // list of suggestions provided by the client. 63 virtual void didAcceptAutofillSuggestion(const WebNode&, 64 const WebString& value, 65 const WebString& label, 66 int itemID, 67 unsigned index) { } 68 69 // Informs the browser that the user has selected an Autofill suggestion for 70 // a WebNode. This happens when the user hovers over a suggestion or uses 71 // the arrow keys to navigate to a suggestion. 72 virtual void didSelectAutofillSuggestion(const WebNode&, 73 const WebString& name, 74 const WebString& label, 75 int itemID) { } 76 77 // Informs the browser that the user has cleared the selection from the 78 // Autofill suggestions popup. This happens when a user uses the arrow 79 // keys to navigate outside the range of possible selections. 80 virtual void didClearAutofillSelection(const WebNode&) { } 81 82 // Informs the browser an interactive autocomplete has been requested. 83 virtual void didRequestAutocomplete(WebFrame*, const WebFormElement&) { } 84 85 // Instructs the browser to remove the Autocomplete entry specified from 86 // its DB. 87 virtual void removeAutocompleteSuggestion(const WebString& name, 88 const WebString& value) { } 89 90 // These methods are called when the users edits a text-field. 91 virtual void textFieldDidEndEditing(const WebInputElement&) { } 92 virtual void textFieldDidChange(const WebInputElement&) { } 93 virtual void textFieldDidReceiveKeyDown(const WebInputElement&, const WebKeyboardEvent&) { } 94 // This is called when a datalist indicator is clicked. 95 virtual void openTextDataListChooser(const WebInputElement&) { } 96 97 // Informs the client whether or not any subsequent text changes should be ignored. 98 virtual void setIgnoreTextChanges(bool ignore) { } 99 100 virtual void didAssociateFormControls(const WebVector<WebNode>&) { } 101 102 protected: 103 virtual ~WebAutofillClient() { } 104 }; 105 106 } // namespace blink 107 108 #endif 109