Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(399)

Side by Side Diff: chrome/browser/autocomplete/autocomplete_popup_model.h

Issue 6731036: Enabled pressing TAB to cycle through the Omnibox results. (Closed) Base URL: http://src.chromium.org/svn/trunk/src/
Patch Set: '' Created 8 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_ 5 #ifndef CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_
6 #define CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_ 6 #define CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_
7 #pragma once 7 #pragma once
8 8
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "chrome/browser/autocomplete/autocomplete.h" 10 #include "chrome/browser/autocomplete/autocomplete.h"
11 #include "chrome/browser/autocomplete/autocomplete_edit.h" 11 #include "chrome/browser/autocomplete/autocomplete_edit.h"
12 12
13 class AutocompletePopupView; 13 class AutocompletePopupView;
14 class SkBitmap; 14 class SkBitmap;
15 15
16 class AutocompletePopupModel { 16 class AutocompletePopupModel {
17 public: 17 public:
18 // See selected_line_state_ for details.
19 enum LineState {
20 NORMAL = 0,
21 KEYWORD
22 };
23
18 AutocompletePopupModel(AutocompletePopupView* popup_view, 24 AutocompletePopupModel(AutocompletePopupView* popup_view,
19 AutocompleteEditModel* edit_model); 25 AutocompleteEditModel* edit_model);
20 ~AutocompletePopupModel(); 26 ~AutocompletePopupModel();
21 27
22 // Returns true if the popup is currently open. 28 // Returns true if the popup is currently open.
23 bool IsOpen() const; 29 bool IsOpen() const;
24 30
25 AutocompletePopupView* view() const { return view_; } 31 AutocompletePopupView* view() const { return view_; }
26 32
27 // Returns the AutocompleteController used by this popup. 33 // Returns the AutocompleteController used by this popup.
(...skipping 10 matching lines...) Expand all
38 } 44 }
39 45
40 // Call to change the hovered line. |line| should be within the range of 46 // Call to change the hovered line. |line| should be within the range of
41 // valid lines (to enable hover) or kNoMatch (to disable hover). 47 // valid lines (to enable hover) or kNoMatch (to disable hover).
42 void SetHoveredLine(size_t line); 48 void SetHoveredLine(size_t line);
43 49
44 size_t selected_line() const { 50 size_t selected_line() const {
45 return selected_line_; 51 return selected_line_;
46 } 52 }
47 53
54 LineState selected_line_state() const {
55 return selected_line_state_;
56 }
57
48 // Call to change the selected line. This will update all state and repaint 58 // Call to change the selected line. This will update all state and repaint
49 // the necessary parts of the window, as well as updating the edit with the 59 // the necessary parts of the window, as well as updating the edit with the
50 // new temporary text. |line| will be clamped to the range of valid lines. 60 // new temporary text. |line| will be clamped to the range of valid lines.
51 // |reset_to_default| is true when the selection is being reset back to the 61 // |reset_to_default| is true when the selection is being reset back to the
52 // default match, and thus there is no temporary text (and no 62 // default match, and thus there is no temporary text (and no
53 // |manually_selected_match_|). If |force| is true then the selected line will 63 // |manually_selected_match_|). If |force| is true then the selected line will
54 // be updated forcibly even if the |line| is same as the current selected 64 // be updated forcibly even if the |line| is same as the current selected
55 // line. 65 // line.
56 // NOTE: This assumes the popup is open, and thus both old and new values for 66 // NOTE: This assumes the popup is open, and thus both old and new values for
57 // the selected line should not be kNoMatch. 67 // the selected line should not be kNoMatch.
58 void SetSelectedLine(size_t line, bool reset_to_default, bool force); 68 void SetSelectedLine(size_t line, bool reset_to_default, bool force);
59 69
60 // Called when the user hits escape after arrowing around the popup. This 70 // Called when the user hits escape after arrowing around the popup. This
61 // will change the selected line back to the default match and redraw. 71 // will change the selected line back to the default match and redraw.
62 void ResetToDefaultMatch(); 72 void ResetToDefaultMatch();
63 73
64 // Gets the selected keyword or keyword hint for the given match. If the match
65 // is already keyword, then the keyword will be returned directly. Otherwise,
66 // it returns GetKeywordForText(match.fill_into_edit, keyword).
67 bool GetKeywordForMatch(const AutocompleteMatch& match,
68 string16* keyword) const;
69
70 // Gets the selected keyword or keyword hint for the given text. Returns
71 // true if |keyword| represents a keyword hint, or false if |keyword|
72 // represents a selected keyword. (|keyword| will always be set [though
73 // possibly to the empty string], and you cannot have both a selected keyword
74 // and a keyword hint simultaneously.)
75 bool GetKeywordForText(const string16& text, string16* keyword) const;
76
77 // Immediately updates and opens the popup if necessary, then moves the 74 // Immediately updates and opens the popup if necessary, then moves the
78 // current selection down (|count| > 0) or up (|count| < 0), clamping to the 75 // current selection down (|count| > 0) or up (|count| < 0), clamping to the
79 // first or last result if necessary. If |count| == 0, the selection will be 76 // first or last result if necessary. If |count| == 0, the selection will be
80 // unchanged, but the popup will still redraw and modify the text in the 77 // unchanged, but the popup will still redraw and modify the text in the
81 // AutocompleteEditModel. 78 // AutocompleteEditModel.
82 void Move(int count); 79 void Move(int count);
83 80
81 // If the selected line has both a normal match and a keyword match, this can
82 // be used to choose which to select. It is an error to call this when the
83 // selected line does not have both matches (or there is no selection).
84 void SetSelectedLineState(LineState state);
85
84 // Called when the user hits shift-delete. This should determine if the item 86 // Called when the user hits shift-delete. This should determine if the item
85 // can be removed from history, and if so, remove it and update the popup. 87 // can be removed from history, and if so, remove it and update the popup.
86 void TryDeletingCurrentItem(); 88 void TryDeletingCurrentItem();
87 89
88 // If |match| is from an extension, returns the extension icon; otherwise 90 // If |match| is from an extension, returns the extension icon; otherwise
89 // returns NULL. 91 // returns NULL.
90 const SkBitmap* GetIconIfExtensionMatch(const AutocompleteMatch& match) const; 92 const SkBitmap* GetIconIfExtensionMatch(const AutocompleteMatch& match) const;
91 93
92 // The match the user has manually chosen, if any. 94 // The match the user has manually chosen, if any.
93 const AutocompleteResult::Selection& manually_selected_match() const { 95 const AutocompleteResult::Selection& manually_selected_match() const {
(...skipping 14 matching lines...) Expand all
108 AutocompleteEditModel* edit_model_; 110 AutocompleteEditModel* edit_model_;
109 111
110 // The line that's currently hovered. If we're not drawing a hover rect, 112 // The line that's currently hovered. If we're not drawing a hover rect,
111 // this will be kNoMatch, even if the cursor is over the popup contents. 113 // this will be kNoMatch, even if the cursor is over the popup contents.
112 size_t hovered_line_; 114 size_t hovered_line_;
113 115
114 // The currently selected line. This is kNoMatch when nothing is selected, 116 // The currently selected line. This is kNoMatch when nothing is selected,
115 // which should only be true when the popup is closed. 117 // which should only be true when the popup is closed.
116 size_t selected_line_; 118 size_t selected_line_;
117 119
120 // If the selected line has both a normal match and a keyword match, this
121 // determines whether the normal match (if NORMAL) or the keyword match
122 // (if KEYWORD) is selected.
123 LineState selected_line_state_;
124
118 // The match the user has manually chosen, if any. 125 // The match the user has manually chosen, if any.
119 AutocompleteResult::Selection manually_selected_match_; 126 AutocompleteResult::Selection manually_selected_match_;
120 127
121 DISALLOW_COPY_AND_ASSIGN(AutocompletePopupModel); 128 DISALLOW_COPY_AND_ASSIGN(AutocompletePopupModel);
122 }; 129 };
123 130
124 #endif // CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_ 131 #endif // CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698