1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
// Copyright (c) 2012 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.
#ifndef CHROME_BROWSER_UI_SIMPLE_MESSAGE_BOX_H_
#define CHROME_BROWSER_UI_SIMPLE_MESSAGE_BOX_H_
#include "base/compiler_specific.h"
#include "base/strings/string16.h"
#include "ui/gfx/native_widget_types.h"
namespace chrome {
enum MessageBoxResult {
// User chose NO or CANCEL. If there's a checkbox, then the checkbox was
// unchecked.
MESSAGE_BOX_RESULT_NO = 0,
// User chose YES or OK. If there's a checkbox, then the checkbox was checked.
MESSAGE_BOX_RESULT_YES = 1,
};
enum MessageBoxType {
MESSAGE_BOX_TYPE_WARNING, // Shows an OK button.
MESSAGE_BOX_TYPE_QUESTION, // Shows YES and NO buttons.
};
// Shows a dialog box with the given |title| and |message|. If |parent| is
// non-NULL, the box will be made modal to the |parent|, except on Mac, where it
// is always app-modal.
//
// NOTE: In general, you should avoid this since it's usually poor UI.
// We have a variety of other surfaces such as app menu notifications and
// infobars; consult the UI leads for a recommendation.
void ShowWarningMessageBox(gfx::NativeWindow parent,
const base::string16& title,
const base::string16& message);
// As above, but with a checkbox. Returns true if the checkbox was checked when
// the dialog was dismissed, false otherwise.
bool ShowWarningMessageBoxWithCheckbox(gfx::NativeWindow parent,
const base::string16& title,
const base::string16& message,
const base::string16& checkbox_text);
// As above, but two buttons are displayed and the return value indicates which
// is chosen.
MessageBoxResult ShowQuestionMessageBox(gfx::NativeWindow parent,
const base::string16& title,
const base::string16& message);
// Shows a dialog box with the given |title| and |message|, and with two buttons
// labeled with |yes_text| and |no_text|. If |parent| is non-NULL, the box will
// be made modal to the |parent|. (Aura only.)
//
// NOTE: In general, you should avoid this since it's usually poor UI.
// We have a variety of other surfaces such as app menu notifications and
// infobars; consult the UI leads for a recommendation.
MessageBoxResult ShowMessageBoxWithButtonText(gfx::NativeWindow parent,
const base::string16& title,
const base::string16& message,
const base::string16& yes_text,
const base::string16& no_text);
// Closes the current message box, if any, accepting or declining based on
// |accept|. Returns whether there was a message box showing.
bool CloseMessageBoxForTest(bool accept) WARN_UNUSED_RESULT;
} // namespace chrome
#endif // CHROME_BROWSER_UI_SIMPLE_MESSAGE_BOX_H_
|