From 00fab5826ead7e1327a21471df6884c655b4ce50 Mon Sep 17 00:00:00 2001 From: Jonathan Olson Date: Thu, 13 May 2021 09:51:11 -0600 Subject: [PATCH] Adding initialScreen/homeScreen, see https://github.com/phetsims/joist/issues/714 --- js/NavigationBar.js | 2 +- js/Sim.js | 29 +++++++++++++++++++++++------ 2 files changed, 24 insertions(+), 7 deletions(-) diff --git a/js/NavigationBar.js b/js/NavigationBar.js index dbeac5c7..1ac2c7f2 100644 --- a/js/NavigationBar.js +++ b/js/NavigationBar.js @@ -124,7 +124,7 @@ define( function( require ) { }, tandem: options.tandem && options.tandem.createTandem( 'homeButton' ) } ); - this.barContents.addChild( this.homeButton ); + phet.chipper.queryParameters.homeScreen && this.barContents.addChild( this.homeButton ); /* * Allocate remaining horizontal space equally for screen buttons, assuming they will be centered in the navbar. diff --git a/js/Sim.js b/js/Sim.js index f1bfc39c..fa022bd6 100644 --- a/js/Sim.js +++ b/js/Sim.js @@ -58,7 +58,7 @@ define( function( require ) { options = _.extend( { // whether to show the home screen, or go immediately to the screen indicated by screenIndex - showHomeScreen: true, + showHomeScreen: phet.chipper.queryParameters.homeScreen, // index of the screen that will be selected at startup screenIndex: 0, @@ -122,13 +122,30 @@ define( function( require ) { //Default values are to show the home screen with the 1st screen selected var showHomeScreen = ( _.isUndefined( options.showHomeScreen ) ) ? true : options.showHomeScreen; + var initialScreen = phet.chipper.queryParameters.initialScreen; + //If specifying 'screens' then use 1-based (not zero-based) and "." delimited string such as "1.3.4" to get the 1st, 3rd and 4th screen if ( phet.chipper.getQueryParameter( 'screens' ) ) { - var screensValueString = phet.chipper.getQueryParameter( 'screens' ); - screens = screensValueString.split( ',' ).map( function( screenString ) { - return screens[ parseInt( screenString, 10 ) - 1 ]; + var newScreens = []; + phet.chipper.getQueryParameter( 'screens' ).split( '.' ).map( function( screenString ) { + return parseInt( screenString, 10 ); + } ).forEach( function( userIndex ) { + var screenIndex = userIndex - 1; // screens query parameter is 1-based + if ( screenIndex < 0 || screenIndex > screens.length - 1 ) { + throw new Error( 'invalid screen index: ' + userIndex ); + } + newScreens.push( screens[ screenIndex ] ); } ); - options.screenIndex = 0; + + // If the user specified an initial screen other than the homescreen and specified a subset of screens + // remap the selected 1-based index from the original screens list to the filtered screens list. + if ( initialScreen !== 0 ) { + var index = _.indexOf( newScreens, screens[ initialScreen - 1 ] ); + assert && assert( index !== -1, 'screen not found' ); + initialScreen = index + 1; + } + + screens = newScreens; } //If there is only one screen, do not show the home screen @@ -142,7 +159,7 @@ define( function( require ) { showHomeScreen: showHomeScreen, // @public (joist-internal) - The selected index - screenIndex: options.screenIndex || 0, + screenIndex: initialScreen === 0 ? 0 : initialScreen - 1, // @public (joist-internal, read-only) - how the home screen and navbar are scaled scale: 1,