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

Side by Side Diff: chrome/browser/ui/views/external_protocol_dialog.cc

Issue 2559783003: Don't treat Esc like Cancel in the external protocol dialog on Views. (Closed)
Patch Set: Add comment Created 4 years 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
« no previous file with comments | « chrome/browser/ui/views/external_protocol_dialog.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/views/external_protocol_dialog.h" 5 #include "chrome/browser/ui/views/external_protocol_dialog.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/metrics/histogram_macros.h" 9 #include "base/metrics/histogram_macros.h"
10 #include "base/strings/string_util.h" 10 #include "base/strings/string_util.h"
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
67 67
68 base::string16 ExternalProtocolDialog::GetWindowTitle() const { 68 base::string16 ExternalProtocolDialog::GetWindowTitle() const {
69 return delegate_->GetTitleText(); 69 return delegate_->GetTitleText();
70 } 70 }
71 71
72 void ExternalProtocolDialog::DeleteDelegate() { 72 void ExternalProtocolDialog::DeleteDelegate() {
73 delete this; 73 delete this;
74 } 74 }
75 75
76 bool ExternalProtocolDialog::Cancel() { 76 bool ExternalProtocolDialog::Cancel() {
77 // We also get called back here if the user closes the dialog or presses
78 // escape. In these cases it would be preferable to ignore the state of the
79 // check box but MessageBox doesn't distinguish this from pressing the cancel
80 // button.
81 delegate_->DoCancel(delegate_->url(), 77 delegate_->DoCancel(delegate_->url(),
82 message_box_view_->IsCheckBoxSelected()); 78 message_box_view_->IsCheckBoxSelected());
83 79
84 ExternalProtocolHandler::RecordMetrics( 80 ExternalProtocolHandler::RecordMetrics(
85 message_box_view_->IsCheckBoxSelected()); 81 message_box_view_->IsCheckBoxSelected());
86 82
87 // Returning true closes the dialog. 83 // Returning true closes the dialog.
88 return true; 84 return true;
89 } 85 }
90 86
91 bool ExternalProtocolDialog::Accept() { 87 bool ExternalProtocolDialog::Accept() {
92 // We record how long it takes the user to accept an external protocol. If 88 // We record how long it takes the user to accept an external protocol. If
93 // users start accepting these dialogs too quickly, we should worry about 89 // users start accepting these dialogs too quickly, we should worry about
94 // clickjacking. 90 // clickjacking.
95 UMA_HISTOGRAM_LONG_TIMES("clickjacking.launch_url", 91 UMA_HISTOGRAM_LONG_TIMES("clickjacking.launch_url",
96 base::TimeTicks::Now() - creation_time_); 92 base::TimeTicks::Now() - creation_time_);
97 93
98 ExternalProtocolHandler::RecordMetrics( 94 ExternalProtocolHandler::RecordMetrics(
99 message_box_view_->IsCheckBoxSelected()); 95 message_box_view_->IsCheckBoxSelected());
100 96
101 delegate_->DoAccept(delegate_->url(), 97 delegate_->DoAccept(delegate_->url(),
102 message_box_view_->IsCheckBoxSelected()); 98 message_box_view_->IsCheckBoxSelected());
103 99
104 // Returning true closes the dialog. 100 // Returning true closes the dialog.
105 return true; 101 return true;
106 } 102 }
107 103
104 bool ExternalProtocolDialog::Close() {
105 // If the user dismisses the dialog without interacting with the buttons (e.g.
106 // via pressing Esc or the X), act as though they cancelled the request, but
107 // ignore the checkbox state. This ensures that if they check the checkbox but
108 // dismiss the dialog, we don't stop prompting them forever.
109 delegate_->DoCancel(delegate_->url(), false);
110 return true;
111 }
112
108 views::View* ExternalProtocolDialog::GetContentsView() { 113 views::View* ExternalProtocolDialog::GetContentsView() {
109 return message_box_view_; 114 return message_box_view_;
110 } 115 }
111 116
112 views::Widget* ExternalProtocolDialog::GetWidget() { 117 views::Widget* ExternalProtocolDialog::GetWidget() {
113 return message_box_view_->GetWidget(); 118 return message_box_view_->GetWidget();
114 } 119 }
115 120
116 const views::Widget* ExternalProtocolDialog::GetWidget() const { 121 const views::Widget* ExternalProtocolDialog::GetWidget() const {
117 return message_box_view_->GetWidget(); 122 return message_box_view_->GetWidget();
(...skipping 19 matching lines...) Expand all
137 message_box_view_ = new views::MessageBoxView(params); 142 message_box_view_ = new views::MessageBoxView(params);
138 message_box_view_->SetCheckBoxLabel(delegate_->GetCheckboxText()); 143 message_box_view_->SetCheckBoxLabel(delegate_->GetCheckboxText());
139 144
140 WebContents* web_contents = tab_util::GetWebContentsByID( 145 WebContents* web_contents = tab_util::GetWebContentsByID(
141 render_process_host_id_, routing_id_); 146 render_process_host_id_, routing_id_);
142 // Only launch the dialog if there is a web contents associated with the 147 // Only launch the dialog if there is a web contents associated with the
143 // request. 148 // request.
144 if (web_contents) 149 if (web_contents)
145 constrained_window::ShowWebModalDialogViews(this, web_contents); 150 constrained_window::ShowWebModalDialogViews(this, web_contents);
146 } 151 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/external_protocol_dialog.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698