mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-09-23 15:03:24 +02:00
Claened up title scene daily run init to be less questionable
This commit is contained in:
parent
17c13115dd
commit
28575fd316
@ -193,7 +193,7 @@ export class TitlePhase extends Phase {
|
||||
|
||||
initDailyRun(): void {
|
||||
globalScene.ui.clearText();
|
||||
globalScene.ui.setMode(UiMode.SAVE_SLOT, SaveSlotUiMode.SAVE, (slotId: number) => {
|
||||
globalScene.ui.setMode(UiMode.SAVE_SLOT, SaveSlotUiMode.SAVE, async (slotId: number) => {
|
||||
if (slotId === -1) {
|
||||
globalScene.phaseManager.toTitleScreen();
|
||||
super.end();
|
||||
@ -202,7 +202,27 @@ export class TitlePhase extends Phase {
|
||||
globalScene.phaseManager.clearPhaseQueue();
|
||||
globalScene.sessionSlotId = slotId;
|
||||
|
||||
const generateDaily = (seed: string) => {
|
||||
let seed = "";
|
||||
// If Online, calls seed fetch from db to generate daily run. If Offline, generates a daily run based on current date.
|
||||
if (!isLocal || isLocalServerConnected) {
|
||||
try {
|
||||
seed = (await fetchDailyRunSeed()) ?? "";
|
||||
if (!seed) {
|
||||
throw new Error("Daily run seed is null!");
|
||||
}
|
||||
} catch (err) {
|
||||
// TODO: Find a better fallback for bad daily run loads
|
||||
console.error("Failed to load daily run:\n", err);
|
||||
}
|
||||
} else {
|
||||
// Grab first 10 chars of ISO date format (YYYY-MM-DD) and convert to base64
|
||||
seed = Overrides.DAILY_RUN_SEED_OVERRIDE ?? btoa(new Date().toISOString().substring(0, 10));
|
||||
}
|
||||
await this.generateDaily(seed);
|
||||
});
|
||||
}
|
||||
|
||||
private async generateDaily(seed: string) {
|
||||
globalScene.gameMode = getGameMode(GameModes.DAILY);
|
||||
// Daily runs don't support all challenges yet (starter select restrictions aren't considered)
|
||||
globalScene.eventManager.startEventChallenges();
|
||||
@ -221,11 +241,7 @@ export class TitlePhase extends Phase {
|
||||
const starterProps = globalScene.gameData.getSpeciesDexAttrProps(starter.species, starter.dexAttr);
|
||||
const starterFormIndex = Math.min(starterProps.formIndex, Math.max(starter.species.forms.length - 1, 0));
|
||||
const starterGender =
|
||||
starter.species.malePercent !== null
|
||||
? !starterProps.female
|
||||
? Gender.MALE
|
||||
: Gender.FEMALE
|
||||
: Gender.GENDERLESS;
|
||||
starter.species.malePercent !== null ? (!starterProps.female ? Gender.MALE : Gender.FEMALE) : Gender.GENDERLESS;
|
||||
const starterPokemon = globalScene.addPlayerPokemon(
|
||||
starter.species,
|
||||
startingLevel,
|
||||
@ -261,7 +277,7 @@ export class TitlePhase extends Phase {
|
||||
}
|
||||
globalScene.updateModifiers(true, true);
|
||||
|
||||
Promise.all(loadPokemonAssets).then(() => {
|
||||
await Promise.all(loadPokemonAssets);
|
||||
globalScene.time.delayedCall(500, () => globalScene.playBgm());
|
||||
globalScene.gameData.gameStats.dailyRunSessionsPlayed++;
|
||||
globalScene.newArena(globalScene.gameMode.getStartingBiome());
|
||||
@ -270,31 +286,6 @@ export class TitlePhase extends Phase {
|
||||
globalScene.sessionPlayTime = 0;
|
||||
globalScene.lastSavePlayTime = 0;
|
||||
this.end();
|
||||
});
|
||||
};
|
||||
|
||||
// If Online, calls seed fetch from db to generate daily run. If Offline, generates a daily run based on current date.
|
||||
if (!isLocal || isLocalServerConnected) {
|
||||
fetchDailyRunSeed()
|
||||
.then(seed => {
|
||||
if (seed) {
|
||||
generateDaily(seed);
|
||||
} else {
|
||||
throw new Error("Daily run seed is null!");
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
console.error("Failed to load daily run:\n", err);
|
||||
});
|
||||
} else {
|
||||
// Grab first 10 chars of ISO date format (YYYY-MM-DD) and convert to base64
|
||||
let seed: string = btoa(new Date().toISOString().substring(0, 10));
|
||||
if (Overrides.DAILY_RUN_SEED_OVERRIDE != null) {
|
||||
seed = Overrides.DAILY_RUN_SEED_OVERRIDE;
|
||||
}
|
||||
generateDaily(seed);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
end(): void {
|
||||
|
Loading…
Reference in New Issue
Block a user