From 958aee1d41ad58997056cd0c784d816c998d6334 Mon Sep 17 00:00:00 2001 From: Adriaan de Groot Date: Tue, 13 Feb 2018 08:11:11 -0500 Subject: [PATCH] [libcalamaresui] Switch text on 'next' button - If the next step will be an install-step (e.g. hit the optional confirmation step) then change the text on the 'next' button to 'install'. - Do a little refactoring to make that more pleasant. FIXES #905 --- src/libcalamaresui/ViewManager.cpp | 36 ++++++++++++++++++++---------- src/libcalamaresui/ViewManager.h | 1 + 2 files changed, 25 insertions(+), 12 deletions(-) diff --git a/src/libcalamaresui/ViewManager.cpp b/src/libcalamaresui/ViewManager.cpp index 645be4371..2be3e3832 100644 --- a/src/libcalamaresui/ViewManager.cpp +++ b/src/libcalamaresui/ViewManager.cpp @@ -192,6 +192,11 @@ ViewManager::currentStepIndex() const return m_currentStep; } +static inline bool +stepNextWillExecute(const ViewStepList& steps, int index) +{ + return ( index + 1 < steps.count() ) && qobject_cast< ExecutionViewStep* >( steps.at( index + 1 ) ); +} void ViewManager::next() @@ -203,9 +208,7 @@ ViewManager::next() // Special case when the user clicks next on the very last page in a view phase // and right before switching to an execution phase. // Depending on Calamares::Settings, we show an "are you sure" prompt or not. - if ( Calamares::Settings::instance()->showPromptBeforeExecution() && - m_currentStep + 1 < m_steps.count() && - qobject_cast< ExecutionViewStep* >( m_steps.at( m_currentStep + 1 ) ) ) + if ( Calamares::Settings::instance()->showPromptBeforeExecution() && stepNextWillExecute( m_steps, m_currentStep ) ) { int reply = QMessageBox::question( m_widget, @@ -242,15 +245,29 @@ ViewManager::next() m_next->setEnabled( !executing && m_steps.at( m_currentStep )->isNextEnabled() ); m_back->setEnabled( !executing && m_steps.at( m_currentStep )->isBackEnabled() ); - if ( m_currentStep == m_steps.count() -1 && - m_steps.last()->isAtEnd() ) + updateButtonLabels(); +} + +void +ViewManager::updateButtonLabels() +{ + if ( stepNextWillExecute( m_steps, m_currentStep ) ) + m_next->setText( tr( "&Install" ) ); + else + m_next->setText( tr( "&Next" ) ); + + if ( m_currentStep == m_steps.count() -1 && m_steps.last()->isAtEnd() ) { m_quit->setText( tr( "&Done" ) ); m_quit->setToolTip( tr( "The installation is complete. Close the installer." ) ); } + else + { + m_quit->setText( tr( "&Cancel" ) ); + m_quit->setToolTip( tr( "Cancel installation without changing the system." ) ); + } } - void ViewManager::back() { @@ -273,12 +290,7 @@ ViewManager::back() if ( m_currentStep == 0 && m_steps.first()->isAtBeginning() ) m_back->setEnabled( false ); - if ( !( m_currentStep == m_steps.count() -1 && - m_steps.last()->isAtEnd() ) ) - { - m_quit->setText( tr( "&Cancel" ) ); - m_quit->setToolTip( tr( "Cancel installation without changing the system." ) ); - } + updateButtonLabels(); } bool ViewManager::confirmCancelInstallation() diff --git a/src/libcalamaresui/ViewManager.h b/src/libcalamaresui/ViewManager.h index 2e7e4df84..e4f215f8f 100644 --- a/src/libcalamaresui/ViewManager.h +++ b/src/libcalamaresui/ViewManager.h @@ -126,6 +126,7 @@ private: virtual ~ViewManager() override; void insertViewStep( int before, ViewStep* step ); + void updateButtonLabels(); static ViewManager* s_instance;