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

Side by Side Diff: chrome/browser/ui/webui/ntp/new_tab_page_handler.cc

Issue 11230014: Use UMA_HISTOGRAM_ENUMERATION instead of UMA_HISTOGRAM_BOOLEAN (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 8 years, 2 months 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 | Annotate | Revision Log
« no previous file with comments | « chrome/browser/ui/webui/ntp/new_tab_page_handler.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
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 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/webui/ntp/new_tab_page_handler.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698