155 lines
5.2 KiB
C++
155 lines
5.2 KiB
C++
// SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
/**************************************************************************
|
|
**
|
|
** This file is part of Qt Creator
|
|
**
|
|
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
|
|
**
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
|
**
|
|
** Commercial Usage
|
|
**
|
|
** Licensees holding valid Qt Commercial licenses may use this file in
|
|
** accordance with the Qt Commercial License Agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and Nokia.
|
|
**
|
|
** GNU Lesser General Public License Usage
|
|
**
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
** General Public License version 2.1 as published by the Free Software
|
|
** Foundation and appearing in the file LICENSE.LGPL included in the
|
|
** packaging of this file. Please review the following information to
|
|
** ensure the GNU Lesser General Public License version 2.1 requirements
|
|
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
|
**
|
|
** If you are unsure which license is appropriate for your use, please
|
|
** contact the sales department at http://qt.nokia.com/contact.
|
|
**
|
|
**************************************************************************/
|
|
|
|
#ifndef CHECKABLEMESSAGEBOX_H
|
|
#define CHECKABLEMESSAGEBOX_H
|
|
|
|
#include <QDialog>
|
|
#include <QDialogButtonBox>
|
|
#include <QMessageBox>
|
|
#include <FCGlobal.h>
|
|
|
|
namespace Gui
|
|
{
|
|
namespace Dialog
|
|
{
|
|
|
|
struct DlgCheckableMessageBoxPrivate;
|
|
|
|
/* A messagebox suitable for questions with a
|
|
* "Do not ask me again" checkbox. Emulates the QMessageBox API with
|
|
* static conveniences. */
|
|
|
|
class GuiExport DlgCheckableMessageBox: public QDialog
|
|
{
|
|
Q_OBJECT
|
|
Q_PROPERTY(QString text READ text WRITE setText) // clazy:exclude=qproperty-without-notify
|
|
Q_PROPERTY(
|
|
QPixmap iconPixmap READ iconPixmap WRITE setIconPixmap
|
|
) // clazy:exclude=qproperty-without-notify
|
|
Q_PROPERTY(bool isChecked READ isChecked WRITE setChecked) // clazy:exclude=qproperty-without-notify
|
|
// Q_PROPERTY(QString prefEntry WRITE setPrefEntry) // Must have a READ accessor!
|
|
Q_PROPERTY(
|
|
QString checkBoxText READ checkBoxText WRITE setCheckBoxText
|
|
) // clazy:exclude=qproperty-without-notify
|
|
Q_PROPERTY(
|
|
QDialogButtonBox::StandardButtons buttons READ standardButtons WRITE setStandardButtons
|
|
) // clazy:exclude=qproperty-without-notify
|
|
Q_PROPERTY(
|
|
QDialogButtonBox::StandardButton defaultButton READ defaultButton WRITE setDefaultButton
|
|
) // clazy:exclude=qproperty-without-notify
|
|
public:
|
|
explicit DlgCheckableMessageBox(QWidget* parent);
|
|
~DlgCheckableMessageBox() override;
|
|
|
|
static QDialogButtonBox::StandardButton question(
|
|
QWidget* parent,
|
|
const QString& title,
|
|
const QString& question,
|
|
const QString& checkBoxText,
|
|
bool* checkBoxSetting,
|
|
QDialogButtonBox::StandardButtons buttons = QDialogButtonBox::Yes | QDialogButtonBox::No,
|
|
QDialogButtonBox::StandardButton defaultButton = QDialogButtonBox::No
|
|
);
|
|
|
|
QString text() const;
|
|
void setText(const QString&);
|
|
|
|
void setPrefEntry(const QString& entry);
|
|
|
|
void setPrefPath(const QString& path);
|
|
|
|
void accept() override;
|
|
void reject() override;
|
|
|
|
bool isChecked() const;
|
|
void setChecked(bool s);
|
|
|
|
QString checkBoxText() const;
|
|
void setCheckBoxText(const QString&);
|
|
|
|
QDialogButtonBox::StandardButtons standardButtons() const;
|
|
void setStandardButtons(QDialogButtonBox::StandardButtons s);
|
|
|
|
QDialogButtonBox::StandardButton defaultButton() const;
|
|
void setDefaultButton(QDialogButtonBox::StandardButton s);
|
|
|
|
// see static QMessageBox::standardPixmap()
|
|
QPixmap iconPixmap() const;
|
|
void setIconPixmap(const QPixmap& p);
|
|
|
|
// Query the result
|
|
QAbstractButton* clickedButton() const;
|
|
QDialogButtonBox::StandardButton clickedStandardButton() const;
|
|
|
|
// Conversion convenience
|
|
static QMessageBox::StandardButton dialogButtonBoxToMessageBoxButton(
|
|
QDialogButtonBox::StandardButton
|
|
);
|
|
|
|
/// convenient show method
|
|
/// It shows a dialog with header and message provided and a checkbox in check state with the
|
|
/// message provided. It uses a parameter in path "User parameter:BaseApp/CheckMessages" derived
|
|
/// from the header test, defaulting to false, to store the status of the checkbox, when the
|
|
/// user exits the modal dialog.
|
|
static void showMessage(
|
|
const QString& header,
|
|
const QString& message,
|
|
bool check = false,
|
|
const QString& checkText = tr("Don't show me again")
|
|
);
|
|
|
|
/// Same as showMessage above, but it checks the specific preference path and parameter
|
|
/// provided, defaulting to entryDefault value if the parameter is not present.
|
|
static void showMessage(
|
|
const QString& header,
|
|
const QString& message,
|
|
const QString& prefPath,
|
|
const QString& paramEntry,
|
|
bool entryDefault = false,
|
|
bool check = false,
|
|
const QString& checkText = QStringLiteral("Don't show me again")
|
|
);
|
|
|
|
private Q_SLOTS:
|
|
void slotClicked(QAbstractButton* b);
|
|
|
|
private:
|
|
DlgCheckableMessageBoxPrivate* m_d;
|
|
QByteArray paramEntry;
|
|
QString prefPath;
|
|
};
|
|
|
|
} // namespace Dialog
|
|
} // namespace Gui
|
|
|
|
#endif // CHECKABLEMESSAGEBOX_H
|