| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | import { cachebust } from "../core/cachebust"; | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  | import { A_B_TESTING_LINK_TYPE, globalConfig, THIRDPARTY_URLS } from "../core/config"; | 
					
						
							|  |  |  | import { GameState } from "../core/game_state"; | 
					
						
							|  |  |  | import { DialogWithForm } from "../core/modal_dialog_elements"; | 
					
						
							|  |  |  | import { FormElementInput } from "../core/modal_dialog_forms"; | 
					
						
							|  |  |  | import { ReadWriteProxy } from "../core/read_write_proxy"; | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | import { | 
					
						
							|  |  |  |     formatSecondsToTimeAgo, | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |     generateFileDownload, | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     isSupportedBrowser, | 
					
						
							|  |  |  |     makeButton, | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |     makeButtonElement, | 
					
						
							|  |  |  |     makeDiv, | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     removeAllChildren, | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |     startFileChoose, | 
					
						
							|  |  |  |     waitNextFrame, | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | } from "../core/utils"; | 
					
						
							|  |  |  | import { HUDModalDialogs } from "../game/hud/parts/modal_dialogs"; | 
					
						
							|  |  |  | import { getApplicationSettingById } from "../profile/application_settings"; | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  | import { T } from "../translations"; | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-19 16:32:39 +00:00
										 |  |  | const trim = require("trim"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @typedef {import("../savegame/savegame_typedefs").SavegameMetadata} SavegameMetadata | 
					
						
							|  |  |  |  * @typedef {import("../profile/setting_types").EnumSetting} EnumSetting | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class MainMenuState extends GameState { | 
					
						
							|  |  |  |     constructor() { | 
					
						
							|  |  |  |         super("MainMenuState"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     getInnerHTML() { | 
					
						
							|  |  |  |         const bannerHtml = `
 | 
					
						
							|  |  |  |             <h3>${T.demoBanners.title}</h3> | 
					
						
							|  |  |  |             <p>${T.demoBanners.intro}</p> | 
					
						
							| 
									
										
										
										
											2020-09-29 16:26:38 +00:00
										 |  |  |             <a href="#" class="steamLink ${A_B_TESTING_LINK_TYPE}" target="_blank">Get the shapez.io standalone!</a> | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |         `;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |         const showDemoBadges = this.app.restrictionMgr.getIsStandaloneMarketingActive(); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |         return `
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             <div class="topButtons"> | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                 ${ | 
					
						
							|  |  |  |                     G_CHINA_VERSION | 
					
						
							|  |  |  |                         ? "" | 
					
						
							|  |  |  |                         : `<button class="languageChoose" data-languageicon="${this.app.settings.getLanguage()}"></button>` | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 <button class="settingsButton"></button> | 
					
						
							|  |  |  |             ${ | 
					
						
							|  |  |  |                 G_IS_STANDALONE || G_IS_DEV | 
					
						
							|  |  |  |                     ? `
 | 
					
						
							|  |  |  |                 <button class="exitAppButton"></button> | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |                     : "" | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <video autoplay muted loop class="fullscreenBackgroundVideo"> | 
					
						
							|  |  |  |                 <source src="${cachebust("res/bg_render.webm")}" type="video/webm"> | 
					
						
							|  |  |  |             </video> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <div class="logo"> | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                 <img src="${cachebust( | 
					
						
							|  |  |  |                     G_CHINA_VERSION ? "res/logo_cn.png" : "res/logo.png" | 
					
						
							|  |  |  |                 )}" alt="shapez.io Logo"> | 
					
						
							| 
									
										
										
										
											2021-03-10 08:29:20 +00:00
										 |  |  |                 <span class="updateLabel">v${G_BUILD_VERSION} - Achievements!</span> | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             </div> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |             <div class="mainWrapper ${showDemoBadges ? "demo" : "noDemo"}"> | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 <div class="sideContainer"> | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |                     ${showDemoBadges ? `<div class="standaloneBanner">${bannerHtml}</div>` : ""} | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 <div class="mainContainer"> | 
					
						
							|  |  |  |                     ${ | 
					
						
							|  |  |  |                         isSupportedBrowser() | 
					
						
							|  |  |  |                             ? "" | 
					
						
							|  |  |  |                             : `<div class="browserWarning">${T.mainMenu.browserWarning}</div>` | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     <div class="buttons"></div> | 
					
						
							|  |  |  |                 </div> | 
					
						
							| 
									
										
										
										
											2021-03-14 11:10:29 +00:00
										 |  |  |                 <div class="bottomContainer"> | 
					
						
							|  |  |  |                     <div class="buttons"></div> | 
					
						
							|  |  |  |                 </div> | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             </div> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |             <div class="footer ${G_CHINA_VERSION ? "china" : ""}"> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 ${ | 
					
						
							|  |  |  |                     G_CHINA_VERSION | 
					
						
							|  |  |  |                         ? "" | 
					
						
							|  |  |  |                         : `
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 <a class="githubLink boxLink" target="_blank"> | 
					
						
							|  |  |  |                     ${T.mainMenu.openSourceHint} | 
					
						
							|  |  |  |                     <span class="thirdpartyLogo githubLogo"></span> | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                 </a>` | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 <a class="discordLink boxLink" target="_blank"> | 
					
						
							|  |  |  |                     ${T.mainMenu.discordLink} | 
					
						
							|  |  |  |                     <span class="thirdpartyLogo  discordLogo"></span> | 
					
						
							|  |  |  |                 </a> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 <div class="sidelinks"> | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                     ${G_CHINA_VERSION ? "" : `<a class="redditLink">${T.mainMenu.subreddit}</a>`} | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                     ${G_CHINA_VERSION ? "" : `<a class="changelog">${T.changelog.title}</a>`} | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                     ${G_CHINA_VERSION ? "" : `<a class="helpTranslate">${T.mainMenu.helpTranslate}</a>`} | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 </div> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-12 11:42:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 <div class="author">${T.mainMenu.madeBy.replace( | 
					
						
							|  |  |  |                     "<author-link>", | 
					
						
							|  |  |  |                     '<a class="producerLink" target="_blank">Tobias Springer</a>' | 
					
						
							|  |  |  |                 )}</div> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |         `;
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Asks the user to import a savegame | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     requestImportSavegame() { | 
					
						
							|  |  |  |         if ( | 
					
						
							|  |  |  |             this.app.savegameMgr.getSavegamesMetaData().length > 0 && | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |             !this.app.restrictionMgr.getHasUnlimitedSavegames() | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |         ) { | 
					
						
							|  |  |  |             this.app.analytics.trackUiClick("importgame_slot_limit_show"); | 
					
						
							| 
									
										
										
										
											2020-09-18 10:55:46 +00:00
										 |  |  |             this.showSavegameSlotLimit(); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |         // Create a 'fake' file-input to accept savegames
 | 
					
						
							|  |  |  |         startFileChoose(".bin").then(file => { | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             if (file) { | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |                 const closeLoader = this.dialogs.showLoadingDialog(); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 waitNextFrame().then(() => { | 
					
						
							|  |  |  |                     this.app.analytics.trackUiClick("import_savegame"); | 
					
						
							|  |  |  |                     const reader = new FileReader(); | 
					
						
							|  |  |  |                     reader.addEventListener("load", event => { | 
					
						
							|  |  |  |                         const contents = event.target.result; | 
					
						
							|  |  |  |                         let realContent; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         try { | 
					
						
							|  |  |  |                             realContent = ReadWriteProxy.deserializeObject(contents); | 
					
						
							|  |  |  |                         } catch (err) { | 
					
						
							|  |  |  |                             closeLoader(); | 
					
						
							|  |  |  |                             this.dialogs.showWarning( | 
					
						
							|  |  |  |                                 T.dialogs.importSavegameError.title, | 
					
						
							|  |  |  |                                 T.dialogs.importSavegameError.text + "<br><br>" + err | 
					
						
							|  |  |  |                             ); | 
					
						
							|  |  |  |                             return; | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         this.app.savegameMgr.importSavegame(realContent).then( | 
					
						
							|  |  |  |                             () => { | 
					
						
							|  |  |  |                                 closeLoader(); | 
					
						
							|  |  |  |                                 this.dialogs.showWarning( | 
					
						
							|  |  |  |                                     T.dialogs.importSavegameSuccess.title, | 
					
						
							|  |  |  |                                     T.dialogs.importSavegameSuccess.text | 
					
						
							|  |  |  |                                 ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                                 this.renderMainMenu(); | 
					
						
							|  |  |  |                                 this.renderSavegames(); | 
					
						
							|  |  |  |                             }, | 
					
						
							|  |  |  |                             err => { | 
					
						
							|  |  |  |                                 closeLoader(); | 
					
						
							|  |  |  |                                 this.dialogs.showWarning( | 
					
						
							|  |  |  |                                     T.dialogs.importSavegameError.title, | 
					
						
							|  |  |  |                                     T.dialogs.importSavegameError.text + ":<br><br>" + err | 
					
						
							|  |  |  |                                 ); | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                         ); | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                     reader.addEventListener("error", error => { | 
					
						
							|  |  |  |                         this.dialogs.showWarning( | 
					
						
							|  |  |  |                             T.dialogs.importSavegameError.title, | 
					
						
							|  |  |  |                             T.dialogs.importSavegameError.text + ":<br><br>" + error | 
					
						
							|  |  |  |                         ); | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                     reader.readAsText(file, "utf-8"); | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onBackButton() { | 
					
						
							|  |  |  |         this.app.platformWrapper.exitApp(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onEnter(payload) { | 
					
						
							|  |  |  |         this.dialogs = new HUDModalDialogs(null, this.app); | 
					
						
							|  |  |  |         const dialogsElement = document.body.querySelector(".modalDialogParent"); | 
					
						
							|  |  |  |         this.dialogs.initializeToElement(dialogsElement); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (payload.loadError) { | 
					
						
							|  |  |  |             this.dialogs.showWarning( | 
					
						
							|  |  |  |                 T.dialogs.gameLoadFailure.title, | 
					
						
							|  |  |  |                 T.dialogs.gameLoadFailure.text + "<br><br>" + payload.loadError | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const qs = this.htmlElement.querySelector.bind(this.htmlElement); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (G_IS_DEV && globalConfig.debug.fastGameEnter) { | 
					
						
							| 
									
										
										
										
											2021-03-14 21:22:14 +00:00
										 |  |  |             if (globalConfig.debug.testPuzzleMode) { | 
					
						
							|  |  |  |                 this.onPuzzlePlayButtonClicked(); | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             const games = this.app.savegameMgr.getSavegamesMetaData(); | 
					
						
							|  |  |  |             if (games.length > 0 && globalConfig.debug.resumeGameOnFastEnter) { | 
					
						
							|  |  |  |                 this.resumeGame(games[0]); | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 this.onPlayButtonClicked(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Initialize video
 | 
					
						
							|  |  |  |         this.videoElement = this.htmlElement.querySelector("video"); | 
					
						
							|  |  |  |         this.videoElement.playbackRate = 0.9; | 
					
						
							|  |  |  |         this.videoElement.addEventListener("canplay", () => { | 
					
						
							|  |  |  |             if (this.videoElement) { | 
					
						
							|  |  |  |                 this.videoElement.classList.add("loaded"); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.trackClicks(qs(".settingsButton"), this.onSettingsButtonClicked); | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (!G_CHINA_VERSION) { | 
					
						
							|  |  |  |             this.trackClicks(qs(".languageChoose"), this.onLanguageChooseClicked); | 
					
						
							|  |  |  |             this.trackClicks(qs(".redditLink"), this.onRedditClicked); | 
					
						
							|  |  |  |             this.trackClicks(qs(".changelog"), this.onChangelogClicked); | 
					
						
							|  |  |  |             this.trackClicks(qs(".helpTranslate"), this.onTranslationHelpLinkClicked); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (G_IS_STANDALONE) { | 
					
						
							|  |  |  |             this.trackClicks(qs(".exitAppButton"), this.onExitAppButtonClicked); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.renderMainMenu(); | 
					
						
							|  |  |  |         this.renderSavegames(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const steamLink = this.htmlElement.querySelector(".steamLink"); | 
					
						
							|  |  |  |         if (steamLink) { | 
					
						
							|  |  |  |             this.trackClicks(steamLink, () => this.onSteamLinkClicked(), { preventClick: true }); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const discordLink = this.htmlElement.querySelector(".discordLink"); | 
					
						
							|  |  |  |         this.trackClicks( | 
					
						
							|  |  |  |             discordLink, | 
					
						
							| 
									
										
										
										
											2021-03-12 11:42:16 +00:00
										 |  |  |             () => { | 
					
						
							|  |  |  |                 this.app.analytics.trackUiClick("main_menu_link_discord"); | 
					
						
							|  |  |  |                 this.app.platformWrapper.openExternalLink(THIRDPARTY_URLS.discord); | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             { preventClick: true } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const githubLink = this.htmlElement.querySelector(".githubLink"); | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |         if (githubLink) { | 
					
						
							|  |  |  |             this.trackClicks( | 
					
						
							|  |  |  |                 githubLink, | 
					
						
							| 
									
										
										
										
											2021-03-12 11:42:16 +00:00
										 |  |  |                 () => { | 
					
						
							|  |  |  |                     this.app.analytics.trackUiClick("main_menu_link_github"); | 
					
						
							|  |  |  |                     this.app.platformWrapper.openExternalLink(THIRDPARTY_URLS.github); | 
					
						
							|  |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2021-03-09 09:07:19 +00:00
										 |  |  |                 { preventClick: true } | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const producerLink = this.htmlElement.querySelector(".producerLink"); | 
					
						
							| 
									
										
										
										
											2021-03-12 11:42:16 +00:00
										 |  |  |         this.trackClicks(producerLink, () => this.app.platformWrapper.openExternalLink("https://tobspr.io"), { | 
					
						
							|  |  |  |             preventClick: true, | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     renderMainMenu() { | 
					
						
							|  |  |  |         const buttonContainer = this.htmlElement.querySelector(".mainContainer .buttons"); | 
					
						
							|  |  |  |         removeAllChildren(buttonContainer); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Import button
 | 
					
						
							|  |  |  |         const importButtonElement = makeButtonElement( | 
					
						
							|  |  |  |             ["importButton", "styledButton"], | 
					
						
							|  |  |  |             T.mainMenu.importSavegame | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         this.trackClicks(importButtonElement, this.requestImportSavegame); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (this.savedGames.length > 0) { | 
					
						
							|  |  |  |             // Continue game
 | 
					
						
							|  |  |  |             const continueButton = makeButton( | 
					
						
							|  |  |  |                 buttonContainer, | 
					
						
							|  |  |  |                 ["continueButton", "styledButton"], | 
					
						
							|  |  |  |                 T.mainMenu.continue | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             this.trackClicks(continueButton, this.onContinueButtonClicked); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             const outerDiv = makeDiv(buttonContainer, null, ["outer"], null); | 
					
						
							|  |  |  |             outerDiv.appendChild(importButtonElement); | 
					
						
							|  |  |  |             const newGameButton = makeButton( | 
					
						
							|  |  |  |                 this.htmlElement.querySelector(".mainContainer .outer"), | 
					
						
							|  |  |  |                 ["newGameButton", "styledButton"], | 
					
						
							|  |  |  |                 T.mainMenu.newGame | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             this.trackClicks(newGameButton, this.onPlayButtonClicked); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             // New game
 | 
					
						
							|  |  |  |             const playBtn = makeButton(buttonContainer, ["playButton", "styledButton"], T.mainMenu.play); | 
					
						
							|  |  |  |             this.trackClicks(playBtn, this.onPlayButtonClicked); | 
					
						
							|  |  |  |             buttonContainer.appendChild(importButtonElement); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-03-14 11:10:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-14 21:22:14 +00:00
										 |  |  |         const bottomButtonContainer = this.htmlElement.querySelector(".bottomContainer .buttons"); | 
					
						
							|  |  |  |         removeAllChildren(bottomButtonContainer); | 
					
						
							| 
									
										
										
										
											2021-03-14 11:10:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const puzzleModeButton = makeButton( | 
					
						
							| 
									
										
										
										
											2021-03-14 21:22:14 +00:00
										 |  |  |             bottomButtonContainer, | 
					
						
							| 
									
										
										
										
											2021-03-14 11:10:29 +00:00
										 |  |  |             ["styledButton"], | 
					
						
							|  |  |  |             T.mainMenu.puzzleMode | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-14 21:22:14 +00:00
										 |  |  |         bottomButtonContainer.appendChild(puzzleModeButton); | 
					
						
							| 
									
										
										
										
											2021-03-14 11:10:29 +00:00
										 |  |  |         this.trackClicks(puzzleModeButton, this.onPuzzleModeButtonClicked); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-14 21:22:14 +00:00
										 |  |  |     renderPuzzleModeMenu() { | 
					
						
							|  |  |  |         const savegames = this.htmlElement.querySelector(".mainContainer .savegames"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (savegames) { | 
					
						
							|  |  |  |             savegames.remove(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const buttonContainer = this.htmlElement.querySelector(".mainContainer .buttons"); | 
					
						
							|  |  |  |         removeAllChildren(buttonContainer); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const playButtonElement = makeButtonElement( | 
					
						
							|  |  |  |             ["playButton", "styledButton"], | 
					
						
							|  |  |  |             T.mainMenu.play | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         buttonContainer.appendChild(playButtonElement); | 
					
						
							|  |  |  |         this.trackClicks(playButtonElement, this.onPuzzlePlayButtonClicked); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const bottomButtonContainer = this.htmlElement.querySelector(".bottomContainer .buttons"); | 
					
						
							|  |  |  |         removeAllChildren(bottomButtonContainer); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const backButton = makeButton( | 
					
						
							|  |  |  |             bottomButtonContainer, | 
					
						
							|  |  |  |             ["styledButton"], | 
					
						
							|  |  |  |             T.mainMenu.back | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         bottomButtonContainer.appendChild(backButton); | 
					
						
							|  |  |  |         this.trackClicks(backButton, this.onBackButtonClicked); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onPuzzlePlayButtonClicked() { | 
					
						
							|  |  |  |         const savegame = this.app.savegameMgr.createNewSavegame(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.moveToState("InGameState", { | 
					
						
							|  |  |  |             savegame, | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-14 11:10:29 +00:00
										 |  |  |     onPuzzleModeButtonClicked() { | 
					
						
							| 
									
										
										
										
											2021-03-14 21:22:14 +00:00
										 |  |  |         this.renderPuzzleModeMenu(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onBackButtonClicked() { | 
					
						
							|  |  |  |         this.renderMainMenu(); | 
					
						
							|  |  |  |         this.renderSavegames(); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onSteamLinkClicked() { | 
					
						
							| 
									
										
										
										
											2020-09-29 16:26:38 +00:00
										 |  |  |         this.app.analytics.trackUiClick("main_menu_steam_link_" + A_B_TESTING_LINK_TYPE); | 
					
						
							|  |  |  |         this.app.platformWrapper.openExternalLink( | 
					
						
							|  |  |  |             THIRDPARTY_URLS.standaloneStorePage + "?ref=mmsl2&prc=" + A_B_TESTING_LINK_TYPE | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onExitAppButtonClicked() { | 
					
						
							|  |  |  |         this.app.platformWrapper.exitApp(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onChangelogClicked() { | 
					
						
							|  |  |  |         this.moveToState("ChangelogState"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onRedditClicked() { | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("main_menu_reddit_link"); | 
					
						
							|  |  |  |         this.app.platformWrapper.openExternalLink(THIRDPARTY_URLS.reddit); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onLanguageChooseClicked() { | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("choose_language"); | 
					
						
							|  |  |  |         const setting = /** @type {EnumSetting} */ (getApplicationSettingById("language")); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const { optionSelected } = this.dialogs.showOptionChooser(T.settings.labels.language.title, { | 
					
						
							|  |  |  |             active: this.app.settings.getLanguage(), | 
					
						
							|  |  |  |             options: setting.options.map(option => ({ | 
					
						
							|  |  |  |                 value: setting.valueGetter(option), | 
					
						
							|  |  |  |                 text: setting.textGetter(option), | 
					
						
							|  |  |  |                 desc: setting.descGetter(option), | 
					
						
							|  |  |  |                 iconPrefix: setting.iconPrefix, | 
					
						
							|  |  |  |             })), | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         optionSelected.add(value => { | 
					
						
							| 
									
										
										
										
											2020-10-08 09:06:56 +00:00
										 |  |  |             this.app.settings.updateLanguage(value).then(() => { | 
					
						
							|  |  |  |                 if (setting.restartRequired) { | 
					
						
							|  |  |  |                     if (this.app.platformWrapper.getSupportsRestart()) { | 
					
						
							|  |  |  |                         this.app.platformWrapper.performRestart(); | 
					
						
							|  |  |  |                     } else { | 
					
						
							|  |  |  |                         this.dialogs.showInfo( | 
					
						
							|  |  |  |                             T.dialogs.restartRequired.title, | 
					
						
							|  |  |  |                             T.dialogs.restartRequired.text, | 
					
						
							|  |  |  |                             ["ok:good"] | 
					
						
							|  |  |  |                         ); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-08 09:06:56 +00:00
										 |  |  |                 if (setting.changeCb) { | 
					
						
							|  |  |  |                     setting.changeCb(this.app, value); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // Update current icon
 | 
					
						
							|  |  |  |             this.htmlElement.querySelector("button.languageChoose").setAttribute("data-languageIcon", value); | 
					
						
							|  |  |  |         }, this); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     get savedGames() { | 
					
						
							|  |  |  |         return this.app.savegameMgr.getSavegamesMetaData(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     renderSavegames() { | 
					
						
							|  |  |  |         const oldContainer = this.htmlElement.querySelector(".mainContainer .savegames"); | 
					
						
							|  |  |  |         if (oldContainer) { | 
					
						
							|  |  |  |             oldContainer.remove(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         const games = this.savedGames; | 
					
						
							|  |  |  |         if (games.length > 0) { | 
					
						
							|  |  |  |             const parent = makeDiv(this.htmlElement.querySelector(".mainContainer"), null, ["savegames"]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             for (let i = 0; i < games.length; ++i) { | 
					
						
							|  |  |  |                 const elem = makeDiv(parent, null, ["savegame"]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 makeDiv( | 
					
						
							|  |  |  |                     elem, | 
					
						
							|  |  |  |                     null, | 
					
						
							|  |  |  |                     ["playtime"], | 
					
						
							|  |  |  |                     formatSecondsToTimeAgo((new Date().getTime() - games[i].lastUpdate) / 1000.0) | 
					
						
							|  |  |  |                 ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 makeDiv( | 
					
						
							|  |  |  |                     elem, | 
					
						
							|  |  |  |                     null, | 
					
						
							|  |  |  |                     ["level"], | 
					
						
							|  |  |  |                     games[i].level | 
					
						
							|  |  |  |                         ? T.mainMenu.savegameLevel.replace("<x>", "" + games[i].level) | 
					
						
							|  |  |  |                         : T.mainMenu.savegameLevelUnknown | 
					
						
							|  |  |  |                 ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 const name = makeDiv( | 
					
						
							|  |  |  |                     elem, | 
					
						
							|  |  |  |                     null, | 
					
						
							|  |  |  |                     ["name"], | 
					
						
							| 
									
										
										
										
											2020-08-28 20:22:29 +00:00
										 |  |  |                     "<span>" + (games[i].name ? games[i].name : T.mainMenu.savegameUnnamed) + "</span>" | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |                 ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 const deleteButton = document.createElement("button"); | 
					
						
							|  |  |  |                 deleteButton.classList.add("styledButton", "deleteGame"); | 
					
						
							|  |  |  |                 elem.appendChild(deleteButton); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 const downloadButton = document.createElement("button"); | 
					
						
							|  |  |  |                 downloadButton.classList.add("styledButton", "downloadGame"); | 
					
						
							|  |  |  |                 elem.appendChild(downloadButton); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 const renameButton = document.createElement("button"); | 
					
						
							|  |  |  |                 renameButton.classList.add("styledButton", "renameGame"); | 
					
						
							|  |  |  |                 name.appendChild(renameButton); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 const resumeButton = document.createElement("button"); | 
					
						
							|  |  |  |                 resumeButton.classList.add("styledButton", "resumeGame"); | 
					
						
							|  |  |  |                 elem.appendChild(resumeButton); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 this.trackClicks(deleteButton, () => this.deleteGame(games[i])); | 
					
						
							|  |  |  |                 this.trackClicks(downloadButton, () => this.downloadGame(games[i])); | 
					
						
							|  |  |  |                 this.trackClicks(resumeButton, () => this.resumeGame(games[i])); | 
					
						
							|  |  |  |                 this.trackClicks(renameButton, () => this.requestRenameSavegame(games[i])); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param {SavegameMetadata} game | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     requestRenameSavegame(game) { | 
					
						
							|  |  |  |         const regex = /^[a-zA-Z0-9_\- ]{1,20}$/; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const nameInput = new FormElementInput({ | 
					
						
							|  |  |  |             id: "nameInput", | 
					
						
							|  |  |  |             label: null, | 
					
						
							|  |  |  |             placeholder: "", | 
					
						
							|  |  |  |             defaultValue: game.name || "", | 
					
						
							| 
									
										
										
										
											2020-09-19 16:32:39 +00:00
										 |  |  |             validator: val => val.match(regex) && trim(val).length > 0, | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |         }); | 
					
						
							|  |  |  |         const dialog = new DialogWithForm({ | 
					
						
							|  |  |  |             app: this.app, | 
					
						
							|  |  |  |             title: T.dialogs.renameSavegame.title, | 
					
						
							|  |  |  |             desc: T.dialogs.renameSavegame.desc, | 
					
						
							|  |  |  |             formElements: [nameInput], | 
					
						
							|  |  |  |             buttons: ["cancel:bad:escape", "ok:good:enter"], | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         this.dialogs.internalShowDialog(dialog); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // When confirmed, save the name
 | 
					
						
							|  |  |  |         dialog.buttonSignals.ok.add(() => { | 
					
						
							| 
									
										
										
										
											2020-09-19 16:32:39 +00:00
										 |  |  |             game.name = trim(nameInput.getValue()); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             this.app.savegameMgr.writeAsync(); | 
					
						
							|  |  |  |             this.renderSavegames(); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param {SavegameMetadata} game | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     resumeGame(game) { | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("resume_game"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.app.adProvider.showVideoAd().then(() => { | 
					
						
							|  |  |  |             this.app.analytics.trackUiClick("resume_game_adcomplete"); | 
					
						
							|  |  |  |             const savegame = this.app.savegameMgr.getSavegameById(game.internalId); | 
					
						
							|  |  |  |             savegame | 
					
						
							|  |  |  |                 .readAsync() | 
					
						
							|  |  |  |                 .then(() => { | 
					
						
							|  |  |  |                     this.moveToState("InGameState", { | 
					
						
							|  |  |  |                         savegame, | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |                 .catch(err => { | 
					
						
							|  |  |  |                     this.dialogs.showWarning( | 
					
						
							|  |  |  |                         T.dialogs.gameLoadFailure.title, | 
					
						
							|  |  |  |                         T.dialogs.gameLoadFailure.text + "<br><br>" + err | 
					
						
							|  |  |  |                     ); | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param {SavegameMetadata} game | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     deleteGame(game) { | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("delete_game"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const signals = this.dialogs.showWarning( | 
					
						
							|  |  |  |             T.dialogs.confirmSavegameDelete.title, | 
					
						
							| 
									
										
										
										
											2020-09-19 12:27:25 +00:00
										 |  |  |             T.dialogs.confirmSavegameDelete.text | 
					
						
							|  |  |  |                 .replace("<savegameName>", game.name || T.mainMenu.savegameUnnamed) | 
					
						
							|  |  |  |                 .replace("<savegameLevel>", String(game.level)), | 
					
						
							|  |  |  |             ["cancel:good", "delete:bad:timeout"] | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         signals.delete.add(() => { | 
					
						
							|  |  |  |             this.app.savegameMgr.deleteSavegame(game).then( | 
					
						
							|  |  |  |                 () => { | 
					
						
							|  |  |  |                     this.renderSavegames(); | 
					
						
							|  |  |  |                     if (this.savedGames.length <= 0) this.renderMainMenu(); | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 err => { | 
					
						
							|  |  |  |                     this.dialogs.showWarning( | 
					
						
							|  |  |  |                         T.dialogs.savegameDeletionError.title, | 
					
						
							|  |  |  |                         T.dialogs.savegameDeletionError.text + "<br><br>" + err | 
					
						
							|  |  |  |                     ); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param {SavegameMetadata} game | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     downloadGame(game) { | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("download_game"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const savegame = this.app.savegameMgr.getSavegameById(game.internalId); | 
					
						
							|  |  |  |         savegame.readAsync().then(() => { | 
					
						
							|  |  |  |             const data = ReadWriteProxy.serializeObject(savegame.currentData); | 
					
						
							|  |  |  |             const filename = (game.name || "unnamed") + ".bin"; | 
					
						
							|  |  |  |             generateFileDownload(filename, data); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-18 10:55:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Shows a hint that the slot limit has been reached | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     showSavegameSlotLimit() { | 
					
						
							|  |  |  |         const { getStandalone } = this.dialogs.showWarning( | 
					
						
							|  |  |  |             T.dialogs.oneSavegameLimit.title, | 
					
						
							|  |  |  |             T.dialogs.oneSavegameLimit.desc, | 
					
						
							|  |  |  |             ["cancel:bad", "getStandalone:good"] | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         getStandalone.add(() => { | 
					
						
							|  |  |  |             this.app.analytics.trackUiClick("visit_steampage_from_slot_limit"); | 
					
						
							| 
									
										
										
										
											2020-09-29 14:46:29 +00:00
										 |  |  |             this.app.platformWrapper.openExternalLink(THIRDPARTY_URLS.standaloneStorePage + "?reF=ssll"); | 
					
						
							| 
									
										
										
										
											2020-09-18 10:55:46 +00:00
										 |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |     onSettingsButtonClicked() { | 
					
						
							|  |  |  |         this.moveToState("SettingsState"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onTranslationHelpLinkClicked() { | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("translation_help_link"); | 
					
						
							|  |  |  |         this.app.platformWrapper.openExternalLink( | 
					
						
							|  |  |  |             "https://github.com/tobspr/shapez.io/blob/master/translations" | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onPlayButtonClicked() { | 
					
						
							|  |  |  |         if ( | 
					
						
							|  |  |  |             this.app.savegameMgr.getSavegamesMetaData().length > 0 && | 
					
						
							| 
									
										
										
										
											2020-10-07 07:48:31 +00:00
										 |  |  |             !this.app.restrictionMgr.getHasUnlimitedSavegames() | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |         ) { | 
					
						
							|  |  |  |             this.app.analytics.trackUiClick("startgame_slot_limit_show"); | 
					
						
							| 
									
										
										
										
											2020-09-18 10:55:46 +00:00
										 |  |  |             this.showSavegameSlotLimit(); | 
					
						
							| 
									
										
										
										
											2020-08-28 20:15:12 +00:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.app.analytics.trackUiClick("startgame"); | 
					
						
							|  |  |  |         this.app.adProvider.showVideoAd().then(() => { | 
					
						
							|  |  |  |             const savegame = this.app.savegameMgr.createNewSavegame(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             this.moveToState("InGameState", { | 
					
						
							|  |  |  |                 savegame, | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |             this.app.analytics.trackUiClick("startgame_adcomplete"); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onContinueButtonClicked() { | 
					
						
							|  |  |  |         let latestLastUpdate = 0; | 
					
						
							|  |  |  |         let latestInternalId; | 
					
						
							|  |  |  |         this.app.savegameMgr.currentData.savegames.forEach(saveGame => { | 
					
						
							|  |  |  |             if (saveGame.lastUpdate > latestLastUpdate) { | 
					
						
							|  |  |  |                 latestLastUpdate = saveGame.lastUpdate; | 
					
						
							|  |  |  |                 latestInternalId = saveGame.internalId; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const savegame = this.app.savegameMgr.getSavegameById(latestInternalId); | 
					
						
							|  |  |  |         savegame.readAsync().then(() => { | 
					
						
							|  |  |  |             this.moveToState("InGameState", { | 
					
						
							|  |  |  |                 savegame, | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onLeave() { | 
					
						
							|  |  |  |         this.dialogs.cleanup(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |