Merge branch 'polish-dont-cancel'

This commit is contained in:
Adriaan de Groot 2019-04-21 23:41:52 +02:00
commit 455d106163
5 changed files with 31 additions and 15 deletions

View File

@ -22,6 +22,8 @@ This release contains contributions from (alphabetically by first name):
* Under-the-hood code cleanups in lots of parts of the core. Calamares now * Under-the-hood code cleanups in lots of parts of the core. Calamares now
builds without warnings when Clang 8 is used. builds without warnings when Clang 8 is used.
* A new *disable-cancel-during-exec* setting provides more fine-grained
control than *disable-cancel* (which hides the button entirely).
## Modules ## ## Modules ##

View File

@ -154,7 +154,9 @@ dont-chroot: false
# Calamares will complain if this is not explicitly set. # Calamares will complain if this is not explicitly set.
# oem-setup: true # oem-setup: true
# If this is set to true, the "Cancel" button will be disabled. # If this is set to true, the "Cancel" button will be disabled entirely.
# The button is also hidden from view.
#
# This can be useful if when e.g. Calamares is used as a post-install # This can be useful if when e.g. Calamares is used as a post-install
# configuration tool and you require the user to go through all the # configuration tool and you require the user to go through all the
# configuration steps. # configuration steps.
@ -167,4 +169,8 @@ disable-cancel: false
# If this is set to true, the "Cancel" button will be disabled once # If this is set to true, the "Cancel" button will be disabled once
# you start the 'Installation', meaning there won't be a way to cancel # you start the 'Installation', meaning there won't be a way to cancel
# the Installation until it has finished or installation has failed. # the Installation until it has finished or installation has failed.
dont-cancel: false #
# Default is false, but Calamares will complain if this is not explicitly set.
#
# YAML: boolean.
disable-cancel-during-exec: false

View File

@ -207,7 +207,7 @@ Settings::Settings( const QString& settingsFilePath,
m_doChroot = !requireBool( config, "dont-chroot", false ); m_doChroot = !requireBool( config, "dont-chroot", false );
m_isSetupMode = requireBool( config, "oem-setup", !m_doChroot ); m_isSetupMode = requireBool( config, "oem-setup", !m_doChroot );
m_disableCancel = requireBool( config, "disable-cancel", false ); m_disableCancel = requireBool( config, "disable-cancel", false );
m_dontCancel = requireBool( config, "dont-cancel", false ); m_dontCancel = requireBool( config, "disable-cancel-during-exec", false );
} }
catch ( YAML::Exception& e ) catch ( YAML::Exception& e )
{ {

View File

@ -69,8 +69,9 @@ public:
*/ */
bool isSetupMode() const { return m_isSetupMode; } bool isSetupMode() const { return m_isSetupMode; }
/** @brief Global setting of disable-cancel: can't cancel ever. */
bool disableCancel() const; bool disableCancel() const;
/** @brief Temporary setting of disable-cancel: can't cancel during exec. */
bool dontCancel() const; bool dontCancel() const;
private: private:

View File

@ -103,7 +103,6 @@ ViewManager::ViewManager( QObject* parent )
if (Calamares::Settings::instance()->disableCancel()) if (Calamares::Settings::instance()->disableCancel())
m_quit->setVisible( false ); m_quit->setVisible( false );
} }
@ -241,22 +240,24 @@ ViewManager::next()
bool executing = false; bool executing = false;
if ( step->isAtEnd() ) if ( step->isAtEnd() )
{ {
const auto const* settings = Calamares::Settings::instance();
// Special case when the user clicks next on the very last page in a view phase // Special case when the user clicks next on the very last page in a view phase
// and right before switching to an execution phase. // and right before switching to an execution phase.
// Depending on Calamares::Settings, we show an "are you sure" prompt or not. // Depending on Calamares::Settings, we show an "are you sure" prompt or not.
if ( Calamares::Settings::instance()->showPromptBeforeExecution() && stepNextWillExecute( m_steps, m_currentStep ) ) if ( settings->showPromptBeforeExecution() && stepNextWillExecute( m_steps, m_currentStep ) )
{ {
QString title = Calamares::Settings::instance()->isSetupMode() QString title = settings->isSetupMode()
? tr( "Continue with setup?" ) ? tr( "Continue with setup?" )
: tr( "Continue with installation?" ); : tr( "Continue with installation?" );
QString question = Calamares::Settings::instance()->isSetupMode() QString question = settings->isSetupMode()
? tr( "The %1 setup program is about to make changes to your " ? tr( "The %1 setup program is about to make changes to your "
"disk in order to set up %2.<br/><strong>You will not be able " "disk in order to set up %2.<br/><strong>You will not be able "
"to undo these changes.</strong>" ) "to undo these changes.</strong>" )
: tr( "The %1 installer is about to make changes to your " : tr( "The %1 installer is about to make changes to your "
"disk in order to install %2.<br/><strong>You will not be able " "disk in order to install %2.<br/><strong>You will not be able "
"to undo these changes.</strong>" ); "to undo these changes.</strong>" );
QString confirm = Calamares::Settings::instance()->isSetupMode() QString confirm = settings->isSetupMode()
? tr( "&Set up now" ) ? tr( "&Set up now" )
: tr( "&Install now" ); : tr( "&Install now" );
@ -283,9 +284,12 @@ ViewManager::next()
{ {
m_back->setEnabled( false ); m_back->setEnabled( false );
m_next->setEnabled( false ); m_next->setEnabled( false );
if (Calamares::Settings::instance()->dontCancel()) // Enabled if there's nothing blocking it during exec
m_quit->setEnabled( false ); m_quit->setEnabled( !( settings->dontCancel() || settings->disableCancel() ) );
} }
else
// Enabled unless it's also hidden
m_quit->setEnabled( !settings->disableCancel() );
} }
else else
step->next(); step->next();
@ -318,13 +322,16 @@ ViewManager::updateButtonLabels()
{ {
m_quit->setText( tr( "&Done" ) ); m_quit->setText( tr( "&Done" ) );
m_quit->setToolTip( complete ); m_quit->setToolTip( complete );
if (Calamares::Settings::instance()->disableCancel()) m_quit->setVisible( true ); // At end, always visible and enabled.
m_quit->setVisible( true ); m_quit->setEnabled( true );
} }
else else
{ {
if ( Calamares::Settings::instance()->disableCancel() ) if ( Calamares::Settings::instance()->disableCancel() )
{
m_quit->setVisible( false ); m_quit->setVisible( false );
m_quit->setEnabled( false ); // Can't be triggered through DBUS
}
m_quit->setText( tr( "&Cancel" ) ); m_quit->setText( tr( "&Cancel" ) );
m_quit->setToolTip( quit ); m_quit->setToolTip( quit );
} }