|  | @@ -1,263 +1,297 @@
 | 
												
													
														
															|  |  /*
 |  |  /*
 | 
												
													
														
															|  |      let difficultyState = {
 |  |      let difficultyState = {
 | 
												
													
														
															|  | 
 |  | +        preload: function(){},
 | 
												
													
														
															|  |  		create: function(){},
 |  |  		create: function(){},
 | 
												
													
														
															|  | -		func_loadMap: function()
 |  | 
 | 
												
													
														
															|  |          ---------------------------- end of phaser functions
 |  |          ---------------------------- end of phaser functions
 | 
												
													
														
															|  | 
 |  | +        func_loadMap: function()
 | 
												
													
														
															|  | 
 |  | +        func_setLabel: function()
 | 
												
													
														
															|  |  	};
 |  |  	};
 | 
												
													
														
															|  |  */
 |  |  */
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | 
 |  | +// DIFFICULTY SCREEN: player can select (I) sublevel type, (II) game difficulty and (III) turn on/off fractions labels
 | 
												
													
														
															|  |  let difficultyState = {
 |  |  let difficultyState = {
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -    create: function() {
 |  | 
 | 
												
													
														
															|  | 
 |  | +    preload: function() {
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +        let curMedia;
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +        switch(currentGameState){
 | 
												
													
														
															|  | 
 |  | +            case 'gameSquareOne': curMedia = media.gameSquareOne; break;
 | 
												
													
														
															|  | 
 |  | +            case 'gameSquareTwo': curMedia = media.gameSquareTwo; break;
 | 
												
													
														
															|  | 
 |  | +            case 'gameCircleOne': curMedia = media.gameCircleOne; break;
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +        for (let i = 0, image = curMedia('image'); i < image.length; i++){
 | 
												
													
														
															|  | 
 |  | +            game.load.image(image[i][0], image[i][1]);
 | 
												
													
														
															|  | 
 |  | +		}
 | 
												
													
														
															|  | 
 |  | +		for (let i = 0, sprite = curMedia('spritesheet'); i < sprite.length; i++){
 | 
												
													
														
															|  | 
 |  | +            game.load.spritesheet(sprite[i][0], sprite[i][1], sprite[i][2], sprite[i][3], sprite[i][4]);
 | 
												
													
														
															|  | 
 |  | +		}	
 | 
												
													
														
															|  | 
 |  | +		for (let i = 0, audio = curMedia('audio'); i < audio.length; i++){
 | 
												
													
														
															|  | 
 |  | +            game.load.audio(audio[i][0], audio[i][1][0], audio[i][1][1]);
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +    },
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +    create: function () {
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |          // Calls function that loads navigation icons
 |  |          // Calls function that loads navigation icons
 | 
												
													
														
															|  | -        iconSettings.func_addIcons(true,true,
 |  | 
 | 
												
													
														
															|  | -                                    false,true,false,
 |  | 
 | 
												
													
														
															|  | -                                    true,false,
 |  | 
 | 
												
													
														
															|  | -                                    false,false);
 |  | 
 | 
												
													
														
															|  | -    
 |  | 
 | 
												
													
														
															|  | 
 |  | +        iconSettings.func_addIcons(true, true,
 | 
												
													
														
															|  | 
 |  | +            false, true, false,
 | 
												
													
														
															|  | 
 |  | +            true, false,
 | 
												
													
														
															|  | 
 |  | +            false, false);
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |          // TITLE
 |  |          // TITLE
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |          const title = game.add.text(game.world.centerX, 40, lang.game_menu_title, textStyles.title2);
 |  |          const title = game.add.text(game.world.centerX, 40, lang.game_menu_title, textStyles.title2);
 | 
												
													
														
															|  |          title.anchor.setTo(0.5, 0.5);
 |  |          title.anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        // LABEL SETTINGS
 |  | 
 | 
												
													
														
															|  | -
 |  | 
 | 
												
													
														
															|  | -        // Text : 'with/without' labeling the fractions
 |  | 
 | 
												
													
														
															|  | -        let labelText = game.add.text(game.world.centerX - 110, 80, "", textStyles.subtitle2);
 |  | 
 | 
												
													
														
															|  | -        levelLabel ? labelText.text = lang.with_name + " " + lang.label_name : labelText.text = lang.without_name + " " + lang.label_name;
 |  | 
 | 
												
													
														
															|  | -        labelText.anchor.setTo(0,0.5);
 |  | 
 | 
												
													
														
															|  | -        // Selection box
 |  | 
 | 
												
													
														
															|  | -        let selectionBox = game.add.sprite(game.world.centerX - 110 - 30, 75, 'select');
 |  | 
 | 
												
													
														
															|  | -        levelLabel ? selectionBox.frame=1 : selectionBox.frame=0;
 |  | 
 | 
												
													
														
															|  | -        selectionBox.anchor.setTo(0.5, 0.5);
 |  | 
 | 
												
													
														
															|  | -        selectionBox.scale.setTo(0.12);
 |  | 
 | 
												
													
														
															|  | -        selectionBox.inputEnabled = true;
 |  | 
 | 
												
													
														
															|  | -        selectionBox.input.useHandCursor = true;
 |  | 
 | 
												
													
														
															|  | -        selectionBox.events.onInputDown.add(function(){ 
 |  | 
 | 
												
													
														
															|  | -            if(levelLabel){
 |  | 
 | 
												
													
														
															|  | -                levelLabel = false; 
 |  | 
 | 
												
													
														
															|  | -                this.selectionBox.frame = 0; 
 |  | 
 | 
												
													
														
															|  | -                this.labelText.text = lang.without_name + " " + lang.label_name;
 |  | 
 | 
												
													
														
															|  | -                if(audioStatus) beepSound.play();
 |  | 
 | 
												
													
														
															|  | -            }else{ 
 |  | 
 | 
												
													
														
															|  | -                levelLabel = true; 
 |  | 
 | 
												
													
														
															|  | -                this.selectionBox.frame = 1; 
 |  | 
 | 
												
													
														
															|  | -                this.labelText.text = lang.with_name + " " + lang.label_name;
 |  | 
 | 
												
													
														
															|  | -                if(audioStatus) beepSound.play();
 |  | 
 | 
												
													
														
															|  | -            }
 |  | 
 | 
												
													
														
															|  | -        },{selectionBox: selectionBox, labelText: labelText});
 |  | 
 | 
												
													
														
															|  | 
 |  | +        // TURN LABEL ON/OFF ICON
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +        if ( currentGameState != 'gameSquareTwo') {
 | 
												
													
														
															|  | 
 |  | +            // Text : 'with/without' labeling the fractions
 | 
												
													
														
															|  | 
 |  | +            let labelText = game.add.text(game.world.centerX - 110, 80, "", textStyles.subtitle2);
 | 
												
													
														
															|  | 
 |  | +            labelText.text = levelLabel ? lang.with_name + " " + lang.label_name : lang.without_name + " " + lang.label_name;
 | 
												
													
														
															|  | 
 |  | +            labelText.anchor.setTo(0, 0.5);
 | 
												
													
														
															|  | 
 |  | +            // Selection box
 | 
												
													
														
															|  | 
 |  | +            let selectionBox = game.add.sprite(game.world.centerX - 110 - 30, 75, 'select');
 | 
												
													
														
															|  | 
 |  | +            selectionBox.frame = levelLabel ? 1 : 0;
 | 
												
													
														
															|  | 
 |  | +            selectionBox.anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +            selectionBox.scale.setTo(0.12);
 | 
												
													
														
															|  | 
 |  | +            selectionBox.inputEnabled = true;
 | 
												
													
														
															|  | 
 |  | +            selectionBox.input.useHandCursor = true;
 | 
												
													
														
															|  | 
 |  | +            selectionBox.events.onInputDown.add(this.func_setLabel, { selectionBox: selectionBox, labelText: labelText });
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        // SETTING DIFFICULTY LEVELS
 |  | 
 | 
												
													
														
															|  | 
 |  | +        // SETTING DIFFICULTY LEVELS (STAIR)
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        let stairHeight; //height growth of a stair
 |  | 
 | 
												
													
														
															|  | -        let stairWidth; //Width of a stair
 |  | 
 | 
												
													
														
															|  | -        let startStair;
 |  | 
 | 
												
													
														
															|  | -        let startSymbol;
 |  | 
 | 
												
													
														
															|  | -        let startGeometricFigure;
 |  | 
 | 
												
													
														
															|  | -        const maxHeight = 120;      // Maximum height of a stair        
 |  | 
 | 
												
													
														
															|  | -        
 |  | 
 | 
												
													
														
															|  | -        if(currentGameState == "gameSquareOne"){
 |  | 
 | 
												
													
														
															|  | -            stairHeight = 40;
 |  | 
 | 
												
													
														
															|  | -            stairWidth  = 100;
 |  | 
 | 
												
													
														
															|  | -            startStair  = 320;
 |  | 
 | 
												
													
														
															|  | -            startSymbol = 180;
 |  | 
 | 
												
													
														
															|  | -            startGeometricFigure = (startSymbol/2)+startStair+stairWidth*3;
 |  | 
 | 
												
													
														
															|  | -        }else if(currentGameState == "gameSquareTwo" || currentGameState == "gameCircleOne"){                
 |  | 
 | 
												
													
														
															|  | -            stairHeight = 29;
 |  | 
 | 
												
													
														
															|  | -            startStair  = 240; 
 |  | 
 | 
												
													
														
															|  | -            startSymbol = 150;
 |  | 
 | 
												
													
														
															|  | -            stairWidth  = 85;
 |  | 
 | 
												
													
														
															|  | -            startGeometricFigure = (startSymbol/2)+startStair+stairWidth*5;
 |  | 
 | 
												
													
														
															|  | -        }else{
 |  | 
 | 
												
													
														
															|  | -            console.log("Error! Name of the game state is not valid!");
 |  | 
 | 
												
													
														
															|  | 
 |  | +        const maxStairHeight = 120;  // Maximum height of the stairs        
 | 
												
													
														
															|  | 
 |  | +        let stairHeight;    // Height growth of a stair
 | 
												
													
														
															|  | 
 |  | +        let stairWidth;     // Width of the stairs
 | 
												
													
														
															|  | 
 |  | +        let startStair;     // Start 'x' position of the stairs
 | 
												
													
														
															|  | 
 |  | +        let startTheme;     // Start 'x' position of the illustrations on the left (character/arrow/equal sign)
 | 
												
													
														
															|  | 
 |  | +        let startShape;     // STart 'x' position of the illustrations on the right (shapes)
 | 
												
													
														
															|  | 
 |  | +        let maxSublevel;
 | 
												
													
														
															|  | 
 |  | +        let maxDifficulty;
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +        switch(currentGameState) {
 | 
												
													
														
															|  | 
 |  | +            case "gameSquareOne":
 | 
												
													
														
															|  | 
 |  | +                stairHeight = 40;
 | 
												
													
														
															|  | 
 |  | +                stairWidth = 100;
 | 
												
													
														
															|  | 
 |  | +                startStair = 320;
 | 
												
													
														
															|  | 
 |  | +                startTheme = 180;
 | 
												
													
														
															|  | 
 |  | +                startShape = (startTheme / 2) + startStair + stairWidth * 3;
 | 
												
													
														
															|  | 
 |  | +                maxSublevel = 2;
 | 
												
													
														
															|  | 
 |  | +                maxDifficulty = 3;
 | 
												
													
														
															|  | 
 |  | +            break;
 | 
												
													
														
															|  | 
 |  | +            case "gameSquareTwo":
 | 
												
													
														
															|  | 
 |  | +            case "gameCircleOne":
 | 
												
													
														
															|  | 
 |  | +                stairHeight = 29;
 | 
												
													
														
															|  | 
 |  | +                stairWidth = 85;
 | 
												
													
														
															|  | 
 |  | +                startStair = 240;
 | 
												
													
														
															|  | 
 |  | +                startTheme = 150;
 | 
												
													
														
															|  | 
 |  | +                startShape = (startTheme / 2) + startStair + stairWidth * 5;
 | 
												
													
														
															|  | 
 |  | +                maxSublevel = 3;
 | 
												
													
														
															|  | 
 |  | +                maxDifficulty = 5;
 | 
												
													
														
															|  | 
 |  | +            break;
 | 
												
													
														
															|  | 
 |  | +            default: if (debugMode) console.log("Error! Name of the game state is not valid!");
 | 
												
													
														
															|  |          }
 |  |          }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        let geometricFigure = [];
 |  | 
 | 
												
													
														
															|  | -        let levelThemeIcons = [];
 |  | 
 | 
												
													
														
															|  | 
 |  | +        let themeIcons = [];
 | 
												
													
														
															|  |          let arrowIcons = [];
 |  |          let arrowIcons = [];
 | 
												
													
														
															|  | -        
 |  | 
 | 
												
													
														
															|  | 
 |  | +        let shapeIcons = [];
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |          let stairs = [];
 |  |          let stairs = [];
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |          const aux = {
 |  |          const aux = {
 | 
												
													
														
															|  | -            maxSublevel: null,
 |  | 
 | 
												
													
														
															|  | -            maxDifficulty: null,
 |  | 
 | 
												
													
														
															|  | -            color: ['0x99b3ff', '0xff6666', '0xb366ff'], // blue, red, purple
 |  | 
 | 
												
													
														
															|  | -            base_y1: [135, 285, 435],
 |  | 
 | 
												
													
														
															|  | 
 |  | +            maxSublevel:    null,
 | 
												
													
														
															|  | 
 |  | +            maxDifficulty:  null,
 | 
												
													
														
															|  | 
 |  | +            color:      [colors.diffBlue, colors.diffRed, colors.diffPurple],
 | 
												
													
														
															|  | 
 |  | +            base_y1:    [135, 285, 435],
 | 
												
													
														
															|  |              sublevel_1: ['Plus', 'Minus', 'Mixed'],
 |  |              sublevel_1: ['Plus', 'Minus', 'Mixed'],
 | 
												
													
														
															|  |              sublevel_2: ['A', 'B', 'C'],
 |  |              sublevel_2: ['A', 'B', 'C'],
 | 
												
													
														
															|  |              get sublevel() {
 |  |              get sublevel() {
 | 
												
													
														
															|  | -                if (currentGameState == 'gameSquareTwo') return this.sublevel_2;
 |  | 
 | 
												
													
														
															|  | -                else return this.sublevel_1;
 |  | 
 | 
												
													
														
															|  | 
 |  | +                return (currentGameState == 'gameSquareTwo') ? this.sublevel_2 : this.sublevel_1;
 | 
												
													
														
															|  |              },
 |  |              },
 | 
												
													
														
															|  |          }
 |  |          }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        switch(currentGameState){
 |  | 
 | 
												
													
														
															|  | -            
 |  | 
 | 
												
													
														
															|  | -            case "gameSquareOne":
 |  | 
 | 
												
													
														
															|  | 
 |  | +        // Placing icons
 | 
												
													
														
															|  | 
 |  | +        switch (currentGameState) {
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -                aux.maxSublevel = 2;
 |  | 
 | 
												
													
														
															|  | -                aux.maxDifficulty = 3;
 |  | 
 | 
												
													
														
															|  | 
 |  | +            case "gameSquareOne":
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |                  // Blue square
 |  |                  // Blue square
 | 
												
													
														
															|  | -                geometricFigure[0] = game.add.graphics(startGeometricFigure, 175);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].lineStyle(2, 0x31314e);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].beginFill(0xefeff5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].drawRect(0, 0, 80, 40);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].endFill();
 |  | 
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0] = game.add.graphics(startShape, 175);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].lineStyle(2, colors.darkBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].beginFill(colors.lightBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].drawRect(0, 0, 80, 40);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].endFill();
 | 
												
													
														
															|  |                  // Red square
 |  |                  // Red square
 | 
												
													
														
															|  | -                geometricFigure[1] = game.add.graphics(startGeometricFigure, 330);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].lineStyle(2, 0xb30000);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].beginFill(0xefeff5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].drawRect(0, 0, 80, 40);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].endFill();
 |  | 
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1] = game.add.graphics(startShape, 330);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].lineStyle(2, colors.red);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].beginFill(colors.lightBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].drawRect(0, 0, 80, 40);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].endFill();
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |                  // Green tractor
 |  |                  // Green tractor
 | 
												
													
														
															|  | -                levelThemeIcons[0] = game.add.sprite(startSymbol+30, 215, 'tractor_green');
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].scale.setTo(0.5);
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].alpha = 0.9;
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0] = game.add.sprite(startTheme + 30, 215, 'tractor');
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].frame = 1;
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].scale.setTo(0.5);
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].alpha = 0.9;
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |                  // Red tractor
 |  |                  // Red tractor
 | 
												
													
														
															|  | -                levelThemeIcons[1] = game.add.sprite(startSymbol+70, 370, 'tractor_red');
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[1].scale.setTo(0.5);
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[1].alpha = 0.9;
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[1].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                
 |  | 
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1] = game.add.sprite(startTheme + 70, 370, 'tractor');
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].frame = 5;
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].scale.setTo(0.5);
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].alpha = 0.9;
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |                  // Plus Arrow
 |  |                  // Plus Arrow
 | 
												
													
														
															|  | -                arrowIcons[0] = game.add.sprite(startSymbol+100, 215, 'h_arrow');
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[0] = game.add.sprite(startTheme + 100, 215, 'h_arrow');
 | 
												
													
														
															|  |                  arrowIcons[0].scale.setTo(0.3);
 |  |                  arrowIcons[0].scale.setTo(0.3);
 | 
												
													
														
															|  |                  arrowIcons[0].alpha = 0.9;
 |  |                  arrowIcons[0].alpha = 0.9;
 | 
												
													
														
															|  | -                arrowIcons[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |                  // Minus Arrow
 |  |                  // Minus Arrow
 | 
												
													
														
															|  | -                arrowIcons[1] = game.add.sprite(startSymbol, 370, 'h_arrow');
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[1] = game.add.sprite(startTheme, 370, 'h_arrow');
 | 
												
													
														
															|  |                  arrowIcons[1].scale.setTo(0.3);
 |  |                  arrowIcons[1].scale.setTo(0.3);
 | 
												
													
														
															|  |                  arrowIcons[1].alpha = 0.9;
 |  |                  arrowIcons[1].alpha = 0.9;
 | 
												
													
														
															|  | -                arrowIcons[1].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[1].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |                  arrowIcons[1].scale.x *= -1;
 |  |                  arrowIcons[1].scale.x *= -1;
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |              break;
 |  |              break;
 | 
												
													
														
															|  | -
 |  | 
 | 
												
													
														
															|  |              case "gameCircleOne":
 |  |              case "gameCircleOne":
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -                aux.maxSublevel = 3;
 |  | 
 | 
												
													
														
															|  | -                aux.maxDifficulty = 5;
 |  | 
 | 
												
													
														
															|  | -
 |  | 
 | 
												
													
														
															|  |                  // Blue Circle
 |  |                  // Blue Circle
 | 
												
													
														
															|  | -                geometricFigure[0] = game.add.graphics(startGeometricFigure, 175);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].lineStyle(2, 0x31314e);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].beginFill(0xefeff5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].drawCircle(0, 0, 60);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[0].endFill();
 |  | 
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0] = game.add.graphics(startShape, 175);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].lineStyle(2, colors.darkBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].beginFill(colors.lightBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].drawCircle(0, 0, 60);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[0].endFill();
 | 
												
													
														
															|  |                  // Red Circle
 |  |                  // Red Circle
 | 
												
													
														
															|  | -                geometricFigure[1] = game.add.graphics(startGeometricFigure, 330);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].lineStyle(2, 0xb30000);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].beginFill(0xefeff5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].drawCircle(0, 0, 60);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[1].endFill();
 |  | 
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1] = game.add.graphics(startShape, 330);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].lineStyle(2, colors.red);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].beginFill(colors.lightBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].drawCircle(0, 0, 60);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[1].endFill();
 | 
												
													
														
															|  |                  // Both blue and red circles
 |  |                  // Both blue and red circles
 | 
												
													
														
															|  | -                geometricFigure[2] = game.add.graphics(startGeometricFigure-30, 485);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[2].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[2].lineStyle(2, 0x31314e);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[2].beginFill(0xefeff5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[2].drawCircle(0, 0, 60);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[2].endFill();
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[3] = game.add.graphics(startGeometricFigure+40, 485);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[3].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[3].lineStyle(2, 0xb30000);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[3].beginFill(0xefeff5);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[3].drawCircle(0, 0, 60);
 |  | 
 | 
												
													
														
															|  | -                geometricFigure[3].endFill();
 |  | 
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[2] = game.add.graphics(startShape - 30, 485);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[2].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[2].lineStyle(2, colors.darkBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[2].beginFill(colors.lightBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[2].drawCircle(0, 0, 60);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[2].endFill();
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[3] = game.add.graphics(startShape + 40, 485);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[3].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[3].lineStyle(2, colors.red);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[3].beginFill(colors.lightBlue);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[3].drawCircle(0, 0, 60);
 | 
												
													
														
															|  | 
 |  | +                shapeIcons[3].endFill();
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |                  // Kid plus
 |  |                  // Kid plus
 | 
												
													
														
															|  | -                levelThemeIcons[0] = game.add.sprite(startSymbol, 195, 'kid_walk'); 
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].scale.setTo(0.6);
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].alpha = 0.8;
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0] = game.add.sprite(startTheme, 195, 'kid_walk');
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].scale.setTo(0.6);
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].alpha = 0.8;
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |                  // Kid minus
 |  |                  // Kid minus
 | 
												
													
														
															|  | -                levelThemeIcons[1] = game.add.sprite(startSymbol+40, 350, 'kid_walk');
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[1].scale.setTo(-0.6, 0.6);
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[1].alpha = 0.8;
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[1].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1] = game.add.sprite(startTheme + 40, 350, 'kid_walk');
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].scale.setTo(-0.6, 0.6);
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].alpha = 0.8;
 | 
												
													
														
															|  | 
 |  | +                themeIcons[1].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |                  // Plus arrow
 |  |                  // Plus arrow
 | 
												
													
														
															|  | -                arrowIcons[0] = game.add.sprite(startSymbol+40, 195, 'h_arrow'); 
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[0] = game.add.sprite(startTheme + 40, 195, 'h_arrow');
 | 
												
													
														
															|  |                  arrowIcons[0].scale.setTo(0.35);
 |  |                  arrowIcons[0].scale.setTo(0.35);
 | 
												
													
														
															|  |                  arrowIcons[0].alpha = 0.8;
 |  |                  arrowIcons[0].alpha = 0.8;
 | 
												
													
														
															|  | -                arrowIcons[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |                  // Minus arrow
 |  |                  // Minus arrow
 | 
												
													
														
															|  | -                arrowIcons[1] = game.add.sprite(startSymbol, 350, 'h_arrow');
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[1] = game.add.sprite(startTheme, 350, 'h_arrow');
 | 
												
													
														
															|  |                  arrowIcons[1].scale.setTo(-0.35, 0.35);
 |  |                  arrowIcons[1].scale.setTo(-0.35, 0.35);
 | 
												
													
														
															|  |                  arrowIcons[1].alpha = 0.8;
 |  |                  arrowIcons[1].alpha = 0.8;
 | 
												
													
														
															|  | -                arrowIcons[1].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[1].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |                  // Both plus and minus arrows
 |  |                  // Both plus and minus arrows
 | 
												
													
														
															|  | -                arrowIcons[2] = game.add.sprite(startSymbol+20, 500, 'h_double'); 
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[2] = game.add.sprite(startTheme + 20, 500, 'h_double');
 | 
												
													
														
															|  |                  arrowIcons[2].scale.setTo(0.5);
 |  |                  arrowIcons[2].scale.setTo(0.5);
 | 
												
													
														
															|  |                  arrowIcons[2].alpha = 0.8;
 |  |                  arrowIcons[2].alpha = 0.8;
 | 
												
													
														
															|  | -                arrowIcons[2].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                arrowIcons[2].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |              break;
 |  |              break;
 | 
												
													
														
															|  | -
 |  | 
 | 
												
													
														
															|  |              case "gameSquareTwo":
 |  |              case "gameSquareTwo":
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -                aux.maxSublevel = 3;
 |  | 
 | 
												
													
														
															|  | -                aux.maxDifficulty = 5;
 |  | 
 | 
												
													
														
															|  | -
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0] = game.add.sprite(startSymbol, 370, 'equal');
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].scale.setTo(0.7);
 |  | 
 | 
												
													
														
															|  | -                levelThemeIcons[0].anchor.setTo(0.5,0.5);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0] = game.add.sprite(startTheme, 370, 'equal');
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].scale.setTo(0.7);
 | 
												
													
														
															|  | 
 |  | +                themeIcons[0].anchor.setTo(0.5, 0.5);
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |              break;
 |  |              break;
 | 
												
													
														
															|  | 
 |  | +            default: if (debugMode) console.log("Error: couldn't finish loading difficulty screen assets");
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -            default:
 |  | 
 | 
												
													
														
															|  | -                console.log("Error: couldn't finish loading difficulty screen assets");
 |  | 
 | 
												
													
														
															|  |          }
 |  |          }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        // Pacing difficulty 'stairs'
 |  | 
 | 
												
													
														
															|  | -        for(let sublevel=0; sublevel<aux.maxSublevel; sublevel++){
 |  | 
 | 
												
													
														
															|  | -            for(let difficulty=1; difficulty<=aux.maxDifficulty; difficulty++){
 |  | 
 | 
												
													
														
															|  | 
 |  | +        // Placing difficulty 'stairs'
 | 
												
													
														
															|  | 
 |  | +        for (let sublevel = 0; sublevel < maxSublevel; sublevel++) {
 | 
												
													
														
															|  | 
 |  | +            for (let difficulty = 1; difficulty <= maxDifficulty; difficulty++) {
 | 
												
													
														
															|  |                  // Position
 |  |                  // Position
 | 
												
													
														
															|  | -                let x1 = startStair+(stairWidth*(difficulty-1));
 |  | 
 | 
												
													
														
															|  | -                let y1 = aux.base_y1[sublevel]+maxHeight-difficulty*stairHeight;
 |  | 
 | 
												
													
														
															|  | -                let x2 = stairWidth;//x1 + 40;
 |  | 
 | 
												
													
														
															|  | -                let y2 = stairHeight*difficulty;//y1 + 24;
 |  | 
 | 
												
													
														
															|  | 
 |  | +                const x1 = startStair + (stairWidth * (difficulty - 1));
 | 
												
													
														
															|  | 
 |  | +                const y1 = aux.base_y1[sublevel] + maxStairHeight - difficulty * stairHeight;
 | 
												
													
														
															|  | 
 |  | +                const x2 = stairWidth;//x1 + 40;
 | 
												
													
														
															|  | 
 |  | +                const y2 = stairHeight * difficulty;//y1 + 24;
 | 
												
													
														
															|  |                  // Graphics
 |  |                  // Graphics
 | 
												
													
														
															|  |                  stairs[difficulty] = game.add.graphics(0, 0);
 |  |                  stairs[difficulty] = game.add.graphics(0, 0);
 | 
												
													
														
															|  | -                stairs[difficulty].lineStyle(1, 0xFFFFFF, 1);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                stairs[difficulty].lineStyle(1, colors.blueBckg);
 | 
												
													
														
															|  |                  stairs[difficulty].beginFill(aux.color[sublevel]);
 |  |                  stairs[difficulty].beginFill(aux.color[sublevel]);
 | 
												
													
														
															|  |                  stairs[difficulty].drawRect(x1, y1, x2, y2);
 |  |                  stairs[difficulty].drawRect(x1, y1, x2, y2);
 | 
												
													
														
															|  |                  stairs[difficulty].endFill();
 |  |                  stairs[difficulty].endFill();
 | 
												
													
														
															|  | -                // Events
 |  | 
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |                  stairs[difficulty].inputEnabled = true;
 |  |                  stairs[difficulty].inputEnabled = true;
 | 
												
													
														
															|  |                  stairs[difficulty].input.useHandCursor = true;
 |  |                  stairs[difficulty].input.useHandCursor = true;
 | 
												
													
														
															|  | -                stairs[difficulty].events.onInputDown.add(this.func_loadMap, {beep: beepSound, difficulty: difficulty, sublevelType: aux.sublevel[sublevel]});
 |  | 
 | 
												
													
														
															|  | -                stairs[difficulty].events.onInputOver.add(function (item) { item.alpha=0.5; }, this);
 |  | 
 | 
												
													
														
															|  | -                stairs[difficulty].events.onInputOut.add(function (item) { item.alpha=1; }, this);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                stairs[difficulty].events.onInputDown.add(this.func_loadMap, { difficulty: difficulty, sublevelType: aux.sublevel[sublevel] });
 | 
												
													
														
															|  | 
 |  | +                stairs[difficulty].events.onInputOver.add(function (item) { item.alpha = 0.5; }, this);
 | 
												
													
														
															|  | 
 |  | +                stairs[difficulty].events.onInputOut.add(function (item) { item.alpha = 1; }, this);
 | 
												
													
														
															|  |                  // Labels
 |  |                  // Labels
 | 
												
													
														
															|  | -                let xl = x1+stairWidth/2; //x label
 |  | 
 | 
												
													
														
															|  | -                let yl = y1+(stairHeight*difficulty)/2; //y label
 |  | 
 | 
												
													
														
															|  | -                let label = game.add.text(xl, yl, difficulty, textStyles.difficultyLabel);
 |  | 
 | 
												
													
														
															|  | -                    label.anchor.setTo(0.5, 0.4);
 |  | 
 | 
												
													
														
															|  | 
 |  | +                const xl = x1 + stairWidth / 2; //x label
 | 
												
													
														
															|  | 
 |  | +                const yl = y1 + (stairHeight * difficulty) / 2; //y label
 | 
												
													
														
															|  | 
 |  | +                const label = game.add.text(xl, yl, difficulty, textStyles.difficultyLabel);
 | 
												
													
														
															|  | 
 |  | +                label.anchor.setTo(0.5, 0.4);
 | 
												
													
														
															|  |              }
 |  |              }
 | 
												
													
														
															|  |          }
 |  |          }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |      // Calls map state
 |  |      // Calls map state
 | 
												
													
														
															|  | -    func_loadMap: function(){
 |  | 
 | 
												
													
														
															|  | 
 |  | +    func_loadMap: function () {
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        if(audioStatus) this.beep.play();
 |  | 
 | 
												
													
														
															|  | 
 |  | +        if (audioStatus) beepSound.play();
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | -        levelPosition   = 0;    //Map position
 |  | 
 | 
												
													
														
															|  | -        levelMove       = true; //Move no next point
 |  | 
 | 
												
													
														
															|  | -        levelDifficulty = this.difficulty;  //Number of difficulty (1 to 5)
 |  | 
 | 
												
													
														
															|  | -        sublevelType    = this.sublevelType;    //Type of game
 |  | 
 | 
												
													
														
															|  | -        passedLevels    = 0;    //reset the game progress when entering a new level
 |  | 
 | 
												
													
														
															|  | 
 |  | +        mapPosition = 0;   //Map position
 | 
												
													
														
															|  | 
 |  | +        mapCanMove = true;       //Move no next point
 | 
												
													
														
															|  | 
 |  | +        levelDifficulty = this.difficulty;  // difficulty for selected level (1..3 or 1..5)
 | 
												
													
														
															|  | 
 |  | +        sublevelType = this.sublevelType;   //Type of game
 | 
												
													
														
															|  | 
 |  | +        completedLevels = 0;       //reset the game progress when entering a new level
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |          game.state.start('map');
 |  |          game.state.start('map');
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +    func_setLabel: function () {
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +        if (levelLabel) {
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +            levelLabel = false;
 | 
												
													
														
															|  | 
 |  | +            this.selectionBox.frame = 0;
 | 
												
													
														
															|  | 
 |  | +            this.labelText.text = lang.without_name + " " + lang.label_name;
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +        } else {
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +            levelLabel = true;
 | 
												
													
														
															|  | 
 |  | +            this.selectionBox.frame = 1;
 | 
												
													
														
															|  | 
 |  | +            this.labelText.text = lang.with_name + " " + lang.label_name;
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +        
 | 
												
													
														
															|  | 
 |  | +        if (audioStatus) beepSound.play();
 | 
												
													
														
															|  | 
 |  | +    
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  |  };
 |  |  };
 |