QMessageBox - move informative+details text to new layout function
Controlling the layout from different functions is not easy, so lets move it to the setupLayout function. Change-Id: I3120a2e98b2f8425befa135595d4ad7ce1b8ca56 Reviewed-by: J-P Nurmi <jpnurmi@digia.com>
This commit is contained in:
parent
77e8ff66f0
commit
f73518e732
@ -302,10 +302,16 @@ void QMessageBoxPrivate::setupLayout()
|
|||||||
QGridLayout *grid = new QGridLayout;
|
QGridLayout *grid = new QGridLayout;
|
||||||
grid->addWidget(iconLabel, 0, 0, 2, 1, Qt::AlignTop);
|
grid->addWidget(iconLabel, 0, 0, 2, 1, Qt::AlignTop);
|
||||||
grid->addWidget(label, 0, 1, 1, 1);
|
grid->addWidget(label, 0, 1, 1, 1);
|
||||||
|
if (informativeLabel)
|
||||||
|
grid->addWidget(informativeLabel, 1, 1, 1, 1);
|
||||||
#ifndef Q_OS_MAC
|
#ifndef Q_OS_MAC
|
||||||
grid->addWidget(buttonBox, 2, 0, 1, 2);
|
grid->addWidget(buttonBox, 2, 0, 1, 2);
|
||||||
#else
|
#else
|
||||||
grid->addWidget(buttonBox, 3, 1, 1, 1);
|
grid->addWidget(buttonBox, 3, 1, 1, 1);
|
||||||
|
#endif
|
||||||
|
if (detailsText)
|
||||||
|
grid->addWidget(detailsText, grid->rowCount(), 0, 1, grid->columnCount());
|
||||||
|
#ifdef Q_OS_MAC
|
||||||
grid->setMargin(0);
|
grid->setMargin(0);
|
||||||
grid->setVerticalSpacing(8);
|
grid->setVerticalSpacing(8);
|
||||||
grid->setHorizontalSpacing(0);
|
grid->setHorizontalSpacing(0);
|
||||||
@ -318,6 +324,7 @@ void QMessageBoxPrivate::setupLayout()
|
|||||||
q->setLayout(grid);
|
q->setLayout(grid);
|
||||||
|
|
||||||
retranslateStrings();
|
retranslateStrings();
|
||||||
|
updateSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
int QMessageBoxPrivate::layoutMinimumWidth()
|
int QMessageBoxPrivate::layoutMinimumWidth()
|
||||||
@ -2460,24 +2467,27 @@ void QMessageBox::setDetailedText(const QString &text)
|
|||||||
{
|
{
|
||||||
Q_D(QMessageBox);
|
Q_D(QMessageBox);
|
||||||
if (text.isEmpty()) {
|
if (text.isEmpty()) {
|
||||||
delete d->detailsText;
|
if (d->detailsText) {
|
||||||
|
d->detailsText->hide();
|
||||||
|
d->detailsText->deleteLater();
|
||||||
|
}
|
||||||
d->detailsText = 0;
|
d->detailsText = 0;
|
||||||
removeButton(d->detailsButton);
|
removeButton(d->detailsButton);
|
||||||
delete d->detailsButton;
|
if (d->detailsButton) {
|
||||||
|
d->detailsButton->hide();
|
||||||
|
d->detailsButton->deleteLater();
|
||||||
|
}
|
||||||
d->detailsButton = 0;
|
d->detailsButton = 0;
|
||||||
return;
|
} else {
|
||||||
|
if (!d->detailsText) {
|
||||||
|
d->detailsText = new QMessageBoxDetailsText(this);
|
||||||
|
d->detailsText->hide();
|
||||||
|
}
|
||||||
|
if (!d->detailsButton)
|
||||||
|
d->detailsButton = new DetailButton(this);
|
||||||
|
d->detailsText->setText(text);
|
||||||
}
|
}
|
||||||
|
d->setupLayout();
|
||||||
if (!d->detailsText) {
|
|
||||||
d->detailsText = new QMessageBoxDetailsText(this);
|
|
||||||
QGridLayout* grid = qobject_cast<QGridLayout*>(layout());
|
|
||||||
if (grid)
|
|
||||||
grid->addWidget(d->detailsText, grid->rowCount(), 0, 1, grid->columnCount());
|
|
||||||
d->detailsText->hide();
|
|
||||||
}
|
|
||||||
if (!d->detailsButton)
|
|
||||||
d->detailsButton = new DetailButton(this);
|
|
||||||
d->detailsText->setText(text);
|
|
||||||
}
|
}
|
||||||
#endif // QT_NO_TEXTEDIT
|
#endif // QT_NO_TEXTEDIT
|
||||||
|
|
||||||
@ -2508,39 +2518,37 @@ void QMessageBox::setInformativeText(const QString &text)
|
|||||||
{
|
{
|
||||||
Q_D(QMessageBox);
|
Q_D(QMessageBox);
|
||||||
if (text.isEmpty()) {
|
if (text.isEmpty()) {
|
||||||
layout()->removeWidget(d->informativeLabel);
|
if (d->informativeLabel) {
|
||||||
delete d->informativeLabel;
|
d->informativeLabel->hide();
|
||||||
|
d->informativeLabel->deleteLater();
|
||||||
|
}
|
||||||
d->informativeLabel = 0;
|
d->informativeLabel = 0;
|
||||||
#ifndef Q_OS_MAC
|
#ifndef Q_OS_MAC
|
||||||
d->label->setContentsMargins(2, 0, 0, 0);
|
d->label->setContentsMargins(2, 0, 0, 0);
|
||||||
#endif
|
#endif
|
||||||
d->updateSize();
|
} else {
|
||||||
return;
|
if (!d->informativeLabel) {
|
||||||
}
|
QLabel *label = new QLabel;
|
||||||
|
label->setObjectName(QLatin1String("qt_msgbox_informativelabel"));
|
||||||
if (!d->informativeLabel) {
|
label->setTextInteractionFlags(Qt::TextInteractionFlags(style()->styleHint(QStyle::SH_MessageBox_TextInteractionFlags, 0, this)));
|
||||||
QLabel *label = new QLabel;
|
label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
|
||||||
label->setObjectName(QLatin1String("qt_msgbox_informativelabel"));
|
label->setOpenExternalLinks(true);
|
||||||
label->setTextInteractionFlags(Qt::TextInteractionFlags(style()->styleHint(QStyle::SH_MessageBox_TextInteractionFlags, 0, this)));
|
label->setWordWrap(true);
|
||||||
label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
|
|
||||||
label->setOpenExternalLinks(true);
|
|
||||||
label->setWordWrap(true);
|
|
||||||
#ifndef Q_OS_MAC
|
#ifndef Q_OS_MAC
|
||||||
d->label->setContentsMargins(2, 0, 0, 0);
|
d->label->setContentsMargins(2, 0, 0, 0);
|
||||||
label->setContentsMargins(2, 0, 0, 6);
|
label->setContentsMargins(2, 0, 0, 6);
|
||||||
label->setIndent(9);
|
label->setIndent(9);
|
||||||
#else
|
#else
|
||||||
label->setContentsMargins(16, 0, 0, 0);
|
label->setContentsMargins(16, 0, 0, 0);
|
||||||
// apply a smaller font the information label on the mac
|
// apply a smaller font the information label on the mac
|
||||||
label->setFont(qt_app_fonts_hash()->value("QTipLabel"));
|
label->setFont(qt_app_fonts_hash()->value("QTipLabel"));
|
||||||
#endif
|
#endif
|
||||||
label->setWordWrap(true);
|
label->setWordWrap(true);
|
||||||
QGridLayout *grid = static_cast<QGridLayout *>(layout());
|
d->informativeLabel = label;
|
||||||
grid->addWidget(label, 1, 1, 1, 1);
|
}
|
||||||
d->informativeLabel = label;
|
d->informativeLabel->setText(text);
|
||||||
}
|
}
|
||||||
d->informativeLabel->setText(text);
|
d->setupLayout();
|
||||||
d->updateSize();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
Loading…
Reference in New Issue
Block a user