Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 #include "chrome/browser/ui/webui/ntp/new_tab_page_handler.h" | 5 #include "chrome/browser/ui/webui/ntp/new_tab_page_handler.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/metrics/field_trial.h" | 10 #include "base/metrics/field_trial.h" |
| 11 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
| 12 #include "chrome/browser/browser_process.h" | 12 #include "chrome/browser/browser_process.h" |
| 13 #include "chrome/browser/extensions/default_apps_trial.h" | 13 #include "chrome/browser/extensions/default_apps_trial.h" |
| 14 #include "chrome/browser/prefs/pref_service.h" | 14 #include "chrome/browser/prefs/pref_service.h" |
| 15 #include "chrome/browser/profiles/profile.h" | 15 #include "chrome/browser/profiles/profile.h" |
| 16 #include "chrome/browser/sync/profile_sync_service.h" | 16 #include "chrome/browser/sync/profile_sync_service.h" |
| 17 #include "chrome/browser/ui/webui/ntp/new_tab_ui.h" | 17 #include "chrome/browser/ui/webui/ntp/new_tab_ui.h" |
| 18 #include "chrome/browser/web_resource/notification_promo.h" | 18 #include "chrome/browser/web_resource/notification_promo.h" |
| 19 #include "chrome/common/pref_names.h" | 19 #include "chrome/common/pref_names.h" |
| 20 #include "content/public/browser/notification_service.h" | 20 #include "content/public/browser/notification_service.h" |
| 21 #include "content/public/browser/web_ui.h" | 21 #include "content/public/browser/web_ui.h" |
| 22 #include "grit/chromium_strings.h" | 22 #include "grit/chromium_strings.h" |
| 23 #include "grit/generated_resources.h" | 23 #include "grit/generated_resources.h" |
| 24 #include "ui/base/l10n/l10n_util.h" | 24 #include "ui/base/l10n/l10n_util.h" |
| 25 | 25 |
| 26 static const char kDefaultPageTypeHistogram[] = | 26 namespace { |
| 27 "NewTabPage.DefaultPageType"; | 27 |
| 28 const char kDefaultPageTypeHistogram[] = "NewTabPage.DefaultPageType"; | |
| 29 | |
| 30 enum PromoAction { | |
| 31 PROMO_CLOSED, | |
| 32 PROMO_VIEWED, | |
|
Dan Beam
2012/10/20 00:50:19
nit: you probably want PROMO_VIEWED first in the h
achuithb
2012/10/20 18:30:42
Good suggestion! Done.
| |
| 33 PROMO_LINK_CLICKED, | |
| 34 PROMO_ACTION_MAX, | |
| 35 }; | |
| 36 | |
| 37 } // namespace | |
| 28 | 38 |
| 29 NewTabPageHandler::NewTabPageHandler() : page_switch_count_(0) { | 39 NewTabPageHandler::NewTabPageHandler() : page_switch_count_(0) { |
| 30 } | 40 } |
| 31 | 41 |
| 32 NewTabPageHandler::~NewTabPageHandler() { | 42 NewTabPageHandler::~NewTabPageHandler() { |
| 33 HISTOGRAM_COUNTS_100("NewTabPage.SingleSessionPageSwitches", | 43 HISTOGRAM_COUNTS_100("NewTabPage.SingleSessionPageSwitches", |
| 34 page_switch_count_); | 44 page_switch_count_); |
| 35 } | 45 } |
| 36 | 46 |
| 37 void NewTabPageHandler::RegisterMessages() { | 47 void NewTabPageHandler::RegisterMessages() { |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 50 kDefaultAppsTrialName), | 60 kDefaultAppsTrialName), |
| 51 shown_page_type, kHistogramEnumerationMax); | 61 shown_page_type, kHistogramEnumerationMax); |
| 52 } | 62 } |
| 53 | 63 |
| 54 web_ui()->RegisterMessageCallback("notificationPromoClosed", | 64 web_ui()->RegisterMessageCallback("notificationPromoClosed", |
| 55 base::Bind(&NewTabPageHandler::HandleNotificationPromoClosed, | 65 base::Bind(&NewTabPageHandler::HandleNotificationPromoClosed, |
| 56 base::Unretained(this))); | 66 base::Unretained(this))); |
| 57 web_ui()->RegisterMessageCallback("notificationPromoViewed", | 67 web_ui()->RegisterMessageCallback("notificationPromoViewed", |
| 58 base::Bind(&NewTabPageHandler::HandleNotificationPromoViewed, | 68 base::Bind(&NewTabPageHandler::HandleNotificationPromoViewed, |
| 59 base::Unretained(this))); | 69 base::Unretained(this))); |
| 70 web_ui()->RegisterMessageCallback("notificationPromoLinkClicked", | |
| 71 base::Bind(&NewTabPageHandler::HandleNotificationPromoLinkClicked, | |
| 72 base::Unretained(this))); | |
| 60 web_ui()->RegisterMessageCallback("bubblePromoClosed", | 73 web_ui()->RegisterMessageCallback("bubblePromoClosed", |
| 61 base::Bind(&NewTabPageHandler::HandleBubblePromoClosed, | 74 base::Bind(&NewTabPageHandler::HandleBubblePromoClosed, |
| 62 base::Unretained(this))); | 75 base::Unretained(this))); |
| 63 web_ui()->RegisterMessageCallback("bubblePromoViewed", | 76 web_ui()->RegisterMessageCallback("bubblePromoViewed", |
| 64 base::Bind(&NewTabPageHandler::HandleBubblePromoViewed, | 77 base::Bind(&NewTabPageHandler::HandleBubblePromoViewed, |
| 65 base::Unretained(this))); | 78 base::Unretained(this))); |
| 66 web_ui()->RegisterMessageCallback("bubblePromoLinkClicked", | 79 web_ui()->RegisterMessageCallback("bubblePromoLinkClicked", |
| 67 base::Bind(&NewTabPageHandler::HandleBubblePromoLinkClicked, | 80 base::Bind(&NewTabPageHandler::HandleBubblePromoLinkClicked, |
| 68 base::Unretained(this))); | 81 base::Unretained(this))); |
| 69 web_ui()->RegisterMessageCallback("pageSelected", | 82 web_ui()->RegisterMessageCallback("pageSelected", |
| 70 base::Bind(&NewTabPageHandler::HandlePageSelected, | 83 base::Bind(&NewTabPageHandler::HandlePageSelected, |
| 71 base::Unretained(this))); | 84 base::Unretained(this))); |
| 72 web_ui()->RegisterMessageCallback("logTimeToClick", | 85 web_ui()->RegisterMessageCallback("logTimeToClick", |
| 73 base::Bind(&NewTabPageHandler::HandleLogTimeToClick, | 86 base::Bind(&NewTabPageHandler::HandleLogTimeToClick, |
| 74 base::Unretained(this))); | 87 base::Unretained(this))); |
| 75 } | 88 } |
| 76 | 89 |
| 77 void NewTabPageHandler::HandleNotificationPromoClosed(const ListValue* args) { | 90 void NewTabPageHandler::HandleNotificationPromoClosed(const ListValue* args) { |
| 78 UMA_HISTOGRAM_BOOLEAN("NewTabPage.Promo.Notification.Closed", true); | 91 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Promo.Notification", |
| 92 PROMO_CLOSED, PROMO_ACTION_MAX); | |
| 79 NotificationPromo::HandleClosed(Profile::FromWebUI(web_ui()), | 93 NotificationPromo::HandleClosed(Profile::FromWebUI(web_ui()), |
| 80 NotificationPromo::NTP_NOTIFICATION_PROMO); | 94 NotificationPromo::NTP_NOTIFICATION_PROMO); |
| 81 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); | 95 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); |
| 82 } | 96 } |
| 83 | 97 |
| 84 void NewTabPageHandler::HandleNotificationPromoViewed(const ListValue* args) { | 98 void NewTabPageHandler::HandleNotificationPromoViewed(const ListValue* args) { |
| 85 UMA_HISTOGRAM_BOOLEAN("NewTabPage.Promo.Notification.Viewed", true); | 99 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Promo.Notification", |
| 100 PROMO_VIEWED, PROMO_ACTION_MAX); | |
| 86 if (NotificationPromo::HandleViewed(Profile::FromWebUI(web_ui()), | 101 if (NotificationPromo::HandleViewed(Profile::FromWebUI(web_ui()), |
| 87 NotificationPromo::NTP_NOTIFICATION_PROMO)) { | 102 NotificationPromo::NTP_NOTIFICATION_PROMO)) { |
| 88 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); | 103 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); |
| 89 } | 104 } |
| 90 } | 105 } |
| 91 | 106 |
| 107 void NewTabPageHandler::HandleNotificationPromoLinkClicked( | |
| 108 const ListValue* args) { | |
| 109 DVLOG(1) << "HandleNotificationPromoLinkClicked"; | |
| 110 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Promo.Notification", | |
| 111 PROMO_LINK_CLICKED, PROMO_ACTION_MAX); | |
| 112 } | |
| 113 | |
| 92 void NewTabPageHandler::HandleBubblePromoClosed(const ListValue* args) { | 114 void NewTabPageHandler::HandleBubblePromoClosed(const ListValue* args) { |
| 93 UMA_HISTOGRAM_BOOLEAN("NewTabPage.Promo.Bubble.Closed", true); | 115 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Promo.Bubble", |
| 116 PROMO_CLOSED, PROMO_ACTION_MAX); | |
| 94 NotificationPromo::HandleClosed(Profile::FromWebUI(web_ui()), | 117 NotificationPromo::HandleClosed(Profile::FromWebUI(web_ui()), |
| 95 NotificationPromo::NTP_BUBBLE_PROMO); | 118 NotificationPromo::NTP_BUBBLE_PROMO); |
| 96 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); | 119 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); |
| 97 } | 120 } |
| 98 | 121 |
| 99 void NewTabPageHandler::HandleBubblePromoViewed(const ListValue* args) { | 122 void NewTabPageHandler::HandleBubblePromoViewed(const ListValue* args) { |
| 100 UMA_HISTOGRAM_BOOLEAN("NewTabPage.Promo.Bubble.Viewed", true); | 123 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Promo.Bubble", |
| 124 PROMO_VIEWED, PROMO_ACTION_MAX); | |
| 101 if (NotificationPromo::HandleViewed(Profile::FromWebUI(web_ui()), | 125 if (NotificationPromo::HandleViewed(Profile::FromWebUI(web_ui()), |
| 102 NotificationPromo::NTP_BUBBLE_PROMO)) { | 126 NotificationPromo::NTP_BUBBLE_PROMO)) { |
| 103 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); | 127 Notify(chrome::NOTIFICATION_PROMO_RESOURCE_STATE_CHANGED); |
| 104 } | 128 } |
| 105 } | 129 } |
| 106 | 130 |
| 107 void NewTabPageHandler::HandleBubblePromoLinkClicked(const ListValue* args) { | 131 void NewTabPageHandler::HandleBubblePromoLinkClicked(const ListValue* args) { |
| 108 DVLOG(1) << "HandleBubblePromoLinkClicked"; | 132 DVLOG(1) << "HandleBubblePromoLinkClicked"; |
| 109 UMA_HISTOGRAM_BOOLEAN("NewTabPage.Promo.Bubble.LinkClicked", true); | 133 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Promo.Bubble", |
| 134 PROMO_LINK_CLICKED, PROMO_ACTION_MAX); | |
| 110 } | 135 } |
| 111 | 136 |
| 112 void NewTabPageHandler::HandlePageSelected(const ListValue* args) { | 137 void NewTabPageHandler::HandlePageSelected(const ListValue* args) { |
| 113 page_switch_count_++; | 138 page_switch_count_++; |
| 114 | 139 |
| 115 double page_id_double; | 140 double page_id_double; |
| 116 CHECK(args->GetDouble(0, &page_id_double)); | 141 CHECK(args->GetDouble(0, &page_id_double)); |
| 117 int page_id = static_cast<int>(page_id_double); | 142 int page_id = static_cast<int>(page_id_double); |
| 118 | 143 |
| 119 double index_double; | 144 double index_double; |
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 191 values->SetInteger("shown_page_index", shown_page & INDEX_MASK); | 216 values->SetInteger("shown_page_index", shown_page & INDEX_MASK); |
| 192 } | 217 } |
| 193 | 218 |
| 194 void NewTabPageHandler::Notify(chrome::NotificationType notification_type) { | 219 void NewTabPageHandler::Notify(chrome::NotificationType notification_type) { |
| 195 content::NotificationService* service = | 220 content::NotificationService* service = |
| 196 content::NotificationService::current(); | 221 content::NotificationService::current(); |
| 197 service->Notify(notification_type, | 222 service->Notify(notification_type, |
| 198 content::Source<NewTabPageHandler>(this), | 223 content::Source<NewTabPageHandler>(this), |
| 199 content::NotificationService::NoDetails()); | 224 content::NotificationService::NoDetails()); |
| 200 } | 225 } |
| OLD | NEW |