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

Unified Diff: chrome/browser/pdf_unsupported_feature.cc

Issue 6320018: Reverse the Yes and No buttons for the PDF infobars. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 9 years, 11 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/pdf_unsupported_feature.cc
===================================================================
--- chrome/browser/pdf_unsupported_feature.cc (revision 72735)
+++ chrome/browser/pdf_unsupported_feature.cc (working copy)
@@ -34,7 +34,8 @@
namespace {
// The info bar delegate used to ask the user if they want to use Adobe Reader
-// by default.
+// by default. We want the infobar to have [No][Yes], so we swap the text on
+// the buttons, and the meaning of the delegate callbacks.
class PDFEnableAdobeReaderConfirmInfoBarDelegate
: public ConfirmInfoBarDelegate {
public:
@@ -51,7 +52,7 @@
}
virtual void InfoBarDismissed() {
- Cancel();
+ OnNo();
}
virtual Type GetInfoBarType() const {
@@ -59,19 +60,11 @@
}
virtual bool Accept() {
- UserMetrics::RecordAction(
- UserMetricsAction("PDF_EnableReaderInfoBarOK"));
- webkit::npapi::PluginList::Singleton()->EnableGroup(
- false, ASCIIToUTF16(PepperPluginRegistry::kPDFPluginName));
- webkit::npapi::PluginList::Singleton()->EnableGroup(
- true, ASCIIToUTF16(webkit::npapi::PluginGroup::kAdobeReaderGroupName));
- return true;
+ return OnNo();
}
virtual bool Cancel() {
- UserMetrics::RecordAction(
- UserMetricsAction("PDF_EnableReaderInfoBarCancel"));
- return true;
+ return OnYes();
}
virtual int GetButtons() const {
@@ -82,10 +75,10 @@
switch (button) {
case BUTTON_OK:
return l10n_util::GetStringUTF16(
- IDS_CONFIRM_MESSAGEBOX_YES_BUTTON_LABEL);
+ IDS_CONFIRM_MESSAGEBOX_NO_BUTTON_LABEL);
case BUTTON_CANCEL:
return l10n_util::GetStringUTF16(
- IDS_CONFIRM_MESSAGEBOX_NO_BUTTON_LABEL);
+ IDS_CONFIRM_MESSAGEBOX_YES_BUTTON_LABEL);
default:
// All buttons are labeled above.
NOTREACHED() << "Bad button id " << button;
@@ -99,6 +92,22 @@
}
private:
+ bool OnYes() {
+ UserMetrics::RecordAction(
+ UserMetricsAction("PDF_EnableReaderInfoBarOK"));
+ webkit::npapi::PluginList::Singleton()->EnableGroup(
+ false, ASCIIToUTF16(PepperPluginRegistry::kPDFPluginName));
+ webkit::npapi::PluginList::Singleton()->EnableGroup(
+ true, ASCIIToUTF16(webkit::npapi::PluginGroup::kAdobeReaderGroupName));
+ return true;
+ }
+
+ bool OnNo() {
+ UserMetrics::RecordAction(
+ UserMetricsAction("PDF_EnableReaderInfoBarCancel"));
+ return true;
+ }
+
DISALLOW_IMPLICIT_CONSTRUCTORS(PDFEnableAdobeReaderConfirmInfoBarDelegate);
};
@@ -206,7 +215,8 @@
};
// The info bar delegate used to inform the user that we don't support a feature
-// in the PDF.
+// in the PDF. See the comment about how we swap buttons for
+// PDFEnableAdobeReaderConfirmInfoBarDelegate.
class PDFUnsupportedFeatureConfirmInfoBarDelegate
: public ConfirmInfoBarDelegate {
public:
@@ -244,7 +254,7 @@
}
virtual void InfoBarDismissed() {
- Cancel();
+ OnNo();
}
virtual Type GetInfoBarType() const {
@@ -252,7 +262,41 @@
}
virtual bool Accept() {
- if (!reader_installed_) {
+ return OnNo();
+ }
+
+ virtual bool Cancel() {
+ return OnYes();
+ }
+
+ virtual int GetButtons() const {
+ return BUTTON_OK | BUTTON_CANCEL;
+ }
+
+ virtual string16 GetButtonLabel(InfoBarButton button) const {
+ switch (button) {
+ case BUTTON_OK:
+ return l10n_util::GetStringUTF16(
+ IDS_CONFIRM_MESSAGEBOX_NO_BUTTON_LABEL);
+ case BUTTON_CANCEL:
+ return l10n_util::GetStringUTF16(
+ IDS_CONFIRM_MESSAGEBOX_YES_BUTTON_LABEL);
+ default:
+ // All buttons are labeled above.
+ NOTREACHED() << "Bad button id " << button;
+ return string16();
+ }
+ }
+
+ virtual string16 GetMessageText() const {
+ return l10n_util::GetStringUTF16(reader_installed_ ?
+ IDS_PDF_INFOBAR_QUESTION_READER_INSTALLED :
+ IDS_PDF_INFOBAR_QUESTION_READER_NOT_INSTALLED);
+ }
+
+ private:
+ bool OnYes() {
+ if (!reader_installed_) {
UserMetrics::RecordAction(
UserMetricsAction("PDF_InstallReaderInfoBarOK"));
OpenReaderUpdateURL(tab_contents_);
@@ -274,7 +318,7 @@
return false;
}
- virtual bool Cancel() {
+ bool OnNo() {
if (reader_installed_) {
UserMetrics::RecordAction(
UserMetricsAction("PDF_UseReaderInfoBarCancel"));
@@ -285,32 +329,6 @@
return true;
}
- virtual int GetButtons() const {
- return BUTTON_OK | BUTTON_CANCEL;
- }
-
- virtual string16 GetButtonLabel(InfoBarButton button) const {
- switch (button) {
- case BUTTON_OK:
- return l10n_util::GetStringUTF16(
- IDS_CONFIRM_MESSAGEBOX_YES_BUTTON_LABEL);
- case BUTTON_CANCEL:
- return l10n_util::GetStringUTF16(
- IDS_CONFIRM_MESSAGEBOX_NO_BUTTON_LABEL);
- default:
- // All buttons are labeled above.
- NOTREACHED() << "Bad button id " << button;
- return string16();
- }
- }
-
- virtual string16 GetMessageText() const {
- return l10n_util::GetStringUTF16(reader_installed_ ?
- IDS_PDF_INFOBAR_QUESTION_READER_INSTALLED :
- IDS_PDF_INFOBAR_QUESTION_READER_NOT_INSTALLED);
- }
-
- private:
TabContents* tab_contents_;
bool reader_installed_;
bool reader_vulnerable_;
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698