libcalamaresui: deal with QMessageBox::question

This commit is contained in:
Adriaan de Groot 2023-09-03 21:54:08 +02:00
parent 159eccbda0
commit 8ea7c578b3

View File

@ -287,6 +287,37 @@ isAtVeryEnd( const ViewStepList& steps, int index )
return ( index >= steps.count() ) || ( index == steps.count() - 1 && steps.last()->isAtEnd() ); return ( index >= steps.count() ) || ( index == steps.count() - 1 && steps.last()->isAtEnd() );
} }
static int
questionBox( QWidget* parent,
const QString& title,
const QString& question,
const QString& button0,
const QString& button1 )
{
#if QT_VERSION >= QT_VERSION_CHECK( 6, 0, 0 )
QMessageBox mb( QMessageBox::Question, title, question, QMessageBox::StandardButton::NoButton, parent );
const auto* const okButton = mb.addButton( button0, QMessageBox::AcceptRole );
mb.addButton( button1, QMessageBox::RejectRole );
mb.exec();
if ( mb.clickedButton() == okButton )
{
return 0;
}
return 1; // Cancel
#else
return QMessageBox::question( parent,
title,
question,
button0,
button1,
QString(),
0 /* default first button, i.e. confirm */,
1 /* escape is second button, i.e. cancel */ );
#endif
}
void void
ViewManager::next() ViewManager::next()
{ {
@ -318,15 +349,11 @@ ViewManager::next()
QString confirm = settings->isSetupMode() ? tr( "&Set up now" ) : tr( "&Install now" ); QString confirm = settings->isSetupMode() ? tr( "&Set up now" ) : tr( "&Install now" );
const auto* branding = Calamares::Branding::instance(); const auto* branding = Calamares::Branding::instance();
int reply int reply = questionBox( m_widget,
= QMessageBox::question( m_widget, title,
title, question.arg( branding->shortProductName(), branding->shortVersionedName() ),
question.arg( branding->shortProductName(), branding->shortVersionedName() ), confirm,
confirm, tr( "Go &back" ) );
tr( "Go &back" ),
QString(),
0 /* default first button, i.e. confirm */,
1 /* escape is second button, i.e. cancel */ );
if ( reply == 1 ) if ( reply == 1 )
{ {
return; return;
@ -548,7 +575,7 @@ ViewManager::data( const QModelIndex& index, int role ) const
// we must be in debug-mode (-d) so presumably it // we must be in debug-mode (-d) so presumably it
// is a distro-developer or Calamares-developer // is a distro-developer or Calamares-developer
// running it, and we don't need translation for them. // running it, and we don't need translation for them.
QString toolTip( "<b>Debug information</b>" ); // Intentionally no translation here QString toolTip( "<b>Debug information</b>" ); // Intentionally no translation here
toolTip.append( "<br/>Type:\tViewStep" ); toolTip.append( "<br/>Type:\tViewStep" );
toolTip.append( QString( "<br/>Pretty:\t%1" ).arg( step->prettyName() ) ); toolTip.append( QString( "<br/>Pretty:\t%1" ).arg( step->prettyName() ) );
toolTip.append( QString( "<br/>Status:\t%1" ).arg( step->prettyStatus() ) ); toolTip.append( QString( "<br/>Status:\t%1" ).arg( step->prettyStatus() ) );