[email protected] | 5c61cc9 | 2012-04-23 02:00:39 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
[email protected] | 80772ed | 2011-08-09 21:11:38 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
[email protected] | b50892c5f | 2012-05-13 07:34:14 | [diff] [blame] | 5 | #ifndef CHROME_BROWSER_UI_SIMPLE_MESSAGE_BOX_H_ |
| 6 | #define CHROME_BROWSER_UI_SIMPLE_MESSAGE_BOX_H_ |
[email protected] | 80772ed | 2011-08-09 21:11:38 | [diff] [blame] | 7 | |
xiyuan | 2404367 | 2017-06-14 15:17:29 | [diff] [blame] | 8 | #include "base/callback_forward.h" |
kjellander | 2befbdd | 2016-11-02 14:09:16 | [diff] [blame] | 9 | #include "base/compiler_specific.h" |
[email protected] | f92d658 | 2013-06-10 22:02:36 | [diff] [blame] | 10 | #include "base/strings/string16.h" |
[email protected] | 80772ed | 2011-08-09 21:11:38 | [diff] [blame] | 11 | #include "ui/gfx/native_widget_types.h" |
| 12 | |
[email protected] | d3322029 | 2012-07-04 01:41:27 | [diff] [blame] | 13 | namespace chrome { |
[email protected] | 80772ed | 2011-08-09 21:11:38 | [diff] [blame] | 14 | |
[email protected] | 5da155e | 2012-05-26 16:31:16 | [diff] [blame] | 15 | enum MessageBoxResult { |
afakhry | 7c9abe7 | 2016-08-05 17:33:19 | [diff] [blame] | 16 | // User chose NO or CANCEL. If there's a checkbox, then the checkbox was |
| 17 | // unchecked. |
| 18 | MESSAGE_BOX_RESULT_NO = 0, |
| 19 | |
| 20 | // User chose YES or OK. If there's a checkbox, then the checkbox was checked. |
| 21 | MESSAGE_BOX_RESULT_YES = 1, |
Elly Fong-Jones | 165afb9 | 2017-06-29 18:43:28 | [diff] [blame^] | 22 | |
| 23 | // Message box was displayed asynchronously and is pending a real result, |
| 24 | // which will be delivered via callback. |
| 25 | MESSAGE_BOX_RESULT_DEFERRED = 2, |
[email protected] | 5da155e | 2012-05-26 16:31:16 | [diff] [blame] | 26 | }; |
| 27 | |
[email protected] | d1f48ef5 | 2012-05-13 19:34:21 | [diff] [blame] | 28 | enum MessageBoxType { |
[email protected] | f8ef716 | 2013-11-22 01:56:41 | [diff] [blame] | 29 | MESSAGE_BOX_TYPE_WARNING, // Shows an OK button. |
| 30 | MESSAGE_BOX_TYPE_QUESTION, // Shows YES and NO buttons. |
[email protected] | d1f48ef5 | 2012-05-13 19:34:21 | [diff] [blame] | 31 | }; |
| 32 | |
[email protected] | 5da155e | 2012-05-26 16:31:16 | [diff] [blame] | 33 | // Shows a dialog box with the given |title| and |message|. If |parent| is |
| 34 | // non-NULL, the box will be made modal to the |parent|, except on Mac, where it |
[email protected] | 24ced7dc0 | 2013-04-04 08:32:39 | [diff] [blame] | 35 | // is always app-modal. |
[email protected] | 5da155e | 2012-05-26 16:31:16 | [diff] [blame] | 36 | // |
| 37 | // NOTE: In general, you should avoid this since it's usually poor UI. |
tfarina | 917cff5e | 2015-10-31 01:16:38 | [diff] [blame] | 38 | // We have a variety of other surfaces such as app menu notifications and |
[email protected] | 5da155e | 2012-05-26 16:31:16 | [diff] [blame] | 39 | // infobars; consult the UI leads for a recommendation. |
estade | e16f96ed | 2016-03-07 22:57:05 | [diff] [blame] | 40 | void ShowWarningMessageBox(gfx::NativeWindow parent, |
| 41 | const base::string16& title, |
| 42 | const base::string16& message); |
| 43 | |
xiyuan | 2404367 | 2017-06-14 15:17:29 | [diff] [blame] | 44 | // As above, but shows the dialog box asynchronously with a checkbox. |
| 45 | // |callback| will be invoked after the dialog is dismissed. It is invoked with |
| 46 | // true if the checkbox is checked and false otherwise. |
| 47 | void ShowWarningMessageBoxWithCheckbox( |
| 48 | gfx::NativeWindow parent, |
| 49 | const base::string16& title, |
| 50 | const base::string16& message, |
| 51 | const base::string16& checkbox_text, |
| 52 | base::OnceCallback<void(bool checked)> callback); |
afakhry | 7c9abe7 | 2016-08-05 17:33:19 | [diff] [blame] | 53 | |
estade | e16f96ed | 2016-03-07 22:57:05 | [diff] [blame] | 54 | // As above, but two buttons are displayed and the return value indicates which |
| 55 | // is chosen. |
| 56 | MessageBoxResult ShowQuestionMessageBox(gfx::NativeWindow parent, |
| 57 | const base::string16& title, |
| 58 | const base::string16& message); |
[email protected] | 80772ed | 2011-08-09 21:11:38 | [diff] [blame] | 59 | |
[email protected] | f8ef716 | 2013-11-22 01:56:41 | [diff] [blame] | 60 | // Shows a dialog box with the given |title| and |message|, and with two buttons |
| 61 | // labeled with |yes_text| and |no_text|. If |parent| is non-NULL, the box will |
| 62 | // be made modal to the |parent|. (Aura only.) |
| 63 | // |
| 64 | // NOTE: In general, you should avoid this since it's usually poor UI. |
tfarina | 917cff5e | 2015-10-31 01:16:38 | [diff] [blame] | 65 | // We have a variety of other surfaces such as app menu notifications and |
[email protected] | f8ef716 | 2013-11-22 01:56:41 | [diff] [blame] | 66 | // infobars; consult the UI leads for a recommendation. |
| 67 | MessageBoxResult ShowMessageBoxWithButtonText(gfx::NativeWindow parent, |
[email protected] | dcd024987 | 2013-12-06 23:58:45 | [diff] [blame] | 68 | const base::string16& title, |
| 69 | const base::string16& message, |
| 70 | const base::string16& yes_text, |
| 71 | const base::string16& no_text); |
[email protected] | f8ef716 | 2013-11-22 01:56:41 | [diff] [blame] | 72 | |
kjellander | 2befbdd | 2016-11-02 14:09:16 | [diff] [blame] | 73 | // Closes the current message box, if any, accepting or declining based on |
| 74 | // |accept|. Returns whether there was a message box showing. |
| 75 | bool CloseMessageBoxForTest(bool accept) WARN_UNUSED_RESULT; |
| 76 | |
[email protected] | d3322029 | 2012-07-04 01:41:27 | [diff] [blame] | 77 | } // namespace chrome |
[email protected] | 80772ed | 2011-08-09 21:11:38 | [diff] [blame] | 78 | |
[email protected] | b50892c5f | 2012-05-13 07:34:14 | [diff] [blame] | 79 | #endif // CHROME_BROWSER_UI_SIMPLE_MESSAGE_BOX_H_ |