OLD | NEW |
---|---|
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 | |
Peter Kasting
2011/12/15 22:56:04
Nit: Missing trailing period
| |
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 |
33 AutocompleteEditModel* edit_model() const { return edit_model_; } | |
34 | |
27 // Returns the AutocompleteController used by this popup. | 35 // Returns the AutocompleteController used by this popup. |
28 AutocompleteController* autocomplete_controller() const { | 36 AutocompleteController* autocomplete_controller() const { |
29 return edit_model_->autocomplete_controller(); | 37 return edit_model_->autocomplete_controller(); |
30 } | 38 } |
31 | 39 |
32 const AutocompleteResult& result() const { | 40 const AutocompleteResult& result() const { |
33 return autocomplete_controller()->result(); | 41 return autocomplete_controller()->result(); |
34 } | 42 } |
35 | 43 |
36 size_t hovered_line() const { | 44 size_t hovered_line() const { |
37 return hovered_line_; | 45 return hovered_line_; |
38 } | 46 } |
39 | 47 |
40 // Call to change the hovered line. |line| should be within the range of | 48 // Call to change the hovered line. |line| should be within the range of |
41 // valid lines (to enable hover) or kNoMatch (to disable hover). | 49 // valid lines (to enable hover) or kNoMatch (to disable hover). |
42 void SetHoveredLine(size_t line); | 50 void SetHoveredLine(size_t line); |
43 | 51 |
44 size_t selected_line() const { | 52 size_t selected_line() const { |
45 return selected_line_; | 53 return selected_line_; |
46 } | 54 } |
47 | 55 |
56 LineState selected_line_state() const { | |
57 return selected_line_state_; | |
58 } | |
59 | |
48 // Call to change the selected line. This will update all state and repaint | 60 // 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 | 61 // 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. | 62 // 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 | 63 // |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 | 64 // default match, and thus there is no temporary text (and no |
53 // |manually_selected_match_|). If |force| is true then the selected line will | 65 // |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 | 66 // be updated forcibly even if the |line| is same as the current selected |
55 // line. | 67 // line. |
56 // NOTE: This assumes the popup is open, and thus both old and new values for | 68 // NOTE: This assumes the popup is open, and thus both old and new values for |
57 // the selected line should not be kNoMatch. | 69 // the selected line should not be kNoMatch. |
58 void SetSelectedLine(size_t line, bool reset_to_default, bool force); | 70 void SetSelectedLine(size_t line, bool reset_to_default, bool force); |
59 | 71 |
60 // Called when the user hits escape after arrowing around the popup. This | 72 // 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. | 73 // will change the selected line back to the default match and redraw. |
62 void ResetToDefaultMatch(); | 74 void ResetToDefaultMatch(); |
63 | 75 |
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 | 76 // Immediately updates and opens the popup if necessary, then moves the |
78 // current selection down (|count| > 0) or up (|count| < 0), clamping to the | 77 // 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 | 78 // 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 | 79 // unchanged, but the popup will still redraw and modify the text in the |
81 // AutocompleteEditModel. | 80 // AutocompleteEditModel. |
82 void Move(int count); | 81 void Move(int count); |
83 | 82 |
83 // If the selected line has both a normal match and a keyword match, this can | |
84 // be used to choose which to select. It is an error to call this when the | |
85 // selected line does not have both matches (or there is no selection). | |
86 void SetSelectedLineState(LineState state); | |
87 | |
84 // Called when the user hits shift-delete. This should determine if the item | 88 // 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. | 89 // can be removed from history, and if so, remove it and update the popup. |
86 void TryDeletingCurrentItem(); | 90 void TryDeletingCurrentItem(); |
87 | 91 |
88 // If |match| is from an extension, returns the extension icon; otherwise | 92 // If |match| is from an extension, returns the extension icon; otherwise |
89 // returns NULL. | 93 // returns NULL. |
90 const SkBitmap* GetIconIfExtensionMatch(const AutocompleteMatch& match) const; | 94 const SkBitmap* GetIconIfExtensionMatch(const AutocompleteMatch& match) const; |
91 | 95 |
92 // The match the user has manually chosen, if any. | 96 // The match the user has manually chosen, if any. |
93 const AutocompleteResult::Selection& manually_selected_match() const { | 97 const AutocompleteResult::Selection& manually_selected_match() const { |
(...skipping 14 matching lines...) Expand all Loading... | |
108 AutocompleteEditModel* edit_model_; | 112 AutocompleteEditModel* edit_model_; |
109 | 113 |
110 // The line that's currently hovered. If we're not drawing a hover rect, | 114 // 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. | 115 // this will be kNoMatch, even if the cursor is over the popup contents. |
112 size_t hovered_line_; | 116 size_t hovered_line_; |
113 | 117 |
114 // The currently selected line. This is kNoMatch when nothing is selected, | 118 // The currently selected line. This is kNoMatch when nothing is selected, |
115 // which should only be true when the popup is closed. | 119 // which should only be true when the popup is closed. |
116 size_t selected_line_; | 120 size_t selected_line_; |
117 | 121 |
122 // If the selected line has both a normal match and a keyword match, this | |
123 // determines whether the normal match (if NORMAL) or the keyword match | |
124 // (if KEYWORD) is selected. | |
125 LineState selected_line_state_; | |
126 | |
118 // The match the user has manually chosen, if any. | 127 // The match the user has manually chosen, if any. |
119 AutocompleteResult::Selection manually_selected_match_; | 128 AutocompleteResult::Selection manually_selected_match_; |
120 | 129 |
121 DISALLOW_COPY_AND_ASSIGN(AutocompletePopupModel); | 130 DISALLOW_COPY_AND_ASSIGN(AutocompletePopupModel); |
122 }; | 131 }; |
123 | 132 |
124 #endif // CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_ | 133 #endif // CHROME_BROWSER_AUTOCOMPLETE_AUTOCOMPLETE_POPUP_MODEL_H_ |
OLD | NEW |