Index: components/search_engines/desktop_search_infobar_delegate_win.cc |
diff --git a/components/search_engines/desktop_search_infobar_delegate_win.cc b/components/search_engines/desktop_search_infobar_delegate_win.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..48e3ceb0f70daf9535fc74114dab2b730a6ab1d3 |
--- /dev/null |
+++ b/components/search_engines/desktop_search_infobar_delegate_win.cc |
@@ -0,0 +1,109 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "components/search_engines/desktop_search_infobar_delegate_win.h" |
+ |
+#include <vector> |
+ |
+#include "base/logging.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "base/metrics/histogram_macros.h" |
+#include "base/metrics/user_metrics.h" |
+#include "base/prefs/pref_service.h" |
+#include "components/infobars/core/infobar.h" |
+#include "components/infobars/core/infobar_delegate.h" |
+#include "components/infobars/core/infobar_manager.h" |
+#include "components/search_engines/desktop_search_utils_win.h" |
+#include "grit/components_strings.h" |
+#include "ui/base/l10n/l10n_util.h" |
+#include "ui/base/window_open_disposition.h" |
+ |
+namespace { |
+ |
+// Values for the Search.WindowsDesktopSearch.InfobarAction histogram. |
+enum WindowsDesktopSearchInfobarAction { |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_MANAGE_SEARCH_SETTINGS = 0, |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_DISMISS = 1, |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_IGNORE = 2, |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_MAX |
+}; |
+ |
+void RecordWindowsDesktopSearchInfobarActionHistogram( |
+ WindowsDesktopSearchInfobarAction action) { |
+ DCHECK_LT(action, WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_MAX); |
+ UMA_HISTOGRAM_ENUMERATION("Search.WindowsDesktopSearch.InfobarAction", action, |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_MAX); |
+} |
+ |
+} // namespace |
+ |
+void WindowsDesktopSearchInfobarDelegate::Show( |
+ infobars::InfoBarManager* infobar_manager, |
+ const base::string16& default_search_engine_name, |
+ const GURL& search_settings_url, |
+ PrefService* pref_service) { |
+ DCHECK(infobar_manager); |
+ infobar_manager->AddInfoBar( |
+ infobar_manager->CreateConfirmInfoBar(scoped_ptr<ConfirmInfoBarDelegate>( |
+ new WindowsDesktopSearchInfobarDelegate(default_search_engine_name, |
+ search_settings_url)))); |
+ pref_service->SetBoolean( |
+ prefs::kWindowsDesktopSearchRedirectionInfobarShownPref, true); |
Peter Kasting
2016/01/20 03:03:01
What if the user navigates quickly and never reall
fdoray
2016/01/21 21:02:33
ainslie@: What do you think? Should we show the in
|
+} |
+ |
+WindowsDesktopSearchInfobarDelegate::WindowsDesktopSearchInfobarDelegate( |
+ const base::string16& default_search_engine_name, |
+ const GURL& search_settings_url) |
+ : default_search_engine_name_(default_search_engine_name), |
+ search_settings_url_(search_settings_url), |
+ closed_by_user_(false) {} |
+ |
+WindowsDesktopSearchInfobarDelegate::~WindowsDesktopSearchInfobarDelegate() { |
+ if (!closed_by_user_) { |
+ base::RecordAction(base::UserMetricsAction( |
+ "WindowsDesktopSearchRedirectionInfoBar_Ignore")); |
+ RecordWindowsDesktopSearchInfobarActionHistogram( |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_IGNORE); |
+ } |
+} |
+ |
+base::string16 WindowsDesktopSearchInfobarDelegate::GetMessageText() const { |
+ return l10n_util::GetStringFUTF16( |
+ IDS_WINDOWS_DESKTOP_SEARCH_REDIRECTION_INFOBAR_MESSAGE, |
+ std::vector<base::string16>(1, default_search_engine_name_), nullptr); |
Peter Kasting
2016/01/20 03:03:01
Why not just call
return l10n_util::GetStringFU
fdoray
2016/01/21 21:02:33
Done.
|
+} |
+ |
+int WindowsDesktopSearchInfobarDelegate::GetButtons() const { |
+ return BUTTON_OK; |
+} |
+ |
+base::string16 WindowsDesktopSearchInfobarDelegate::GetButtonLabel( |
+ InfoBarButton button) const { |
+ return l10n_util::GetStringUTF16( |
+ IDS_WINDOWS_DESKTOP_SEARCH_REDIRECTION_INFOBAR_BUTTON); |
+} |
+ |
+bool WindowsDesktopSearchInfobarDelegate::Accept() { |
+ base::RecordAction(base::UserMetricsAction( |
+ "WindowsDesktopSearchRedirectionInfoBar_ManageSearchSettings")); |
+ RecordWindowsDesktopSearchInfobarActionHistogram( |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_MANAGE_SEARCH_SETTINGS); |
+ infobar()->owner()->OpenURL(search_settings_url_, NEW_FOREGROUND_TAB); |
Peter Kasting
2016/01/20 03:03:01
If we already have a settings page open, will this
fdoray
2016/01/21 21:02:33
Done.
|
+ |
+ // Do not close the infobar. |
Peter Kasting
2016/01/20 03:03:01
Why?
Also, doesn't this mean we'll always record
fdoray
2016/01/21 21:02:33
Done. Once the user has interacted with the infoba
|
+ return false; |
+} |
+ |
+infobars::InfoBarDelegate::InfoBarIdentifier |
+WindowsDesktopSearchInfobarDelegate::GetIdentifier() const { |
+ return WINDOWS_DESKTOP_SEARCH_INFOBAR_DELEGATE; |
+} |
+ |
+void WindowsDesktopSearchInfobarDelegate::InfoBarDismissed() { |
+ base::RecordAction(base::UserMetricsAction( |
+ "WindowsDesktopSearchRedirectionInfoBar_Dismiss")); |
+ RecordWindowsDesktopSearchInfobarActionHistogram( |
+ WINDOWS_DESKTOP_SEARCH_INFOBAR_ACTION_DISMISS); |
+ closed_by_user_ = true; |
+} |