[libcalamaresui] Remove *back* button from ViewManager

- Now the back button should be done by clients as well
- Refactor in CalamaresWindow to avoid leaking local button pointers
  to surrounding code.
- Add macro UPDATE_BUTTON_PROPERTY for convenience in ViewManager
  (ugh, macro) to change a value and emit corresponding update signal.
This commit is contained in:
Adriaan de Groot 2020-04-02 12:31:14 +02:00
parent 8920be6bca
commit 38deb66e42
3 changed files with 75 additions and 49 deletions

View File

@ -164,28 +164,39 @@ QWidget*
CalamaresWindow::getWidgetNavigation() CalamaresWindow::getWidgetNavigation()
{ {
QWidget* navigation = new QWidget( this ); QWidget* navigation = new QWidget( this );
QBoxLayout* bottomLayout = new QHBoxLayout;
bottomLayout->addStretch();
// Create buttons and sets an initial icon; the icons may change // Create buttons and sets an initial icon; the icons may change
{
auto* back = new QPushButton( getButtonIcon( QStringLiteral( "go-previous" ) ), tr( "&Back" ), navigation ); auto* back = new QPushButton( getButtonIcon( QStringLiteral( "go-previous" ) ), tr( "&Back" ), navigation );
back->setObjectName( "view-button-back" ); back->setObjectName( "view-button-back" );
connect( back, &QPushButton::clicked, m_viewManager, &Calamares::ViewManager::back ); connect( back, &QPushButton::clicked, m_viewManager, &Calamares::ViewManager::back );
connect( m_viewManager, &Calamares::ViewManager::backEnabledChanged, back, &QPushButton::setEnabled );
connect( m_viewManager, &Calamares::ViewManager::backLabelChanged, back, &QPushButton::setText );
connect( m_viewManager, &Calamares::ViewManager::backIconChanged, this, [=]( QString n ) {
setButtonIcon( back, n );
} );
bottomLayout->addWidget( back );
}
{
auto* next = new QPushButton( getButtonIcon( QStringLiteral( "go-next" ) ), tr( "&Next" ), navigation ); auto* next = new QPushButton( getButtonIcon( QStringLiteral( "go-next" ) ), tr( "&Next" ), navigation );
next->setObjectName( "view-button-next" ); next->setObjectName( "view-button-next" );
connect( next, &QPushButton::clicked, m_viewManager, &Calamares::ViewManager::next ); connect( next, &QPushButton::clicked, m_viewManager, &Calamares::ViewManager::next );
connect( m_viewManager, &Calamares::ViewManager::nextEnabledChanged, next, &QPushButton::setEnabled ); connect( m_viewManager, &Calamares::ViewManager::nextEnabledChanged, next, &QPushButton::setEnabled );
connect( m_viewManager, &Calamares::ViewManager::nextLabelChanged, next, &QPushButton::setText ); connect( m_viewManager, &Calamares::ViewManager::nextLabelChanged, next, &QPushButton::setText );
connect( connect( m_viewManager, &Calamares::ViewManager::nextIconChanged, this, [=]( QString n ) {
m_viewManager, &Calamares::ViewManager::nextIconChanged, this, [=]( QString n ) { setButtonIcon( next, n ); } ); setButtonIcon( next, n );
} );
bottomLayout->addWidget( next );
}
bottomLayout->addSpacing( 12 );
{
auto* quit = new QPushButton( getButtonIcon( QStringLiteral( "dialog-cancel" ) ), tr( "&Cancel" ), navigation ); auto* quit = new QPushButton( getButtonIcon( QStringLiteral( "dialog-cancel" ) ), tr( "&Cancel" ), navigation );
quit->setObjectName( "view-button-cancel" ); quit->setObjectName( "view-button-cancel" );
connect( quit, &QPushButton::clicked, m_viewManager, &Calamares::ViewManager::quit ); connect( quit, &QPushButton::clicked, m_viewManager, &Calamares::ViewManager::quit );
QBoxLayout* bottomLayout = new QHBoxLayout;
bottomLayout->addStretch();
bottomLayout->addWidget( back );
bottomLayout->addWidget( next );
bottomLayout->addSpacing( 12 );
bottomLayout->addWidget( quit ); bottomLayout->addWidget( quit );
}
navigation->setLayout( bottomLayout ); navigation->setLayout( bottomLayout );
return navigation; return navigation;

View File

@ -38,6 +38,12 @@
#include <QMessageBox> #include <QMessageBox>
#include <QMetaObject> #include <QMetaObject>
#define UPDATE_BUTTON_PROPERTY( name, value ) \
{ \
m_##name = value; \
emit name##Changed( m_##name ); \
}
namespace Calamares namespace Calamares
{ {
@ -89,8 +95,6 @@ ViewManager::ViewManager( QObject* parent )
mainLayout->addWidget( m_stack ); mainLayout->addWidget( m_stack );
// Create buttons and sets an initial icon; the icons may change // Create buttons and sets an initial icon; the icons may change
m_back = new QPushButton( getButtonIcon( QStringLiteral( "go-previous" ) ), tr( "&Back" ), m_widget );
m_back->setObjectName( "view-button-back" );
m_quit = new QPushButton( getButtonIcon( QStringLiteral( "dialog-cancel" ) ), tr( "&Cancel" ), m_widget ); m_quit = new QPushButton( getButtonIcon( QStringLiteral( "dialog-cancel" ) ), tr( "&Cancel" ), m_widget );
m_quit->setObjectName( "view-button-cancel" ); m_quit->setObjectName( "view-button-cancel" );
@ -99,13 +103,9 @@ ViewManager::ViewManager( QObject* parent )
QBoxLayout* bottomLayout = new QHBoxLayout; QBoxLayout* bottomLayout = new QHBoxLayout;
mainLayout->addLayout( bottomLayout ); mainLayout->addLayout( bottomLayout );
bottomLayout->addStretch(); bottomLayout->addStretch();
bottomLayout->addWidget( m_back );
bottomLayout->addSpacing( 12 );
bottomLayout->addWidget( m_quit ); bottomLayout->addWidget( m_quit );
connect( m_back, &QPushButton::clicked, this, &ViewManager::back );
connect( m_quit, &QPushButton::clicked, this, &ViewManager::quit ); connect( m_quit, &QPushButton::clicked, this, &ViewManager::quit );
m_back->setEnabled( false );
connect( JobQueue::instance(), &JobQueue::failed, this, &ViewManager::onInstallationFailed ); connect( JobQueue::instance(), &JobQueue::failed, this, &ViewManager::onInstallationFailed );
connect( JobQueue::instance(), &JobQueue::finished, this, &ViewManager::next ); connect( JobQueue::instance(), &JobQueue::finished, this, &ViewManager::next );
@ -363,9 +363,8 @@ ViewManager::next()
{ {
// Reached the end in a weird state (e.g. no finished step after an exec) // Reached the end in a weird state (e.g. no finished step after an exec)
executing = false; executing = false;
m_nextEnabled = false; UPDATE_BUTTON_PROPERTY( nextEnabled, false )
emit nextEnabledChanged( m_nextEnabled ); UPDATE_BUTTON_PROPERTY( backEnabled, false )
m_back->setEnabled( false );
} }
updateCancelEnabled( !settings->disableCancel() && !( executing && settings->disableCancelDuringExec() ) ); updateCancelEnabled( !settings->disableCancel() && !( executing && settings->disableCancelDuringExec() ) );
} }
@ -376,9 +375,8 @@ ViewManager::next()
if ( m_currentStep < m_steps.count() ) if ( m_currentStep < m_steps.count() )
{ {
m_nextEnabled = !executing && m_steps.at( m_currentStep )->isNextEnabled(); UPDATE_BUTTON_PROPERTY( nextEnabled, !executing && m_steps.at( m_currentStep )->isNextEnabled() )
emit nextEnabledChanged( m_nextEnabled ); UPDATE_BUTTON_PROPERTY( backEnabled, !executing && m_steps.at( m_currentStep )->isBackEnabled() )
m_back->setEnabled( !executing && m_steps.at( m_currentStep )->isBackEnabled() );
} }
updateButtonLabels(); updateButtonLabels();
@ -400,21 +398,17 @@ ViewManager::updateButtonLabels()
// If we're going into the execution step / install phase, other message // If we're going into the execution step / install phase, other message
if ( stepIsExecute( m_steps, m_currentStep + 1 ) ) if ( stepIsExecute( m_steps, m_currentStep + 1 ) )
{ {
m_nextLabel = nextIsInstallationStep; UPDATE_BUTTON_PROPERTY( nextLabel, nextIsInstallationStep )
m_nextIcon = "run-install"; UPDATE_BUTTON_PROPERTY( nextIcon, "run-install" )
emit nextLabelChanged( m_nextLabel );
emit nextIconChanged( m_nextIcon );
} }
else else
{ {
m_nextLabel = tr( "&Next" ); UPDATE_BUTTON_PROPERTY( nextLabel, tr( "&Next" ) )
m_nextIcon = "go-next"; UPDATE_BUTTON_PROPERTY( nextIcon, "go-next" )
emit nextLabelChanged( m_nextLabel );
emit nextIconChanged( m_nextIcon );
} }
// Going back is always simple // Going back is always simple
m_back->setText( tr( "&Back" ) ); UPDATE_BUTTON_PROPERTY( backLabel, tr( "&Back" ) )
// Cancel button changes label at the end // Cancel button changes label at the end
if ( isAtVeryEnd( m_steps, m_currentStep ) ) if ( isAtVeryEnd( m_steps, m_currentStep ) )
@ -465,14 +459,11 @@ ViewManager::back()
return; return;
} }
m_nextEnabled = m_steps.at( m_currentStep )->isNextEnabled(); UPDATE_BUTTON_PROPERTY( nextEnabled, m_steps.at( m_currentStep )->isNextEnabled() )
emit nextEnabledChanged( m_nextEnabled ); UPDATE_BUTTON_PROPERTY( backEnabled,
m_back->setEnabled( m_steps.at( m_currentStep )->isBackEnabled() ); ( m_currentStep == 0 && m_steps.first()->isAtBeginning() )
? false
if ( m_currentStep == 0 && m_steps.first()->isAtBeginning() ) : m_steps.at( m_currentStep )->isBackEnabled() )
{
m_back->setEnabled( false );
}
updateButtonLabels(); updateButtonLabels();
} }

View File

@ -38,10 +38,15 @@ class UIDLLEXPORT ViewManager : public QAbstractListModel
{ {
Q_OBJECT Q_OBJECT
Q_PROPERTY( int currentStepIndex READ currentStepIndex NOTIFY currentStepChanged FINAL ) Q_PROPERTY( int currentStepIndex READ currentStepIndex NOTIFY currentStepChanged FINAL )
Q_PROPERTY( bool nextEnabled READ nextEnabled NOTIFY nextEnabledChanged FINAL ) Q_PROPERTY( bool nextEnabled READ nextEnabled NOTIFY nextEnabledChanged FINAL )
Q_PROPERTY( QString nextLabel READ nextLabel NOTIFY nextLabelChanged FINAL ) Q_PROPERTY( QString nextLabel READ nextLabel NOTIFY nextLabelChanged FINAL )
Q_PROPERTY( QString nextIcon READ nextIcon NOTIFY nextIconChanged FINAL ) Q_PROPERTY( QString nextIcon READ nextIcon NOTIFY nextIconChanged FINAL )
Q_PROPERTY( bool backEnabled READ backEnabled NOTIFY backEnabledChanged FINAL )
Q_PROPERTY( QString backLabel READ backLabel NOTIFY backLabelChanged FINAL )
Q_PROPERTY( QString backIcon READ backIcon NOTIFY backIconChanged FINAL )
public: public:
/** /**
* @brief instance access to the ViewManager singleton. * @brief instance access to the ViewManager singleton.
@ -121,6 +126,18 @@ public Q_SLOTS:
* have any pages before the current one. * have any pages before the current one.
*/ */
void back(); void back();
bool backEnabled() const
{
return m_backEnabled; ///< Is the back-button to be enabled
}
QString backLabel() const
{
return m_backLabel; ///< What should be displayed on the back-button
}
QString backIcon() const
{
return m_backIcon; ///< Name of the icon to show
}
/** /**
* @brief Probably quit * @brief Probably quit
@ -152,6 +169,10 @@ signals:
void nextLabelChanged( QString ) const; void nextLabelChanged( QString ) const;
void nextIconChanged( QString ) const; void nextIconChanged( QString ) const;
void backEnabledChanged( bool ) const;
void backLabelChanged( QString ) const;
void backIconChanged( QString ) const;
private: private:
explicit ViewManager( QObject* parent = nullptr ); explicit ViewManager( QObject* parent = nullptr );
virtual ~ViewManager() override; virtual ~ViewManager() override;
@ -167,13 +188,16 @@ private:
QWidget* m_widget; QWidget* m_widget;
QStackedWidget* m_stack; QStackedWidget* m_stack;
QPushButton* m_back;
QPushButton* m_quit; QPushButton* m_quit;
bool m_nextEnabled = false; bool m_nextEnabled = false;
QString m_nextLabel; QString m_nextLabel;
QString m_nextIcon; ///< Name of icon to show on button QString m_nextIcon; ///< Name of icon to show on button
bool m_backEnabled = false;
QString m_backLabel;
QString m_backIcon;
public: public:
/** @section Model /** @section Model
* *