OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/passwords/manage_passwords_bubble_model.h" | 5 #include "chrome/browser/ui/passwords/manage_passwords_bubble_model.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 #include <limits> | 10 #include <limits> |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
73 // Class responsible for collecting and reporting all the runtime interactions | 73 // Class responsible for collecting and reporting all the runtime interactions |
74 // with the bubble. | 74 // with the bubble. |
75 class ManagePasswordsBubbleModel::InteractionKeeper { | 75 class ManagePasswordsBubbleModel::InteractionKeeper { |
76 public: | 76 public: |
77 InteractionKeeper( | 77 InteractionKeeper( |
78 password_manager::InteractionsStats stats, | 78 password_manager::InteractionsStats stats, |
79 password_manager::metrics_util::UIDisplayDisposition display_disposition); | 79 password_manager::metrics_util::UIDisplayDisposition display_disposition); |
80 | 80 |
81 ~InteractionKeeper() = default; | 81 ~InteractionKeeper() = default; |
82 | 82 |
83 // Records UMA events and updates the interaction statistics when the bubble | 83 // Records UMA events, updates the interaction statistics and sends |
84 // is closed. | 84 // notifications to the delegate when the bubble is closed. |
85 void ReportInteractions(const ManagePasswordsBubbleModel* model); | 85 void ReportInteractions(const ManagePasswordsBubbleModel* model); |
86 | 86 |
87 void set_dismissal_reason( | 87 void set_dismissal_reason( |
88 password_manager::metrics_util::UIDismissalReason reason) { | 88 password_manager::metrics_util::UIDismissalReason reason) { |
89 dismissal_reason_ = reason; | 89 dismissal_reason_ = reason; |
90 } | 90 } |
91 | 91 |
92 void set_update_password_submission_event( | 92 void set_update_password_submission_event( |
93 password_manager::metrics_util::UpdatePasswordSubmissionEvent event) { | 93 password_manager::metrics_util::UpdatePasswordSubmissionEvent event) { |
94 update_password_submission_event_ = event; | 94 update_password_submission_event_ = event; |
(...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
186 } | 186 } |
187 } else if (model->state() != | 187 } else if (model->state() != |
188 password_manager::ui::PENDING_PASSWORD_UPDATE_STATE) { | 188 password_manager::ui::PENDING_PASSWORD_UPDATE_STATE) { |
189 // We have separate metrics for the Update bubble so do not record dismissal | 189 // We have separate metrics for the Update bubble so do not record dismissal |
190 // reason for it. | 190 // reason for it. |
191 metrics_util::LogUIDismissalReason(dismissal_reason_); | 191 metrics_util::LogUIDismissalReason(dismissal_reason_); |
192 } | 192 } |
193 | 193 |
194 if (model->state() == password_manager::ui::PENDING_PASSWORD_UPDATE_STATE || | 194 if (model->state() == password_manager::ui::PENDING_PASSWORD_UPDATE_STATE || |
195 model->state() == password_manager::ui::PENDING_PASSWORD_STATE) { | 195 model->state() == password_manager::ui::PENDING_PASSWORD_STATE) { |
| 196 // Send a notification if there was no interaction with the bubble. |
| 197 bool no_interaction = |
| 198 model->state() == password_manager::ui::PENDING_PASSWORD_UPDATE_STATE |
| 199 ? update_password_submission_event_ == |
| 200 metrics_util::NO_UPDATE_SUBMISSION |
| 201 : dismissal_reason_ == metrics_util::NO_DIRECT_INTERACTION; |
| 202 if (no_interaction && model->delegate_) { |
| 203 model->delegate_->OnNoInteraction(); |
| 204 } |
| 205 |
| 206 // Send UMA. |
196 if (update_password_submission_event_ == | 207 if (update_password_submission_event_ == |
197 metrics_util::NO_UPDATE_SUBMISSION) { | 208 metrics_util::NO_UPDATE_SUBMISSION) { |
198 update_password_submission_event_ = | 209 update_password_submission_event_ = |
199 model->GetUpdateDismissalReason(NO_INTERACTION); | 210 model->GetUpdateDismissalReason(NO_INTERACTION); |
200 if (model->delegate_ && | |
201 model->state() == password_manager::ui::PENDING_PASSWORD_UPDATE_STATE) | |
202 model->delegate_->OnNoInteractionOnUpdate(); | |
203 } | 211 } |
204 | |
205 if (update_password_submission_event_ != metrics_util::NO_UPDATE_SUBMISSION) | 212 if (update_password_submission_event_ != metrics_util::NO_UPDATE_SUBMISSION) |
206 LogUpdatePasswordSubmissionEvent(update_password_submission_event_); | 213 LogUpdatePasswordSubmissionEvent(update_password_submission_event_); |
207 } | 214 } |
208 } | 215 } |
209 | 216 |
210 ManagePasswordsBubbleModel::ManagePasswordsBubbleModel( | 217 ManagePasswordsBubbleModel::ManagePasswordsBubbleModel( |
211 base::WeakPtr<PasswordsModelDelegate> delegate, | 218 base::WeakPtr<PasswordsModelDelegate> delegate, |
212 DisplayReason display_reason) | 219 DisplayReason display_reason) |
213 : password_overridden_(false), | 220 : password_overridden_(false), |
214 delegate_(std::move(delegate)) { | 221 delegate_(std::move(delegate)) { |
(...skipping 296 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
511 return metrics_util::NO_UPDATE_SUBMISSION; | 518 return metrics_util::NO_UPDATE_SUBMISSION; |
512 } | 519 } |
513 if (state_ != password_manager::ui::PENDING_PASSWORD_UPDATE_STATE) | 520 if (state_ != password_manager::ui::PENDING_PASSWORD_UPDATE_STATE) |
514 return metrics_util::NO_UPDATE_SUBMISSION; | 521 return metrics_util::NO_UPDATE_SUBMISSION; |
515 if (password_overridden_) | 522 if (password_overridden_) |
516 return update_events[3][behavior]; | 523 return update_events[3][behavior]; |
517 if (ShouldShowMultipleAccountUpdateUI()) | 524 if (ShouldShowMultipleAccountUpdateUI()) |
518 return update_events[2][behavior]; | 525 return update_events[2][behavior]; |
519 return update_events[1][behavior]; | 526 return update_events[1][behavior]; |
520 } | 527 } |
OLD | NEW |