summaryrefslogtreecommitdiffstats
path: root/kdeui/kmessagebox.h
diff options
context:
space:
mode:
Diffstat (limited to 'kdeui/kmessagebox.h')
-rw-r--r--kdeui/kmessagebox.h1166
1 files changed, 1166 insertions, 0 deletions
diff --git a/kdeui/kmessagebox.h b/kdeui/kmessagebox.h
new file mode 100644
index 000000000..850fb7a5b
--- /dev/null
+++ b/kdeui/kmessagebox.h
@@ -0,0 +1,1166 @@
+/* This file is part of the KDE libraries
+ Copyright (C) 1999 Waldo Bastian (bastian@kde.org)
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public
+ License as published by the Free Software Foundation; version 2
+ of the License.
+
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public License
+ along with this library; see the file COPYING.LIB. If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA.
+*/
+#ifndef _KMESSAGEBOX_H_
+#define _KMESSAGEBOX_H_
+
+#include <qstring.h>
+#include <qmessagebox.h>
+
+#include <kguiitem.h>
+#include <kstdguiitem.h>
+
+class QWidget;
+class QStringList;
+class KConfig;
+class KDialogBase;
+
+ /**
+ * Easy message dialog box.
+ *
+ * Provides convenience functions for some i18n'ed standard dialogs.
+ *
+ * The text in message boxes is wrapped automatically. The text may either
+ * be plaintext or richtext. If the text is plaintext, a newline-character
+ * may be used to indicate the end of a paragraph.
+ *
+ * @author Waldo Bastian (bastian@kde.org)
+ */
+class KDEUI_EXPORT KMessageBox
+{
+public:
+ /**
+ * Button types.
+ **/
+ enum ButtonCode
+ {
+ Ok = 1,
+ Cancel = 2,
+ Yes = 3,
+ No = 4,
+ Continue = 5
+ };
+
+ enum DialogType
+ {
+ QuestionYesNo = 1,
+ WarningYesNo = 2,
+ WarningContinueCancel = 3,
+ WarningYesNoCancel = 4,
+ Information = 5,
+ // Reserved for: SSLMessageBox = 6
+ Sorry = 7,
+ Error = 8,
+ QuestionYesNoCancel = 9
+ };
+
+ enum OptionsType
+ {
+ Notify = 1, ///< Emit a KNotifyClient event
+ AllowLink = 2, ///< The message may contain links.
+ Dangerous = 4, ///< The action to be confirmed by the dialog is a potentially destructive one
+ PlainCaption = 8, /**< Do not use KApplication::makeStdCaption()
+ @since 3.4
+ */
+ NoExec = 16 /**< Do not call exec() in createKMessageBox()
+ @since 3.4
+ */
+ };
+
+ /**
+ * Display a simple "question" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Question").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return 'Yes' is returned if the Yes-button is pressed. 'No' is returned
+ * if the No-button is pressed.
+ *
+ * To be used for questions like "Do you have a printer?"
+ *
+ * The default button is "Yes". Pressing "Esc" selects "No".
+ */
+
+ static int questionYesNo(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int questionYesNoWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+ /**
+ * Display a simple "question" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Question").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return 'Yes' is returned if the Yes-button is pressed. 'No' is returned
+ * if the No-button is pressed.
+ *
+ * To be used for questions like "Do you want to discard the message or save it for later?",
+ *
+ * The default button is "Yes". Pressing "Esc" selects "Cancel".
+ *
+ * NOTE: The cancel button will always have the i18n'ed text '&Cancel'.
+ */
+
+ static int questionYesNoCancel(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int questionYesNoCancelWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display a "question" dialog with a listbox to show information to the user
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox. If the list is
+ * empty, it doesn't show any listbox, working as questionYesNo.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Question").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return 'Yes' is returned if the Yes-button is pressed. 'No' is returned
+ * if the No-button is pressed.
+ *
+ * To be used for questions like "Do you really want to delete these files?"
+ * And show the user exactly which files are going to be deleted in case
+ * he presses "Yes"
+ *
+ * The default button is "Yes". Pressing "Esc" selects "No".
+ */
+
+ static int questionYesNoList(QWidget *parent,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int questionYesNoListWId(WId parent_id,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display a "warning" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Warning").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return @p Yes is returned if the Yes-button is pressed. @p No is returned
+ * if the No-button is pressed.
+ *
+ * To be used for questions "Shall I update your configuration?"
+ * The text should explain the implication of both options.
+ *
+ * The default button is "No". Pressing "Esc" selects "No".
+ */
+ static int warningYesNo(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify | Dangerous);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int warningYesNoWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify | Dangerous);
+
+ /**
+ * Display a "warning" dialog with a listbox to show information to the user
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox. If the list is
+ * empty, it doesn't show any listbox, working as questionYesNo.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Question").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return 'Yes' is returned if the Yes-button is pressed. 'No' is returned
+ * if the No-button is pressed.
+ *
+ * To be used for questions like "Do you really want to delete these files?"
+ * And show the user exactly which files are going to be deleted in case
+ * he presses "Yes"
+ *
+ * The default button is "No". Pressing "Esc" selects "No".
+ */
+
+ static int warningYesNoList(QWidget *parent,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify | Dangerous);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int warningYesNoListWId(WId parent_id,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify | Dangerous);
+
+ /**
+ * Display a "warning" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Warning").
+ * @param buttonContinue The text for the first button.
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * The second button always has the text "Cancel".
+ *
+ * @return @p Continue is returned if the Continue-button is pressed.
+ * @p Cancel is returned if the Cancel-button is pressed.
+ *
+ * To be used for questions like "You are about to Print. Are you sure?"
+ * the continueButton should then be labeled "Print".
+ *
+ * The default button is buttonContinue. Pressing "Esc" selects "Cancel".
+ */
+ static int warningContinueCancel(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonContinue = KStdGuiItem::cont(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int warningContinueCancelWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonContinue = KStdGuiItem::cont(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display a "warning" dialog with a listbox to show information to the user.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox. If the
+ * list is empty, it doesn't show any listbox, working
+ * as warningContinueCancel.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Warning").
+ * @param buttonContinue The text for the first button.
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further confirmation can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ *
+ * @param options see OptionsType
+ *
+ * The second button always has the text "Cancel".
+ *
+ * @return @p Continue is returned if the Continue-button is pressed.
+ * @p Cancel is returned if the Cancel-button is pressed.
+ *
+ * To be used for questions like "You are about to Print. Are you sure?"
+ * the continueButton should then be labeled "Print".
+ *
+ * The default button is buttonContinue. Pressing "Esc" selects "Cancel".
+ */
+ static int warningContinueCancelList(QWidget *parent,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonContinue = KStdGuiItem::cont(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int warningContinueCancelListWId(WId parent_id,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonContinue = KStdGuiItem::cont(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display a Yes/No/Cancel "warning" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Warning").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further questions can be turned off. If turned off
+ * all questions will be automatically answered with the
+ * last answer (either Yes or No).
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return @p Yes is returned if the Yes-button is pressed. @p No is returned
+ * if the No-button is pressed. @p Cancel is retunred if the Cancel-
+ * button is pressed.
+ *
+ * To be used for questions "Do you want to save your changes?"
+ * The text should explain the implication of choosing 'No'.
+ *
+ * The default button is "Yes". Pressing "Esc" selects "Cancel"
+ *
+ * NOTE: The cancel button will always have the i18n'ed text '&Cancel'.
+ */
+
+ static int warningYesNoCancel(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int warningYesNoCancelWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display a Yes/No/Cancel "warning" dialog with a listbox to show information
+ * to the user.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox. If the
+ * list is empty, it doesn't show any listbox, working
+ * as warningYesNoCancel.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Warning").
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontAskAgainName If provided, a checkbox is added with which
+ * further questions can be turned off. If turned off
+ * all questions will be automatically answered with the
+ * last answer (either Yes or No).
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * If @p dontAskAgainName starts with a ':' then the setting
+ * is stored in the global config file.
+ * @param options see OptionsType
+ *
+ * @return @p Yes is returned if the Yes-button is pressed. @p No is returned
+ * if the No-button is pressed. @p Cancel is retunred if the Cancel-
+ * button is pressed.
+ *
+ * To be used for questions "Do you want to save your changes?"
+ * The text should explain the implication of choosing 'No'.
+ *
+ * The default button is "Yes". Pressing "Esc" selects "Cancel"
+ *
+ * NOTE: The cancel button will always have the i18n'ed text '&Cancel'.
+ *
+ * @since 3.2
+ */
+ static int warningYesNoCancelList(QWidget *parent,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int warningYesNoCancelListWId(WId parent_id,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display an "Error" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Error").
+ * @param options see OptionsType
+ *
+ * Your program messed up and now it's time to inform the user.
+ * To be used for important things like "Sorry, I deleted your hard disk."
+ *
+ * If your program detects the action specified by the user is somehow
+ * not allowed, this should never be reported with error(). Use sorry()
+ * instead to explain to the user that this action is not allowed.
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The OK button will always have the i18n'ed text '&OK'.
+ */
+
+ static void error(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ *
+ * @since 3.2
+ */
+ static void errorWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * Display an "Error" dialog with a listbox.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox. If the
+ * list is empty, it doesn't show any listbox, working
+ * as error().
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Error").
+ * @param options see OptionsType
+ *
+ * Your program messed up and now it's time to inform the user.
+ * To be used for important things like "Sorry, I deleted your hard disk."
+ *
+ * If your program detects the action specified by the user is somehow
+ * not allowed, this should never be reported with error(). Use sorry()
+ * instead to explain to the user that this action is not allowed.
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The OK button will always have the i18n'ed text '&OK'.
+ *
+ * @since 3.4
+ */
+
+ static void errorList(QWidget *parent,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.4
+ */
+
+ static void errorListWId(WId parent_id,
+ const QString &text,
+ const QStringList &strlist,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * Displays an "Error" dialog with a "Details >>" button.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param details Detailed message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Error").
+ * @param options see OptionsType
+ *
+ * Your program messed up and now it's time to inform the user.
+ * To be used for important things like "Sorry, I deleted your hard disk."
+ *
+ * The @p details message can conatin additional information about
+ * the problem and can be shown on request to advanced/interested users.
+ *
+ * If your program detects the action specified by the user is somehow
+ * not allowed, this should never be reported with error(). Use sorry()
+ * instead to explain to the user that this action is not allowed.
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The OK button will always have the i18n'ed text '&OK'.
+ */
+ static void detailedError(QWidget *parent,
+ const QString &text,
+ const QString &details,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void detailedErrorWId(WId parent_id,
+ const QString &text,
+ const QString &details,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * Like detailedError
+ *
+ * This function will return immediately, the messagebox will be shown
+ * once the application enters an event loop and no other messagebox
+ * is being shown.
+ *
+ * Note that if the parent gets deleted, the messagebox will not be
+ * shown.
+ */
+ static void queuedDetailedError( QWidget *parent,
+ const QString &text,
+ const QString &details,
+ const QString &caption = QString::null);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void queuedDetailedErrorWId( WId parent_id,
+ const QString &text,
+ const QString &details,
+ const QString &caption = QString::null);
+
+ /**
+ * Display an "Sorry" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Sorry").
+ * @param options see OptionsType
+ *
+ * Either your program messed up and asks for understanding
+ * or your user did something stupid.
+ *
+ * To be used for small problems like
+ * "Sorry, I can't find the file you specified."
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The ok button will always have the i18n'ed text '&OK'.
+ */
+
+ static void sorry(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void sorryWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * Displays a "Sorry" dialog with a "Details >>" button.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param details Detailed message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Sorry").
+ * @param options see OptionsType
+ *
+ * Either your program messed up and asks for understanding
+ * or your user did something stupid.
+ *
+ * To be used for small problems like
+ * "Sorry, I can't find the file you specified."
+ *
+ * And then @p details can contain something like
+ * "foobar.txt was not found in any of
+ * the following directories:
+ * /usr/bin,/usr/local/bin,/usr/sbin"
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The ok button will always have the i18n'ed text '&OK'.
+ */
+
+ static void detailedSorry(QWidget *parent,
+ const QString &text,
+ const QString &details,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void detailedSorryWId(WId parent_id,
+ const QString &text,
+ const QString &details,
+ const QString &caption = QString::null,
+ int options = Notify);
+
+ /**
+ * Display an "Information" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Information").
+ * @param dontShowAgainName If provided, a checkbox is added with which
+ * further notifications can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * @param options see OptionsType
+ *
+ *
+ * Your program wants to tell the user something.
+ * To be used for things like:
+ * "Your bookmarks have been rearranged."
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The OK button will always have the i18n'ed text '&OK'.
+ */
+
+ static void information(QWidget *parent,
+ const QString &text,
+ const QString &caption = QString::null,
+ const QString &dontShowAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void informationWId(WId parent_id,
+ const QString &text,
+ const QString &caption = QString::null,
+ const QString &dontShowAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Display an "Information" dialog with a listbox.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox. If the
+ * list is empty, it doesn't show any listbox, working
+ * as information.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("Information").
+ * @param dontShowAgainName If provided, a checkbox is added with which
+ * further notifications can be turned off.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * The setting is stored in the "Notification Messages" group.
+ * @param options see OptionsType
+ *
+ *
+ * Your program wants to tell the user something.
+ * To be used for things like:
+ * "The following bookmarks have been rearranged:"
+ *
+ * The default button is "&OK". Pressing "Esc" selects the OK-button.
+ *
+ * NOTE: The OK button will always have the i18n'ed text '&OK'.
+ * @since 3.1
+ */
+
+ static void informationList(QWidget *parent,
+ const QString &text,
+ const QStringList & strlist,
+ const QString &caption = QString::null,
+ const QString &dontShowAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void informationListWId(WId parent_id,
+ const QString &text,
+ const QStringList & strlist,
+ const QString &caption = QString::null,
+ const QString &dontShowAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Enable all messages which have been turned off with the
+ * @p dontShowAgainName feature.
+ */
+ static void enableAllMessages();
+
+ /**
+ * Re-enable a specific @p dontShowAgainName messages that had
+ * previously been turned off.
+ * @see saveDontShowAgainYesNo()
+ * @see saveDontShowAgainContinue()
+ * @since 3.2
+ */
+ static void enableMessage(const QString &dontShowAgainName);
+
+ /**
+ * Display an "About" dialog.
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param text Message string.
+ * @param caption Message box title. The application name is added to
+ * the title. The default title is i18n("About \<appname\>").
+ * @param options see OptionsType
+ *
+ *
+ * Your program wants to show some general information about the application
+ * like the authors's names and email addresses.
+ *
+ * The default button is "&OK".
+ *
+ * NOTE: The ok button will always have the i18n'ed text '&OK'.
+ */
+ static void about(QWidget *parent,
+ const QString& text,
+ const QString& caption = QString::null,
+ int options = Notify);
+
+ /**
+ * Alternate method to show a messagebox:
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param type type of message box: QuestionYesNo, WarningYesNo, WarningContinueCancel...
+ * @param text Message string.
+ * @param caption Message box title.
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param dontShowAskAgainName If provided, a checkbox is added with which
+ * further questions/informations can be turned off. If turned off
+ * all questions will be automatically answered with the
+ * last answer (either Yes or No), if the message box needs an answer.
+ * The string is used to lookup and store the setting
+ * in the applications config file.
+ * @param options see OptionsType
+ * Note: for ContinueCancel, buttonYes is the continue button and buttonNo is unused.
+ * and for Information, none is used.
+ * @return a button code, as defined in KMessageBox.
+ */
+ static int messageBox( QWidget *parent, DialogType type, const QString &text,
+ const QString &caption,
+ const KGuiItem &buttonYes,
+ const KGuiItem &buttonNo,
+ const QString &dontShowAskAgainName,
+ int options = Notify);
+
+ /**
+ * Alternate method to show a messagebox:
+ *
+ * @param parent If @p parent is 0, then the message box becomes an
+ * application-global modal dialog box. If @p parent is a
+ * widget, the message box becomes modal relative to parent.
+ * @param type type of message box: QuestionYesNo, WarningYesNo, WarningContinueCancel...
+ * @param text Message string.
+ * @param caption Message box title.
+ * @param buttonYes The text for the first button.
+ * The default is i18n("&Yes").
+ * @param buttonNo The text for the second button.
+ * The default is i18n("&No").
+ * @param options see OptionsType
+ * Note: for ContinueCancel, buttonYes is the continue button and buttonNo is unused.
+ * and for Information, none is used.
+ * @return a button code, as defined in KMessageBox.
+ */
+ // KDE4 - merge with above?
+ static int messageBox( QWidget *parent, DialogType type, const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ int options = Notify);
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static int messageBoxWId( WId parent_id, DialogType type, const QString &text,
+ const QString &caption = QString::null,
+ const KGuiItem &buttonYes = KStdGuiItem::yes(),
+ const KGuiItem &buttonNo = KStdGuiItem::no(),
+ const QString &dontShowAskAgainName = QString::null,
+ int options = Notify);
+
+ /**
+ * Like messageBox
+ *
+ * Only for message boxes of type Information, Sorry or Error.
+ *
+ * This function will return immediately, the messagebox will be shown
+ * once the application enters an event loop and no other messagebox
+ * is being shown.
+ *
+ * Note that if the parent gets deleted, the messagebox will not be
+ * shown.
+ */
+ static void queuedMessageBox( QWidget *parent,
+ DialogType type, const QString &text,
+ const QString &caption,
+ int options );
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void queuedMessageBoxWId( WId parent_id,
+ DialogType type, const QString &text,
+ const QString &caption,
+ int options );
+
+ /**
+ * @overload
+ *
+ * This is an overloaded member function, provided for convenience.
+ * It behaves essentially like the above function.
+ */
+ static void queuedMessageBox( QWidget *parent,
+ DialogType type, const QString &text,
+ const QString &caption = QString::null );
+
+ /**
+ * This function accepts the window id of the parent window, instead
+ * of QWidget*. It should be used only when necessary.
+ * @since 3.2
+ */
+ static void queuedMessageBoxWId( WId parent_id,
+ DialogType type, const QString &text,
+ const QString &caption = QString::null );
+
+ /**
+ * @return true if the corresponding yes/no message box should be shown.
+ * @param dontShowAgainName the name that identify the message box. If
+ * empty, true is always returned.
+ * @param result is set to the result (Yes or No) that was chosen the last
+ * time the message box was shown. Only meaningful, if the message box
+ * should not be shown.
+ * @since 3.2
+ */
+ static bool shouldBeShownYesNo(const QString &dontShowAgainName,
+ ButtonCode &result);
+ /**
+ * @return true if the corresponding continue/cancel message box should be
+ * shown.
+ * @param dontShowAgainName the name that identify the message box. If
+ * empty, true is always returned.
+ * @since 3.2
+ */
+ static bool shouldBeShownContinue(const QString &dontShowAgainName);
+
+ /**
+ * Save the fact that the yes/no message box should not be shown again.
+ * @param dontShowAgainName the name that identify the message box. If
+ * empty, this method does nothing.
+ * @param result the value (Yes or No) that should be used as the result
+ * for the message box.
+ * @since 3.2
+ */
+ static void saveDontShowAgainYesNo(const QString &dontShowAgainName,
+ ButtonCode result);
+
+ /**
+ * Save the fact that the continue/cancel message box should not be shown
+ * again.
+ * @param dontShowAgainName the name that identify the message box. If
+ * empty, this method does nothing.
+ * @since 3.2
+ */
+ static void saveDontShowAgainContinue(const QString &dontShowAgainName);
+
+ /**
+ * Use @p cfg for all settings related to the dontShowAgainName feature.
+ * If @p cfg is 0 (default) KGlobal::config() will be used.
+ * @since 3.2
+ */
+ static void setDontShowAskAgainConfig(KConfig* cfg);
+
+ /**
+ * Create content and layout of a standard dialog
+ *
+ * @param dialog The parent dialog base
+ * @param icon Which predefined icon the message box shall show.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox.
+ * If the list is empty, it doesn't show any listbox
+ * @param ask The text of the checkbox. If empty none will be shown.
+ * @param checkboxReturn The result of the checkbox. If it's initially
+ * true then the checkbox will be checked by default.
+ * @param options see OptionsType
+ * @param details Detailed message string.
+ * @since 3.3
+ * @return A KDialogBase button code, not a KMessageBox button code,
+ * based on the buttonmask given to the constructor of the
+ * @p dialog (ie. will return KDialogBase::Yes [256] instead of
+ * KMessageBox::Yes [3]). Will return KMessageBox::Cancel
+ * if the message box is queued for display instead of
+ * exec()ed immediately or if the option NoExec is set.
+ * @note The @p dialog that is passed in is deleted by this
+ * function. Do not delete it yourself.
+ */
+ static int createKMessageBox(KDialogBase *dialog, QMessageBox::Icon icon,
+ const QString &text, const QStringList &strlist,
+ const QString &ask, bool *checkboxReturn,
+ int options, const QString &details=QString::null);
+
+ /**
+ * Create content and layout of a standard dialog
+ *
+ * @param dialog The parent dialog base
+ * @param icon A QPixmap containing the icon to be displayed in the
+ * dialog next to the text.
+ * @param text Message string.
+ * @param strlist List of strings to be written in the listbox.
+ * If the list is empty, it doesn't show any listbox
+ * @param ask The text of the checkbox. If empty none will be shown.
+ * @param checkboxReturn The result of the checkbox. If it's initially
+ * true then the checkbox will be checked by default.
+ * @param options see OptionsType
+ * @param details Detailed message string.
+ * @param notifyType The type of notification to send when this message
+ * is presentend.
+ * @since 3.3
+ * @return A KDialogBase button code, not a KMessageBox button code,
+ * based on the buttonmask given to the constructor of the
+ * @p dialog (ie. will return KDialogBase::Yes [256] instead of
+ * KMessageBox::Yes [3]). Will return KMessageBox::Cancel
+ * if the message box is queued for display instead of
+ * exec()ed immediately or if the option NoExec is set.
+ * @note The @p dialog that is passed in is deleted by this
+ * function. Do not delete it yourself.
+ */
+ static int createKMessageBox(KDialogBase *dialog, QPixmap icon,
+ const QString &text, const QStringList &strlist,
+ const QString &ask, bool *checkboxReturn,
+ int options, const QString &details=QString::null,
+ QMessageBox::Icon notifyType=QMessageBox::Information);
+
+private:
+ static KConfig* againConfig;
+};
+
+#endif