summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsamarth@chromium.org <samarth@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-06-14 00:46:26 +0000
committersamarth@chromium.org <samarth@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-06-14 00:46:26 +0000
commit0d0b4a4e77be5bcd40895f814241a1ea233f1a22 (patch)
tree9af16b951ba4b9a9b2cd72c9e1b43c0e61989f57
parent41bb06f20858e038aa9fa02be5de415b757bc113 (diff)
downloadchromium_src-0d0b4a4e77be5bcd40895f814241a1ea233f1a22.zip
chromium_src-0d0b4a4e77be5bcd40895f814241a1ea233f1a22.tar.gz
chromium_src-0d0b4a4e77be5bcd40895f814241a1ea233f1a22.tar.bz2
InstantExtended: notify Instant NTP when user input starts and ends.
BUG=248164 R=jered@chromium.org, palmer@chromium.org Review URL: https://codereview.chromium.org/15951013 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@206255 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/resources/local_ntp/local_ntp.js2
-rw-r--r--chrome/browser/ui/browser_instant_controller.cc8
-rw-r--r--chrome/browser/ui/search/instant_controller.cc15
-rw-r--r--chrome/browser/ui/search/instant_controller.h6
-rw-r--r--chrome/browser/ui/search/instant_page.cc5
-rw-r--r--chrome/browser/ui/search/instant_page.h3
-rw-r--r--chrome/common/render_messages.h3
-rw-r--r--chrome/renderer/resources/extensions/searchbox_api.js4
-rw-r--r--chrome/renderer/searchbox/searchbox.cc27
-rw-r--r--chrome/renderer/searchbox/searchbox.h3
-rw-r--r--chrome/renderer/searchbox/searchbox_extension.cc50
-rw-r--r--chrome/renderer/searchbox/searchbox_extension.h2
12 files changed, 122 insertions, 6 deletions
diff --git a/chrome/browser/resources/local_ntp/local_ntp.js b/chrome/browser/resources/local_ntp/local_ntp.js
index d1ddebe..cd7c7bb 100644
--- a/chrome/browser/resources/local_ntp/local_ntp.js
+++ b/chrome/browser/resources/local_ntp/local_ntp.js
@@ -203,7 +203,7 @@ var ntpApiHandle;
* The state of the NTP when a query is entered into the Omnibox.
* @type {NTP_DISPOSE_STATE}
*/
-var omniboxInputBehavior = NTP_DISPOSE_STATE.HIDE_FAKEBOX_AND_LOGO;
+var omniboxInputBehavior = NTP_DISPOSE_STATE.NONE;
/**
diff --git a/chrome/browser/ui/browser_instant_controller.cc b/chrome/browser/ui/browser_instant_controller.cc
index cacd42f..008753e 100644
--- a/chrome/browser/ui/browser_instant_controller.cc
+++ b/chrome/browser/ui/browser_instant_controller.cc
@@ -211,6 +211,14 @@ void BrowserInstantController::FocusOmnibox(bool caret_visibility) {
GetLocationEntry();
omnibox_view->SetFocus();
omnibox_view->model()->SetCaretVisibility(caret_visibility);
+ if (!caret_visibility) {
+ // If the user clicked on the fakebox, any text already in the omnibox
+ // should get cleared when they start typing. Selecting all the existing
+ // text is a convenient way to accomplish this. It also gives a slight
+ // visual cue to users who really understand selection state about what will
+ // happen if they start typing.
+ omnibox_view->SelectAll(false);
+ }
}
content::WebContents* BrowserInstantController::GetActiveWebContents() const {
diff --git a/chrome/browser/ui/search/instant_controller.cc b/chrome/browser/ui/search/instant_controller.cc
index 9a3e084..f4ba1a4 100644
--- a/chrome/browser/ui/search/instant_controller.cc
+++ b/chrome/browser/ui/search/instant_controller.cc
@@ -976,8 +976,11 @@ void InstantController::OmniboxFocusChanged(
if (extended_enabled()) {
if (overlay_)
overlay_->FocusChanged(omnibox_focus_state_, reason);
- if (instant_tab_)
+
+ if (instant_tab_) {
instant_tab_->FocusChanged(omnibox_focus_state_, reason);
+ instant_tab_->SetInputInProgress(IsInputInProgress());
+ }
}
if (state == OMNIBOX_FOCUS_VISIBLE && old_focus_state == OMNIBOX_FOCUS_NONE) {
@@ -1008,6 +1011,10 @@ void InstantController::SearchModeChanged(const SearchMode& old_mode,
HideOverlay();
ResetInstantTab();
+
+ if (instant_tab_ &&
+ old_mode.is_search_suggestions() != new_mode.is_search_suggestions())
+ instant_tab_->SetInputInProgress(IsInputInProgress());
}
void InstantController::ActiveTabChanged() {
@@ -1655,9 +1662,15 @@ void InstantController::UpdateInfoForInstantTab() {
UpdateMostVisitedItems();
instant_tab_->FocusChanged(omnibox_focus_state_,
omnibox_focus_change_reason_);
+ instant_tab_->SetInputInProgress(IsInputInProgress());
}
}
+bool InstantController::IsInputInProgress() const {
+ return search_mode_.is_search_suggestions() &&
+ omnibox_focus_state_ == OMNIBOX_FOCUS_VISIBLE;
+}
+
void InstantController::HideOverlay() {
HideInternal();
ReloadOverlayIfStale();
diff --git a/chrome/browser/ui/search/instant_controller.h b/chrome/browser/ui/search/instant_controller.h
index fe4cd93..cdb170b 100644
--- a/chrome/browser/ui/search/instant_controller.h
+++ b/chrome/browser/ui/search/instant_controller.h
@@ -402,6 +402,10 @@ class InstantController : public InstantPage::Delegate {
// Sends theme info, omnibox bounds, font info, etc. down to the Instant tab.
void UpdateInfoForInstantTab();
+ // Returns whether input is in progress, i.e. if the omnibox has focus and the
+ // active tab is in mode SEARCH_SUGGESTIONS.
+ bool IsInputInProgress() const;
+
// Hide the overlay. Also sends an onchange event (with blank query) to the
// overlay, telling it to clear out results for any old queries.
void HideOverlay();
@@ -417,8 +421,6 @@ class InstantController : public InstantPage::Delegate {
// Send the omnibox popup bounds to the page.
void SendPopupBoundsToPage();
-
-
// If possible, tries to mutate |suggestion| to a valid suggestion. Returns
// true if successful. (Note that |suggestion| may be modified even if this
// returns false.)
diff --git a/chrome/browser/ui/search/instant_page.cc b/chrome/browser/ui/search/instant_page.cc
index 3fe82ba..8568d2e 100644
--- a/chrome/browser/ui/search/instant_page.cc
+++ b/chrome/browser/ui/search/instant_page.cc
@@ -117,6 +117,11 @@ void InstantPage::FocusChanged(OmniboxFocusState state,
Send(new ChromeViewMsg_SearchBoxFocusChanged(routing_id(), state, reason));
}
+void InstantPage::SetInputInProgress(bool input_in_progress) {
+ Send(new ChromeViewMsg_SearchBoxSetInputInProgress(
+ routing_id(), input_in_progress));
+}
+
void InstantPage::SendMostVisitedItems(
const std::vector<InstantMostVisitedItem>& items) {
Send(new ChromeViewMsg_SearchBoxMostVisitedItemsChanged(routing_id(), items));
diff --git a/chrome/browser/ui/search/instant_page.h b/chrome/browser/ui/search/instant_page.h
index 53a3243..5bb3045 100644
--- a/chrome/browser/ui/search/instant_page.h
+++ b/chrome/browser/ui/search/instant_page.h
@@ -191,6 +191,9 @@ class InstantPage : public content::WebContentsObserver {
// Tells the page that the omnibox focus has changed.
void FocusChanged(OmniboxFocusState state, OmniboxFocusChangeReason reason);
+ // Tells the page that user input started or stopped.
+ void SetInputInProgress(bool input_in_progress);
+
// Tells the page about new Most Visited data.
void SendMostVisitedItems(
const std::vector<InstantMostVisitedItem>& items);
diff --git a/chrome/common/render_messages.h b/chrome/common/render_messages.h
index a5bbb06..bb29864 100644
--- a/chrome/common/render_messages.h
+++ b/chrome/common/render_messages.h
@@ -368,6 +368,9 @@ IPC_MESSAGE_ROUTED2(ChromeViewMsg_SearchBoxFocusChanged,
OmniboxFocusState /* new_focus_state */,
OmniboxFocusChangeReason /* reason */)
+IPC_MESSAGE_ROUTED1(ChromeViewMsg_SearchBoxSetInputInProgress,
+ bool /* input_in_progress */)
+
IPC_MESSAGE_ROUTED1(ChromeViewMsg_SearchBoxMostVisitedItemsChanged,
std::vector<InstantMostVisitedItem> /* items */)
diff --git a/chrome/renderer/resources/extensions/searchbox_api.js b/chrome/renderer/resources/extensions/searchbox_api.js
index c17ae98..8a21d03 100644
--- a/chrome/renderer/resources/extensions/searchbox_api.js
+++ b/chrome/renderer/resources/extensions/searchbox_api.js
@@ -253,6 +253,7 @@ if (!chrome.embeddedSearch) {
native function UndoAllMostVisitedDeletions();
native function UndoMostVisitedDeletion();
native function NavigateNewTabPage();
+ native function IsInputInProgress();
function GetMostVisitedItemsWrapper() {
var mostVisitedItems = GetMostVisitedItems();
@@ -272,6 +273,7 @@ if (!chrome.embeddedSearch) {
// =======================================================================
this.__defineGetter__('mostVisited', GetMostVisitedItemsWrapper);
this.__defineGetter__('themeBackgroundInfo', GetThemeBackgroundInfo);
+ this.__defineGetter__('isInputInProgress', IsInputInProgress);
this.deleteMostVisitedItem = function(restrictedId) {
DeleteMostVisitedItem(restrictedId);
@@ -288,6 +290,8 @@ if (!chrome.embeddedSearch) {
this.onmostvisitedchange = null;
this.onthemechange = null;
+ this.oninputstart = null;
+ this.oninputcancel = null;
};
// Export legacy searchbox API.
diff --git a/chrome/renderer/searchbox/searchbox.cc b/chrome/renderer/searchbox/searchbox.cc
index 0416889..a33edfb 100644
--- a/chrome/renderer/searchbox/searchbox.cc
+++ b/chrome/renderer/searchbox/searchbox.cc
@@ -70,6 +70,7 @@ SearchBox::SearchBox(content::RenderView* render_view)
start_margin_(0),
is_focused_(false),
is_key_capture_enabled_(false),
+ is_input_in_progress_(false),
display_instant_results_(false),
omnibox_font_size_(0),
autocomplete_results_cache_(kMaxInstantAutocompleteResultItemCacheSize),
@@ -242,6 +243,8 @@ bool SearchBox::OnMessageReceived(const IPC::Message& message) {
IPC_MESSAGE_HANDLER(ChromeViewMsg_SearchBoxSetDisplayInstantResults,
OnSetDisplayInstantResults)
IPC_MESSAGE_HANDLER(ChromeViewMsg_SearchBoxFocusChanged, OnFocusChanged)
+ IPC_MESSAGE_HANDLER(ChromeViewMsg_SearchBoxSetInputInProgress,
+ OnSetInputInProgress)
IPC_MESSAGE_HANDLER(ChromeViewMsg_SearchBoxThemeChanged,
OnThemeChanged)
IPC_MESSAGE_HANDLER(ChromeViewMsg_SearchBoxFontInformation,
@@ -415,8 +418,28 @@ void SearchBox::OnFocusChanged(OmniboxFocusState new_focus_state,
if (is_focused != is_focused_) {
is_focused_ = is_focused;
DVLOG(1) << render_view() << " OnFocusChange";
- extensions_v8::SearchBoxExtension::DispatchFocusChange(
- render_view()->GetWebView()->mainFrame());
+ if (render_view()->GetWebView() &&
+ render_view()->GetWebView()->mainFrame()) {
+ extensions_v8::SearchBoxExtension::DispatchFocusChange(
+ render_view()->GetWebView()->mainFrame());
+ }
+ }
+}
+
+void SearchBox::OnSetInputInProgress(bool is_input_in_progress) {
+ if (is_input_in_progress_ != is_input_in_progress) {
+ is_input_in_progress_ = is_input_in_progress;
+ DVLOG(1) << render_view() << " OnSetInputInProgress";
+ if (render_view()->GetWebView() &&
+ render_view()->GetWebView()->mainFrame()) {
+ if (is_input_in_progress_) {
+ extensions_v8::SearchBoxExtension::DispatchInputStart(
+ render_view()->GetWebView()->mainFrame());
+ } else {
+ extensions_v8::SearchBoxExtension::DispatchInputCancel(
+ render_view()->GetWebView()->mainFrame());
+ }
+ }
}
}
diff --git a/chrome/renderer/searchbox/searchbox.h b/chrome/renderer/searchbox/searchbox.h
index e1383e8..0a45a05 100644
--- a/chrome/renderer/searchbox/searchbox.h
+++ b/chrome/renderer/searchbox/searchbox.h
@@ -69,6 +69,7 @@ class SearchBox : public content::RenderViewObserver,
size_t selection_end() const { return selection_end_; }
bool is_focused() const { return is_focused_; }
bool is_key_capture_enabled() const { return is_key_capture_enabled_; }
+ bool is_input_in_progress() const { return is_input_in_progress_; }
bool display_instant_results() const { return display_instant_results_; }
const string16& omnibox_font() const { return omnibox_font_; }
size_t omnibox_font_size() const { return omnibox_font_size_; }
@@ -158,6 +159,7 @@ class SearchBox : public content::RenderViewObserver,
size_t selection_end);
void OnFocusChanged(OmniboxFocusState new_focus_state,
OmniboxFocusChangeReason reason);
+ void OnSetInputInProgress(bool input_in_progress);
void OnSetDisplayInstantResults(bool display_instant_results);
void OnThemeChanged(const ThemeBackgroundInfo& theme_info);
void OnThemeAreaHeightChanged(int height);
@@ -188,6 +190,7 @@ class SearchBox : public content::RenderViewObserver,
gfx::Rect popup_bounds_;
bool is_focused_;
bool is_key_capture_enabled_;
+ bool is_input_in_progress_;
ThemeBackgroundInfo theme_info_;
bool display_instant_results_;
string16 omnibox_font_;
diff --git a/chrome/renderer/searchbox/searchbox_extension.cc b/chrome/renderer/searchbox/searchbox_extension.cc
index 5458a35..4a73002 100644
--- a/chrome/renderer/searchbox/searchbox_extension.cc
+++ b/chrome/renderer/searchbox/searchbox_extension.cc
@@ -458,6 +458,28 @@ static const char kDispatchFocusChangedScript[] =
" true;"
"}";
+static const char kDispatchInputStartScript[] =
+ "if (window.chrome &&"
+ " window.chrome.embeddedSearch &&"
+ " window.chrome.embeddedSearch.newTabPage &&"
+ " window.chrome.embeddedSearch.newTabPage.oninputstart &&"
+ " typeof window.chrome.embeddedSearch.newTabPage.oninputstart =="
+ " 'function') {"
+ " window.chrome.embeddedSearch.newTabPage.oninputstart();"
+ " true;"
+ "}";
+
+static const char kDispatchInputCancelScript[] =
+ "if (window.chrome &&"
+ " window.chrome.embeddedSearch &&"
+ " window.chrome.embeddedSearch.newTabPage &&"
+ " window.chrome.embeddedSearch.newTabPage.oninputcancel &&"
+ " typeof window.chrome.embeddedSearch.newTabPage.oninputcancel =="
+ " 'function') {"
+ " window.chrome.embeddedSearch.newTabPage.oninputcancel();"
+ " true;"
+ "}";
+
static const char kDispatchToggleVoiceSearchScript[] =
"if (window.chrome &&"
" window.chrome.embeddedSearch &&"
@@ -624,6 +646,10 @@ class SearchBoxExtensionWrapper : public v8::Extension {
// Gets whether the omnibox has focus or not.
static void IsFocused(const v8::FunctionCallbackInfo<v8::Value>& args);
+ // Gets whether user input is in progress.
+ static void IsInputInProgress(
+ const v8::FunctionCallbackInfo<v8::Value>& args);
+
private:
DISALLOW_COPY_AND_ASSIGN(SearchBoxExtensionWrapper);
};
@@ -709,6 +735,8 @@ v8::Handle<v8::FunctionTemplate> SearchBoxExtensionWrapper::GetNativeFunction(
return v8::FunctionTemplate::New(GetMostVisitedItemData);
if (name->Equals(v8::String::New("IsFocused")))
return v8::FunctionTemplate::New(IsFocused);
+ if (name->Equals(v8::String::New("IsInputInProgress")))
+ return v8::FunctionTemplate::New(IsInputInProgress);
return v8::Handle<v8::FunctionTemplate>();
}
@@ -1425,6 +1453,18 @@ void SearchBoxExtensionWrapper::IsFocused(
}
// static
+void SearchBoxExtensionWrapper::IsInputInProgress(
+ const v8::FunctionCallbackInfo<v8::Value>& args) {
+ content::RenderView* render_view = GetRenderView();
+ if (!render_view) return;
+
+ bool is_input_in_progress =
+ SearchBox::Get(render_view)->is_input_in_progress();
+ DVLOG(1) << render_view << " IsInputInProgress: " << is_input_in_progress;
+ args.GetReturnValue().Set(is_input_in_progress);
+}
+
+// static
void SearchBoxExtension::DispatchChange(WebKit::WebFrame* frame) {
Dispatch(frame, kDispatchChangeEventScript);
}
@@ -1495,6 +1535,16 @@ void SearchBoxExtension::DispatchFocusChange(WebKit::WebFrame* frame) {
}
// static
+void SearchBoxExtension::DispatchInputStart(WebKit::WebFrame* frame) {
+ Dispatch(frame, kDispatchInputStartScript);
+}
+
+// static
+void SearchBoxExtension::DispatchInputCancel(WebKit::WebFrame* frame) {
+ Dispatch(frame, kDispatchInputCancelScript);
+}
+
+// static
void SearchBoxExtension::DispatchToggleVoiceSearch(
WebKit::WebFrame* frame) {
Dispatch(frame, kDispatchToggleVoiceSearchScript);
diff --git a/chrome/renderer/searchbox/searchbox_extension.h b/chrome/renderer/searchbox/searchbox_extension.h
index 45adc92..c58ea77 100644
--- a/chrome/renderer/searchbox/searchbox_extension.h
+++ b/chrome/renderer/searchbox/searchbox_extension.h
@@ -41,6 +41,8 @@ class SearchBoxExtension {
static void DispatchThemeChange(WebKit::WebFrame* frame);
static void DispatchBarsHidden(WebKit::WebFrame* frame);
static void DispatchFocusChange(WebKit::WebFrame* frame);
+ static void DispatchInputStart(WebKit::WebFrame* frame);
+ static void DispatchInputCancel(WebKit::WebFrame* frame);
static void DispatchToggleVoiceSearch(WebKit::WebFrame* frame);
// New Tab Page API.