Chromium Code Reviews| Index: chrome/browser/ui/views/download/download_feedback_dialog_view.cc |
| diff --git a/chrome/browser/ui/views/download/download_feedback_dialog_view.cc b/chrome/browser/ui/views/download/download_feedback_dialog_view.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..38f62133cd893102fbcd27e15dc98635ba19ebbe |
| --- /dev/null |
| +++ b/chrome/browser/ui/views/download/download_feedback_dialog_view.cc |
| @@ -0,0 +1,94 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/ui/views/download/download_feedback_dialog_view.h" |
| + |
| +#include "chrome/browser/prefs/pref_service_syncable.h" |
| +#include "chrome/browser/profiles/profile.h" |
| +#include "chrome/browser/ui/views/constrained_window_views.h" |
| +#include "grit/generated_resources.h" |
| +#include "ui/base/l10n/l10n_util.h" |
| +#include "ui/views/controls/message_box_view.h" |
| +#include "ui/views/widget/widget.h" |
| + |
| +// static |
| +void DownloadFeedbackDialogView::Show( |
| + gfx::NativeWindow parent_window, |
| + Profile* profile, |
| + const base::Callback<void(bool)>& callback) { |
| + // Enforce the constraint that this dialog should only be shown if it hasn't |
|
Peter Kasting
2014/02/04 21:56:33
Nit: DCHECKs don't really "enforce" anything, so I
felt
2014/02/04 23:37:22
Done.
|
| + // been shown before. |
| + DCHECK(profile->GetPrefs()-> |
| + GetInteger(prefs::kSafeBrowsingDownloadReportingEnabled) == kNeverShown); |
| + DownloadFeedbackDialogView* window = new DownloadFeedbackDialogView( |
|
Peter Kasting
2014/02/04 21:56:33
Nit: Breaking after '=' instead of '(' seems a lit
felt
2014/02/04 23:37:22
Done.
|
| + profile, callback); |
| + CreateBrowserModalDialogViews(window, parent_window)->Show(); |
| +} |
| + |
| +DownloadFeedbackDialogView::DownloadFeedbackDialogView( |
| + Profile* profile, |
| + const base::Callback<void(bool)>& callback) |
| + : profile_(profile), |
| + callback_(callback), |
| + explanation_box_view_(NULL) { |
| + title_text_ = l10n_util::GetStringUTF16(IDS_FEEDBACK_SERVICE_DIALOG_TITLE); |
|
Peter Kasting
2014/02/04 21:56:33
Nit: All these strings can be set in the initializ
felt
2014/02/04 23:37:22
Done.
|
| + base::string16 explanation_text = l10n_util::GetStringUTF16( |
|
Peter Kasting
2014/02/04 21:56:33
Nit: You can just inline this into the next statem
felt
2014/02/04 23:37:22
Done.
|
| + IDS_FEEDBACK_SERVICE_DIALOG_EXPLANATION); |
| + explanation_box_view_ = new views::MessageBoxView( |
| + views::MessageBoxView::InitParams(explanation_text)); |
| + ok_button_text_ = |
| + l10n_util::GetStringUTF16(IDS_FEEDBACK_SERVICE_DIALOG_OK_BUTTON_LABEL); |
| + cancel_button_text_ = l10n_util::GetStringUTF16( |
| + IDS_FEEDBACK_SERVICE_DIALOG_CANCEL_BUTTON_LABEL); |
| +} |
| + |
| +DownloadFeedbackDialogView::~DownloadFeedbackDialogView() {} |
| + |
| +int DownloadFeedbackDialogView::GetDefaultDialogButton() const { |
| + return ui::DIALOG_BUTTON_CANCEL; |
| +} |
| + |
| +base::string16 DownloadFeedbackDialogView::GetDialogButtonLabel( |
| + ui::DialogButton button) const { |
| + return (button == ui::DIALOG_BUTTON_OK) ? |
| + ok_button_text_ : cancel_button_text_; |
| +} |
| + |
| +bool DownloadFeedbackDialogView::Cancel() { |
| + profile_->GetPrefs()-> |
| + SetInteger(prefs::kSafeBrowsingDownloadReportingEnabled, kUserDisabled); |
| + callback_.Run(false); |
| + return true; |
| +} |
| + |
| +bool DownloadFeedbackDialogView::Accept() { |
| + profile_->GetPrefs()-> |
| + SetInteger(prefs::kSafeBrowsingDownloadReportingEnabled, kUserEnabled); |
| + callback_.Run(true); |
| + return true; |
| +} |
| + |
| +ui::ModalType DownloadFeedbackDialogView::GetModalType() const { |
| + return ui::MODAL_TYPE_SYSTEM; |
|
Peter Kasting
2014/02/04 21:56:33
Why does this need to be system-modal?
felt
2014/02/04 23:37:22
I was copying how similar dialogs seem to work. I
Peter Kasting
2014/02/05 00:07:36
In general, we want to be as non-modal as possible
felt
2014/02/05 02:08:53
This dialog doesn't pertain to any specific tab. I
Peter Kasting
2014/02/05 02:10:54
I think that's MODAL_TYPE_WINDOW? sky might know
felt
2014/02/05 18:41:32
sky agrees it should be MODAL_TYPE_WINDOW, so done
|
| +} |
| + |
| +base::string16 DownloadFeedbackDialogView::GetWindowTitle() const { |
| + return title_text_; |
| +} |
| + |
| +void DownloadFeedbackDialogView::DeleteDelegate() { |
| + delete this; |
| +} |
| + |
| +views::Widget* DownloadFeedbackDialogView::GetWidget() { |
| + return explanation_box_view_->GetWidget(); |
| +} |
| + |
| +const views::Widget* DownloadFeedbackDialogView::GetWidget() const { |
| + return explanation_box_view_->GetWidget(); |
| +} |
| + |
| +views::View* DownloadFeedbackDialogView::GetContentsView() { |
| + return explanation_box_view_; |
| +} |