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

Side by Side Diff: chrome/browser/instant/instant_controller.h

Issue 11413217: Instant API: tell page whether the browser is capturing key strokes. (Closed) Base URL: http://git.chromium.org/chromium/src.git@focus
Patch Set: Fixed comments, mouse handling logic. Created 8 years 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
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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_INSTANT_INSTANT_CONTROLLER_H_ 5 #ifndef CHROME_BROWSER_INSTANT_INSTANT_CONTROLLER_H_
6 #define CHROME_BROWSER_INSTANT_INSTANT_CONTROLLER_H_ 6 #define CHROME_BROWSER_INSTANT_INSTANT_CONTROLLER_H_
7 7
8 #include <map> 8 #include <map>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after
77 // The preview WebContents. May be NULL. InstantController retains ownership. 77 // The preview WebContents. May be NULL. InstantController retains ownership.
78 content::WebContents* GetPreviewContents() const; 78 content::WebContents* GetPreviewContents() const;
79 79
80 // Returns true if the Instant preview can be committed now. 80 // Returns true if the Instant preview can be committed now.
81 bool IsCurrent() const; 81 bool IsCurrent() const;
82 82
83 // If the preview is showing search results, commits the preview, calling 83 // If the preview is showing search results, commits the preview, calling
84 // CommitInstant() on the browser, and returns true. Else, returns false. 84 // CommitInstant() on the browser, and returns true. Else, returns false.
85 bool CommitIfCurrent(InstantCommitType type); 85 bool CommitIfCurrent(InstantCommitType type);
86 86
87 // The omnibox has lost focus. Commit or discard the preview accordingly. 87 // Called to indicate that the omnibox focus state changed with the given
88 void OmniboxLostFocus(gfx::NativeView view_gaining_focus); 88 // |reason|. If |focus_state| is FOCUS_NONE, |view_gaining_focus| is set to
89 89 // the view gaining focus.
90 // The omnibox has gained focus. Preload the default search engine, in 90 void OmniboxFocusChanged(OmniboxFocusState focus_state,
91 // anticipation of the user typing a query. 91 OmniboxFocusChangeReason reason,
92 void OmniboxGotFocus(); 92 gfx::NativeView view_gaining_focus);
93 93
94 // The search mode in the active tab has changed. Pass the message down to 94 // The search mode in the active tab has changed. Pass the message down to
95 // the loader which will notify the renderer. Create |instant_tab_| if the 95 // the loader which will notify the renderer. Create |instant_tab_| if the
96 // |new_mode| reflects an Instant search results page. 96 // |new_mode| reflects an Instant search results page.
97 void SearchModeChanged(const chrome::search::Mode& old_mode, 97 void SearchModeChanged(const chrome::search::Mode& old_mode,
98 const chrome::search::Mode& new_mode); 98 const chrome::search::Mode& new_mode);
99 99
100 // The user switched tabs. Hide the preview. Create |instant_tab_| if the 100 // The user switched tabs. Hide the preview. Create |instant_tab_| if the
101 // newly active tab is an Instant search results page. 101 // newly active tab is an Instant search results page.
102 void ActiveTabChanged(); 102 void ActiveTabChanged();
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
140 140
141 // Invoked by InstantLoader when the preview gains focus, usually due to the 141 // Invoked by InstantLoader when the preview gains focus, usually due to the
142 // user clicking on it. 142 // user clicking on it.
143 void InstantLoaderContentsFocused(); 143 void InstantLoaderContentsFocused();
144 144
145 private: 145 private:
146 FRIEND_TEST_ALL_PREFIXES(InstantTest, OmniboxFocusLoadsInstant); 146 FRIEND_TEST_ALL_PREFIXES(InstantTest, OmniboxFocusLoadsInstant);
147 FRIEND_TEST_ALL_PREFIXES(InstantTest, NonInstantSearchProvider); 147 FRIEND_TEST_ALL_PREFIXES(InstantTest, NonInstantSearchProvider);
148 FRIEND_TEST_ALL_PREFIXES(InstantTest, InstantLoaderRefresh); 148 FRIEND_TEST_ALL_PREFIXES(InstantTest, InstantLoaderRefresh);
149 149
150 // Helper for OmniboxFocusChanged. Commit or discard the preview.
151 void OmniboxLostFocus(gfx::NativeView view_gaining_focus);
152
150 // Creates a new loader if necessary, using the instant_url property of the 153 // Creates a new loader if necessary, using the instant_url property of the
151 // |template_url| (for example, if the Instant URL has changed since the last 154 // |template_url| (for example, if the Instant URL has changed since the last
152 // time the loader was created). Returns false if the |template_url| doesn't 155 // time the loader was created). Returns false if the |template_url| doesn't
153 // have a valid Instant URL; true otherwise. 156 // have a valid Instant URL; true otherwise.
154 bool ResetLoader(const TemplateURL* template_url, 157 bool ResetLoader(const TemplateURL* template_url,
155 const content::WebContents* active_tab); 158 const content::WebContents* active_tab);
156 159
157 // Ensures that the |loader_| uses the default Instant URL, recreating it if 160 // Ensures that the |loader_| uses the default Instant URL, recreating it if
158 // necessary, and returns true. Returns false if the Instant URL could not be 161 // necessary, and returns true. Returns false if the Instant URL could not be
159 // determined or the active tab is NULL (browser is shutting down). 162 // determined or the active tab is NULL (browser is shutting down).
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
230 // the user has typed. 233 // the user has typed.
231 InstantSuggestion last_suggestion_; 234 InstantSuggestion last_suggestion_;
232 235
233 // See comments on the getter above. 236 // See comments on the getter above.
234 content::PageTransition last_transition_type_; 237 content::PageTransition last_transition_type_;
235 238
236 // True if the last match passed to Update() was a search (versus a URL). 239 // True if the last match passed to Update() was a search (versus a URL).
237 // Used to ensure that the preview page is committable. 240 // Used to ensure that the preview page is committable.
238 bool last_match_was_search_; 241 bool last_match_was_search_;
239 242
240 // True if the omnibox is focused, false otherwise. 243 // Omnibox focus state.
241 bool is_omnibox_focused_; 244 OmniboxFocusState omnibox_focus_state_;
242 245
243 // The search model mode for the active tab. 246 // The search model mode for the active tab.
244 chrome::search::Mode search_mode_; 247 chrome::search::Mode search_mode_;
245 248
246 // Current omnibox bounds. 249 // Current omnibox bounds.
247 gfx::Rect omnibox_bounds_; 250 gfx::Rect omnibox_bounds_;
248 251
249 // Last bounds passed to the page. 252 // Last bounds passed to the page.
250 gfx::Rect last_omnibox_bounds_; 253 gfx::Rect last_omnibox_bounds_;
251 254
(...skipping 23 matching lines...) Expand all
275 278
276 // Whether to allow the preview to show search suggestions. In general, the 279 // Whether to allow the preview to show search suggestions. In general, the
277 // preview is allowed to show search suggestions whenever |search_mode_| is 280 // preview is allowed to show search suggestions whenever |search_mode_| is
278 // MODE_SEARCH_SUGGESTIONS, except in those cases where this is false. 281 // MODE_SEARCH_SUGGESTIONS, except in those cases where this is false.
279 bool allow_preview_to_show_search_suggestions_; 282 bool allow_preview_to_show_search_suggestions_;
280 283
281 DISALLOW_COPY_AND_ASSIGN(InstantController); 284 DISALLOW_COPY_AND_ASSIGN(InstantController);
282 }; 285 };
283 286
284 #endif // CHROME_BROWSER_INSTANT_INSTANT_CONTROLLER_H_ 287 #endif // CHROME_BROWSER_INSTANT_INSTANT_CONTROLLER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698