* Update i18n.ts * Update config.ts * Update game-stats-ui-handler.ts * Add files via upload * Cleanup code + Modification of the interface to manage labels dynamically (without this, the language change was not reflected until the page was completely refreshed) * Apply ESLint after rebase on upstream/main * Remove useless initStatsKeys * Adds german localization + Changes font size in german only (because otherwise it overflows :D) * Adds an additional method of formatting large numbers to make it a little more pleasant to read + The other was a little too barbaric in what it truncated, but is still useful in certain cases + Use abbreviations from 10^0 to 10^33 * Use of the new 'formatFancyLargeNumber' method to display money owned in combat and the highest sum of money obtained in statistics --------- Co-authored-by: Lugiad <adrien.grivel@hotmail.fr> Co-authored-by: Jannik Tappert <38758606+CodeTappert@users.noreply.github.com>
This commit is contained in:
parent
da5370cbd5
commit
6d2b8ef2d1
|
@ -1264,7 +1264,7 @@ export default class BattleScene extends SceneBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
updateMoneyText(): void {
|
updateMoneyText(): void {
|
||||||
this.moneyText.setText(`₽${Utils.formatLargeNumber(this.money, 1000)}`);
|
this.moneyText.setText(`₽${Utils.formatFancyLargeNumber(this.money, 3)}`);
|
||||||
this.moneyText.setVisible(true);
|
this.moneyText.setVisible(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,6 @@ import { WindowVariant, getWindowVariantSuffix } from "./ui/ui-theme";
|
||||||
import { isMobile } from "./touch-controls";
|
import { isMobile } from "./touch-controls";
|
||||||
import * as Utils from "./utils";
|
import * as Utils from "./utils";
|
||||||
import { initI18n } from "./plugins/i18n";
|
import { initI18n } from "./plugins/i18n";
|
||||||
import {initStatsKeys} from "#app/ui/game-stats-ui-handler";
|
|
||||||
import {initPokemonPrevolutions} from "#app/data/pokemon-evolutions";
|
import {initPokemonPrevolutions} from "#app/data/pokemon-evolutions";
|
||||||
import {initBiomes} from "#app/data/biomes";
|
import {initBiomes} from "#app/data/biomes";
|
||||||
import {initEggMoves} from "#app/data/egg-moves";
|
import {initEggMoves} from "#app/data/egg-moves";
|
||||||
|
@ -310,7 +309,6 @@ export class LoadingScene extends SceneBase {
|
||||||
|
|
||||||
this.loadLoadingScreen();
|
this.loadLoadingScreen();
|
||||||
|
|
||||||
initStatsKeys();
|
|
||||||
initPokemonPrevolutions();
|
initPokemonPrevolutions();
|
||||||
initBiomes();
|
initBiomes();
|
||||||
initEggMoves();
|
initEggMoves();
|
||||||
|
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const deConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Statistiken",
|
||||||
|
"playTime": "Spielzeit",
|
||||||
|
"totalBattles": "Kämpfe insgesamt",
|
||||||
|
"starters": "Starter",
|
||||||
|
"shinyStarters": "Schillernde Starter",
|
||||||
|
"speciesSeen": "Gesehene Arten",
|
||||||
|
"speciesCaught": "Gefangene Arten",
|
||||||
|
"ribbonsOwned": "Bänder im Besitz",
|
||||||
|
"classicRuns": "Klassik-Modus Versuche",
|
||||||
|
"classicWins": "Klassik-Modus Siege",
|
||||||
|
"dailyRunAttempts": "Täglicher-Modus Versuche",
|
||||||
|
"dailyRunWins": "Täglicher-Modus Siege",
|
||||||
|
"endlessRuns": "Endlos-Modus Versuche",
|
||||||
|
"highestWaveEndless": "Höchste Welle (Endlos)",
|
||||||
|
"highestMoney": "Max. Geld im Besitz",
|
||||||
|
"highestDamage": "Höchster Schaden",
|
||||||
|
"highestHPHealed": "Höchste Heilung",
|
||||||
|
"pokemonEncountered": "Getroffene Pokémon",
|
||||||
|
"pokemonDefeated": "Besiegte Pokémon",
|
||||||
|
"pokemonCaught": "Gefangene Pokémon",
|
||||||
|
"eggsHatched": "Ausgebrütete Eier",
|
||||||
|
"subLegendsSeen": "Getroffene Sub-Legenden",
|
||||||
|
"subLegendsCaught": "Gefangene Sub-Legenden",
|
||||||
|
"subLegendsHatched": "Ausgebrütete Sub-Legenden",
|
||||||
|
"legendsSeen": "Getroffene Legenden",
|
||||||
|
"legendsCaught": "Gefangene Legenden",
|
||||||
|
"legendsHatched": "Ausgebrütete Legenden",
|
||||||
|
"mythicalsSeen": "Getroffene Mythische",
|
||||||
|
"mythicalsCaught": "Gefangene Mythische",
|
||||||
|
"mythicalsHatched": "Ausgebrütete Mythische",
|
||||||
|
"shiniesSeen": "Getroffene Schillernde",
|
||||||
|
"shiniesCaught": "Gefangene Schillernde",
|
||||||
|
"shiniesHatched": "Ausgebrütete Schillernde",
|
||||||
|
"pokemonFused": "Pokémon fusioniert",
|
||||||
|
"trainersDefeated": "Besiegte Trainer",
|
||||||
|
"eggsPulled": "Gezogene Eier",
|
||||||
|
"rareEggsPulled": "Seltene Eier Gezogen",
|
||||||
|
"epicEggsPulled": "Epische Eier Gezogen",
|
||||||
|
"legendaryEggsPulled": "Legendäre Eier Gezogen",
|
||||||
|
"manaphyEggsPulled": "Manaphy Eier Gezogen",
|
||||||
|
} as const;
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const enConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Stats",
|
||||||
|
"playTime": "Play Time",
|
||||||
|
"totalBattles": "Total Battles",
|
||||||
|
"starters": "Starters",
|
||||||
|
"shinyStarters": "Shiny Starters",
|
||||||
|
"speciesSeen": "Species Seen",
|
||||||
|
"speciesCaught": "Species Caught",
|
||||||
|
"ribbonsOwned": "Ribbons Owned",
|
||||||
|
"classicRuns": "Classic Runs",
|
||||||
|
"classicWins": "Classic Wins",
|
||||||
|
"dailyRunAttempts": "Daily Run Attempts",
|
||||||
|
"dailyRunWins": "Daily Run Wins",
|
||||||
|
"endlessRuns": "Endless Runs",
|
||||||
|
"highestWaveEndless": "Highest Wave (Endless)",
|
||||||
|
"highestMoney": "Highest Money",
|
||||||
|
"highestDamage": "Highest Damage",
|
||||||
|
"highestHPHealed": "Highest HP Healed",
|
||||||
|
"pokemonEncountered": "Pokémon Encountered",
|
||||||
|
"pokemonDefeated": "Pokémon Defeated",
|
||||||
|
"pokemonCaught": "Pokémon Caught",
|
||||||
|
"eggsHatched": "Eggs Hatched",
|
||||||
|
"subLegendsSeen": "Sub-Legends Seen",
|
||||||
|
"subLegendsCaught": "Sub-Legends Caught",
|
||||||
|
"subLegendsHatched": "Sub-Legends Hatched",
|
||||||
|
"legendsSeen": "Legends Seen",
|
||||||
|
"legendsCaught": "Legends Caught",
|
||||||
|
"legendsHatched": "Legends Hatched",
|
||||||
|
"mythicalsSeen": "Mythicals Seen",
|
||||||
|
"mythicalsCaught": "Mythicals Caught",
|
||||||
|
"mythicalsHatched": "Mythicals Hatched",
|
||||||
|
"shiniesSeen": "Shinies Seen",
|
||||||
|
"shiniesCaught": "Shinies Caught",
|
||||||
|
"shiniesHatched": "Shinies Hatched",
|
||||||
|
"pokemonFused": "Pokémon Fused",
|
||||||
|
"trainersDefeated": "Trainers Defeated",
|
||||||
|
"eggsPulled": "Eggs Pulled",
|
||||||
|
"rareEggsPulled": "Rare Eggs Pulled",
|
||||||
|
"epicEggsPulled": "Epic Eggs Pulled",
|
||||||
|
"legendaryEggsPulled": "Legendary Eggs Pulled",
|
||||||
|
"manaphyEggsPulled": "Manaphy Eggs Pulled",
|
||||||
|
} as const;
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const esConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Stats",
|
||||||
|
"playTime": "Play Time",
|
||||||
|
"totalBattles": "Total Battles",
|
||||||
|
"starters": "Starters",
|
||||||
|
"shinyStarters": "Shiny Starters",
|
||||||
|
"speciesSeen": "Species Seen",
|
||||||
|
"speciesCaught": "Species Caught",
|
||||||
|
"ribbonsOwned": "Ribbons Owned",
|
||||||
|
"classicRuns": "Classic Runs",
|
||||||
|
"classicWins": "Classic Wins",
|
||||||
|
"dailyRunAttempts": "Daily Run Attempts",
|
||||||
|
"dailyRunWins": "Daily Run Wins",
|
||||||
|
"endlessRuns": "Endless Runs",
|
||||||
|
"highestWaveEndless": "Highest Wave (Endless)",
|
||||||
|
"highestMoney": "Highest Money",
|
||||||
|
"highestDamage": "Highest Damage",
|
||||||
|
"highestHPHealed": "Highest HP Healed",
|
||||||
|
"pokemonEncountered": "Pokémon Encountered",
|
||||||
|
"pokemonDefeated": "Pokémon Defeated",
|
||||||
|
"pokemonCaught": "Pokémon Caught",
|
||||||
|
"eggsHatched": "Eggs Hatched",
|
||||||
|
"subLegendsSeen": "Sub-Legends Seen",
|
||||||
|
"subLegendsCaught": "Sub-Legends Caught",
|
||||||
|
"subLegendsHatched": "Sub-Legends Hatched",
|
||||||
|
"legendsSeen": "Legends Seen",
|
||||||
|
"legendsCaught": "Legends Caught",
|
||||||
|
"legendsHatched": "Legends Hatched",
|
||||||
|
"mythicalsSeen": "Mythicals Seen",
|
||||||
|
"mythicalsCaught": "Mythicals Caught",
|
||||||
|
"mythicalsHatched": "Mythicals Hatched",
|
||||||
|
"shiniesSeen": "Shinies Seen",
|
||||||
|
"shiniesCaught": "Shinies Caught",
|
||||||
|
"shiniesHatched": "Shinies Hatched",
|
||||||
|
"pokemonFused": "Pokémon Fused",
|
||||||
|
"trainersDefeated": "Trainers Defeated",
|
||||||
|
"eggsPulled": "Eggs Pulled",
|
||||||
|
"rareEggsPulled": "Rare Eggs Pulled",
|
||||||
|
"epicEggsPulled": "Epic Eggs Pulled",
|
||||||
|
"legendaryEggsPulled": "Legendary Eggs Pulled",
|
||||||
|
"manaphyEggsPulled": "Manaphy Eggs Pulled",
|
||||||
|
} as const;
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const frConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Statistiques",
|
||||||
|
"playTime": "Temps de jeu",
|
||||||
|
"totalBattles": "Total combats",
|
||||||
|
"shinyStarters": "Starters chroma",
|
||||||
|
"starters": "Starters",
|
||||||
|
"speciesSeen": "Espèces vues",
|
||||||
|
"speciesCaught": "Espèces capt.",
|
||||||
|
"ribbonsOwned": "Rubans possédés",
|
||||||
|
"classicRuns": "Parties en Classique",
|
||||||
|
"classicWins": "Victoires en Classique",
|
||||||
|
"dailyRunAttempts": "Essais Défi du jour",
|
||||||
|
"dailyRunWins": "Victoires Défi du jour",
|
||||||
|
"endlessRuns": "Parties en Infini",
|
||||||
|
"highestWaveEndless": "Record vagues (Infini)",
|
||||||
|
"highestMoney": "Record d’argent",
|
||||||
|
"highestDamage": "Record de dégâts",
|
||||||
|
"highestHPHealed": "Record PV soignés",
|
||||||
|
"pokemonEncountered": "Pokémon rencontrés",
|
||||||
|
"pokemonDefeated": "Pokémon battus",
|
||||||
|
"pokemonCaught": "Pokémon capturés",
|
||||||
|
"eggsHatched": "Œufs éclos",
|
||||||
|
"subLegendsSeen": "Semi-légendaires vus",
|
||||||
|
"subLegendsCaught": "Semi-légendaires capt.",
|
||||||
|
"subLegendsHatched": "Semi-légendaires éclos",
|
||||||
|
"legendsSeen": "Legendaires vus",
|
||||||
|
"legendsCaught": "Légendaires capt.",
|
||||||
|
"legendsHatched": "Légendaires éclos",
|
||||||
|
"mythicalsSeen": "Fabuleux vus",
|
||||||
|
"mythicalsCaught": "Fabuleux capt.",
|
||||||
|
"mythicalsHatched": "Fabuleux éclos",
|
||||||
|
"shiniesSeen": "Chromatiques vus",
|
||||||
|
"shiniesCaught": "Chromatiques capt.",
|
||||||
|
"shiniesHatched": "Chromatiques éclos",
|
||||||
|
"pokemonFused": "Pokémon fusionnés",
|
||||||
|
"trainersDefeated": "Dresseurs battus",
|
||||||
|
"eggsPulled": "Œufs obtenus",
|
||||||
|
"rareEggsPulled": "Œufs Rares",
|
||||||
|
"epicEggsPulled": "Œufs Épiques",
|
||||||
|
"legendaryEggsPulled": "Œufs Légendaires",
|
||||||
|
"manaphyEggsPulled": "Œufs de Manaphy",
|
||||||
|
} as const;
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const itConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Stats",
|
||||||
|
"playTime": "Play Time",
|
||||||
|
"totalBattles": "Total Battles",
|
||||||
|
"starters": "Starters",
|
||||||
|
"shinyStarters": "Shiny Starters",
|
||||||
|
"speciesSeen": "Species Seen",
|
||||||
|
"speciesCaught": "Species Caught",
|
||||||
|
"ribbonsOwned": "Ribbons Owned",
|
||||||
|
"classicRuns": "Classic Runs",
|
||||||
|
"classicWins": "Classic Wins",
|
||||||
|
"dailyRunAttempts": "Daily Run Attempts",
|
||||||
|
"dailyRunWins": "Daily Run Wins",
|
||||||
|
"endlessRuns": "Endless Runs",
|
||||||
|
"highestWaveEndless": "Highest Wave (Endless)",
|
||||||
|
"highestMoney": "Highest Money",
|
||||||
|
"highestDamage": "Highest Damage",
|
||||||
|
"highestHPHealed": "Highest HP Healed",
|
||||||
|
"pokemonEncountered": "Pokémon Encountered",
|
||||||
|
"pokemonDefeated": "Pokémon Defeated",
|
||||||
|
"pokemonCaught": "Pokémon Caught",
|
||||||
|
"eggsHatched": "Eggs Hatched",
|
||||||
|
"subLegendsSeen": "Sub-Legends Seen",
|
||||||
|
"subLegendsCaught": "Sub-Legends Caught",
|
||||||
|
"subLegendsHatched": "Sub-Legends Hatched",
|
||||||
|
"legendsSeen": "Legends Seen",
|
||||||
|
"legendsCaught": "Legends Caught",
|
||||||
|
"legendsHatched": "Legends Hatched",
|
||||||
|
"mythicalsSeen": "Mythicals Seen",
|
||||||
|
"mythicalsCaught": "Mythicals Caught",
|
||||||
|
"mythicalsHatched": "Mythicals Hatched",
|
||||||
|
"shiniesSeen": "Shinies Seen",
|
||||||
|
"shiniesCaught": "Shinies Caught",
|
||||||
|
"shiniesHatched": "Shinies Hatched",
|
||||||
|
"pokemonFused": "Pokémon Fused",
|
||||||
|
"trainersDefeated": "Trainers Defeated",
|
||||||
|
"eggsPulled": "Eggs Pulled",
|
||||||
|
"rareEggsPulled": "Rare Eggs Pulled",
|
||||||
|
"epicEggsPulled": "Epic Eggs Pulled",
|
||||||
|
"legendaryEggsPulled": "Legendary Eggs Pulled",
|
||||||
|
"manaphyEggsPulled": "Manaphy Eggs Pulled",
|
||||||
|
} as const;
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const ptBrConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Stats",
|
||||||
|
"playTime": "Play Time",
|
||||||
|
"totalBattles": "Total Battles",
|
||||||
|
"starters": "Starters",
|
||||||
|
"shinyStarters": "Shiny Starters",
|
||||||
|
"speciesSeen": "Species Seen",
|
||||||
|
"speciesCaught": "Species Caught",
|
||||||
|
"ribbonsOwned": "Ribbons Owned",
|
||||||
|
"classicRuns": "Classic Runs",
|
||||||
|
"classicWins": "Classic Wins",
|
||||||
|
"dailyRunAttempts": "Daily Run Attempts",
|
||||||
|
"dailyRunWins": "Daily Run Wins",
|
||||||
|
"endlessRuns": "Endless Runs",
|
||||||
|
"highestWaveEndless": "Highest Wave (Endless)",
|
||||||
|
"highestMoney": "Highest Money",
|
||||||
|
"highestDamage": "Highest Damage",
|
||||||
|
"highestHPHealed": "Highest HP Healed",
|
||||||
|
"pokemonEncountered": "Pokémon Encountered",
|
||||||
|
"pokemonDefeated": "Pokémon Defeated",
|
||||||
|
"pokemonCaught": "Pokémon Caught",
|
||||||
|
"eggsHatched": "Eggs Hatched",
|
||||||
|
"subLegendsSeen": "Sub-Legends Seen",
|
||||||
|
"subLegendsCaught": "Sub-Legends Caught",
|
||||||
|
"subLegendsHatched": "Sub-Legends Hatched",
|
||||||
|
"legendsSeen": "Legends Seen",
|
||||||
|
"legendsCaught": "Legends Caught",
|
||||||
|
"legendsHatched": "Legends Hatched",
|
||||||
|
"mythicalsSeen": "Mythicals Seen",
|
||||||
|
"mythicalsCaught": "Mythicals Caught",
|
||||||
|
"mythicalsHatched": "Mythicals Hatched",
|
||||||
|
"shiniesSeen": "Shinies Seen",
|
||||||
|
"shiniesCaught": "Shinies Caught",
|
||||||
|
"shiniesHatched": "Shinies Hatched",
|
||||||
|
"pokemonFused": "Pokémon Fused",
|
||||||
|
"trainersDefeated": "Trainers Defeated",
|
||||||
|
"eggsPulled": "Eggs Pulled",
|
||||||
|
"rareEggsPulled": "Rare Eggs Pulled",
|
||||||
|
"epicEggsPulled": "Epic Eggs Pulled",
|
||||||
|
"legendaryEggsPulled": "Legendary Eggs Pulled",
|
||||||
|
"manaphyEggsPulled": "Manaphy Eggs Pulled",
|
||||||
|
} as const;
|
|
@ -20,6 +20,7 @@ import { tutorial } from "./tutorial";
|
||||||
import { weather } from "./weather";
|
import { weather } from "./weather";
|
||||||
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
import { battleMessageUiHandler } from "./battle-message-ui-handler";
|
||||||
import { berry } from "./berry";
|
import { berry } from "./berry";
|
||||||
|
import { gameStatsUiHandler } from "./game-stats-ui-handler";
|
||||||
import { voucher } from "./voucher";
|
import { voucher } from "./voucher";
|
||||||
import {
|
import {
|
||||||
PGMdialogue,
|
PGMdialogue,
|
||||||
|
@ -56,6 +57,7 @@ export const zhCnConfig = {
|
||||||
weather: weather,
|
weather: weather,
|
||||||
battleMessageUiHandler: battleMessageUiHandler,
|
battleMessageUiHandler: battleMessageUiHandler,
|
||||||
berry: berry,
|
berry: berry,
|
||||||
|
gameStatsUiHandler: gameStatsUiHandler,
|
||||||
voucher: voucher,
|
voucher: voucher,
|
||||||
biome: biome,
|
biome: biome,
|
||||||
PGMdialogue: PGMdialogue,
|
PGMdialogue: PGMdialogue,
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
import { SimpleTranslationEntries } from "#app/plugins/i18n";
|
||||||
|
|
||||||
|
export const gameStatsUiHandler: SimpleTranslationEntries = {
|
||||||
|
"stats": "Stats",
|
||||||
|
"playTime": "Play Time",
|
||||||
|
"totalBattles": "Total Battles",
|
||||||
|
"starters": "Starters",
|
||||||
|
"shinyStarters": "Shiny Starters",
|
||||||
|
"speciesSeen": "Species Seen",
|
||||||
|
"speciesCaught": "Species Caught",
|
||||||
|
"ribbonsOwned": "Ribbons Owned",
|
||||||
|
"classicRuns": "Classic Runs",
|
||||||
|
"classicWins": "Classic Wins",
|
||||||
|
"dailyRunAttempts": "Daily Run Attempts",
|
||||||
|
"dailyRunWins": "Daily Run Wins",
|
||||||
|
"endlessRuns": "Endless Runs",
|
||||||
|
"highestWaveEndless": "Highest Wave (Endless)",
|
||||||
|
"highestMoney": "Highest Money",
|
||||||
|
"highestDamage": "Highest Damage",
|
||||||
|
"highestHPHealed": "Highest HP Healed",
|
||||||
|
"pokemonEncountered": "Pokémon Encountered",
|
||||||
|
"pokemonDefeated": "Pokémon Defeated",
|
||||||
|
"pokemonCaught": "Pokémon Caught",
|
||||||
|
"eggsHatched": "Eggs Hatched",
|
||||||
|
"subLegendsSeen": "Sub-Legends Seen",
|
||||||
|
"subLegendsCaught": "Sub-Legends Caught",
|
||||||
|
"subLegendsHatched": "Sub-Legends Hatched",
|
||||||
|
"legendsSeen": "Legends Seen",
|
||||||
|
"legendsCaught": "Legends Caught",
|
||||||
|
"legendsHatched": "Legends Hatched",
|
||||||
|
"mythicalsSeen": "Mythicals Seen",
|
||||||
|
"mythicalsCaught": "Mythicals Caught",
|
||||||
|
"mythicalsHatched": "Mythicals Hatched",
|
||||||
|
"shiniesSeen": "Shinies Seen",
|
||||||
|
"shiniesCaught": "Shinies Caught",
|
||||||
|
"shiniesHatched": "Shinies Hatched",
|
||||||
|
"pokemonFused": "Pokémon Fused",
|
||||||
|
"trainersDefeated": "Trainers Defeated",
|
||||||
|
"eggsPulled": "Eggs Pulled",
|
||||||
|
"rareEggsPulled": "Rare Eggs Pulled",
|
||||||
|
"epicEggsPulled": "Epic Eggs Pulled",
|
||||||
|
"legendaryEggsPulled": "Legendary Eggs Pulled",
|
||||||
|
"manaphyEggsPulled": "Manaphy Eggs Pulled",
|
||||||
|
} as const;
|
|
@ -178,6 +178,7 @@ declare module "i18next" {
|
||||||
modifierType: ModifierTypeTranslationEntries;
|
modifierType: ModifierTypeTranslationEntries;
|
||||||
battleMessageUiHandler: SimpleTranslationEntries;
|
battleMessageUiHandler: SimpleTranslationEntries;
|
||||||
berry: BerryTranslationEntries;
|
berry: BerryTranslationEntries;
|
||||||
|
gameStatsUiHandler: SimpleTranslationEntries;
|
||||||
voucher: SimpleTranslationEntries;
|
voucher: SimpleTranslationEntries;
|
||||||
biome: SimpleTranslationEntries;
|
biome: SimpleTranslationEntries;
|
||||||
PGMdialogue: DialogueTranslationEntries;
|
PGMdialogue: DialogueTranslationEntries;
|
||||||
|
|
|
@ -7,9 +7,10 @@ import * as Utils from "../utils";
|
||||||
import { DexAttr, GameData } from "../system/game-data";
|
import { DexAttr, GameData } from "../system/game-data";
|
||||||
import { speciesStarters } from "../data/pokemon-species";
|
import { speciesStarters } from "../data/pokemon-species";
|
||||||
import {Button} from "../enums/buttons";
|
import {Button} from "../enums/buttons";
|
||||||
|
import i18next from "../plugins/i18n";
|
||||||
|
|
||||||
interface DisplayStat {
|
interface DisplayStat {
|
||||||
label?: string;
|
label_key?: string;
|
||||||
sourceFunc?: (gameData: GameData) => string;
|
sourceFunc?: (gameData: GameData) => string;
|
||||||
hidden?: boolean;
|
hidden?: boolean;
|
||||||
}
|
}
|
||||||
|
@ -20,70 +21,193 @@ interface DisplayStats {
|
||||||
|
|
||||||
const displayStats: DisplayStats = {
|
const displayStats: DisplayStats = {
|
||||||
playTime: {
|
playTime: {
|
||||||
|
label_key: "playTime",
|
||||||
sourceFunc: gameData => Utils.getPlayTimeString(gameData.gameStats.playTime)
|
sourceFunc: gameData => Utils.getPlayTimeString(gameData.gameStats.playTime)
|
||||||
},
|
},
|
||||||
battles: "Total Battles",
|
battles: {
|
||||||
|
label_key: "totalBattles",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.battles.toString(),
|
||||||
|
},
|
||||||
startersUnlocked: {
|
startersUnlocked: {
|
||||||
label: "Starters",
|
label_key: "starters",
|
||||||
sourceFunc: gameData => {
|
sourceFunc: gameData => {
|
||||||
const starterCount = gameData.getStarterCount(d => !!d.caughtAttr);
|
const starterCount = gameData.getStarterCount(d => !!d.caughtAttr);
|
||||||
return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarters).length) * 1000) / 10}%)`;
|
return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarters).length) * 1000) / 10}%)`;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
shinyStartersUnlocked: {
|
shinyStartersUnlocked: {
|
||||||
label: "Shiny Starters",
|
label_key: "shinyStarters",
|
||||||
sourceFunc: gameData => {
|
sourceFunc: gameData => {
|
||||||
const starterCount = gameData.getStarterCount(d => !!(d.caughtAttr & DexAttr.SHINY));
|
const starterCount = gameData.getStarterCount(d => !!(d.caughtAttr & DexAttr.SHINY));
|
||||||
return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarters).length) * 1000) / 10}%)`;
|
return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarters).length) * 1000) / 10}%)`;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
dexSeen: {
|
dexSeen: {
|
||||||
label: "Species Seen",
|
label_key: "speciesSeen",
|
||||||
sourceFunc: gameData => {
|
sourceFunc: gameData => {
|
||||||
const seenCount = gameData.getSpeciesCount(d => !!d.seenAttr);
|
const seenCount = gameData.getSpeciesCount(d => !!d.seenAttr);
|
||||||
return `${seenCount} (${Math.floor((seenCount / Object.keys(gameData.dexData).length) * 1000) / 10}%)`;
|
return `${seenCount} (${Math.floor((seenCount / Object.keys(gameData.dexData).length) * 1000) / 10}%)`;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
dexCaught: {
|
dexCaught: {
|
||||||
label: "Species Caught",
|
label_key: "speciesCaught",
|
||||||
sourceFunc: gameData => {
|
sourceFunc: gameData => {
|
||||||
const caughtCount = gameData.getSpeciesCount(d => !!d.caughtAttr);
|
const caughtCount = gameData.getSpeciesCount(d => !!d.caughtAttr);
|
||||||
return `${caughtCount} (${Math.floor((caughtCount / Object.keys(gameData.dexData).length) * 1000) / 10}%)`;
|
return `${caughtCount} (${Math.floor((caughtCount / Object.keys(gameData.dexData).length) * 1000) / 10}%)`;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ribbonsOwned: "Ribbons Owned",
|
ribbonsOwned: {
|
||||||
classicSessionsPlayed: "Classic Runs",
|
label_key: "ribbonsOwned",
|
||||||
sessionsWon: "Classic Wins",
|
sourceFunc: gameData => gameData.gameStats.ribbonsOwned.toString(),
|
||||||
dailyRunSessionsPlayed: "Daily Run Attempts",
|
},
|
||||||
dailyRunSessionsWon: "Daily Run Wins",
|
classicSessionsPlayed:{
|
||||||
endlessSessionsPlayed: "Endless Runs?",
|
label_key: "classicRuns",
|
||||||
highestEndlessWave: "Highest Wave (Endless)?",
|
sourceFunc: gameData => gameData.gameStats.classicSessionsPlayed.toString(),
|
||||||
highestMoney: "Highest Money",
|
},
|
||||||
highestDamage: "Highest Damage",
|
sessionsWon: {
|
||||||
highestHeal: "Highest HP Healed",
|
label_key: "classicWins",
|
||||||
pokemonSeen: "Pokémon Encountered",
|
sourceFunc: gameData => gameData.gameStats.sessionsWon.toString(),
|
||||||
pokemonDefeated: "Pokémon Defeated",
|
},
|
||||||
pokemonCaught: "Pokémon Caught",
|
dailyRunSessionsPlayed: {
|
||||||
pokemonHatched: "Eggs Hatched",
|
label_key: "dailyRunAttempts",
|
||||||
subLegendaryPokemonSeen: "Sub-Legends Seen?",
|
sourceFunc: gameData => gameData.gameStats.dailyRunSessionsPlayed.toString(),
|
||||||
subLegendaryPokemonCaught: "Sub-Legends Caught?",
|
},
|
||||||
subLegendaryPokemonHatched: "Sub-Legends Hatched?",
|
dailyRunSessionsWon: {
|
||||||
legendaryPokemonSeen: "Legends Seen?",
|
label_key: "dailyRunWins",
|
||||||
legendaryPokemonCaught: "Legends Caught?",
|
sourceFunc: gameData => gameData.gameStats.dailyRunSessionsWon.toString(),
|
||||||
legendaryPokemonHatched: "Legends Hatched?",
|
},
|
||||||
mythicalPokemonSeen: "Mythicals Seen?",
|
endlessSessionsPlayed: {
|
||||||
mythicalPokemonCaught: "Mythicals Caught?",
|
label_key: "endlessRuns",
|
||||||
mythicalPokemonHatched: "Mythicals Hatched?",
|
sourceFunc: gameData => gameData.gameStats.endlessSessionsPlayed.toString(),
|
||||||
shinyPokemonSeen: "Shinies Seen?",
|
hidden: true
|
||||||
shinyPokemonCaught: "Shinies Caught?",
|
},
|
||||||
shinyPokemonHatched: "Shinies Hatched?",
|
highestEndlessWave: {
|
||||||
pokemonFused: "Pokémon Fused?",
|
label_key: "highestWaveEndless",
|
||||||
trainersDefeated: "Trainers Defeated",
|
sourceFunc: gameData => gameData.gameStats.highestEndlessWave.toString(),
|
||||||
eggsPulled: "Eggs Pulled",
|
hidden: true
|
||||||
rareEggsPulled: "Rare Eggs Pulled?",
|
},
|
||||||
epicEggsPulled: "Epic Eggs Pulled?",
|
highestMoney: {
|
||||||
legendaryEggsPulled: "Legendary Eggs Pulled?",
|
label_key: "highestMoney",
|
||||||
manaphyEggsPulled: "Manaphy Eggs Pulled?"
|
sourceFunc: gameData => Utils.formatFancyLargeNumber(gameData.gameStats.highestMoney, 3),
|
||||||
|
},
|
||||||
|
highestDamage: {
|
||||||
|
label_key: "highestDamage",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.highestDamage.toString(),
|
||||||
|
},
|
||||||
|
highestHeal: {
|
||||||
|
label_key: "highestHPHealed",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.highestHeal.toString(),
|
||||||
|
},
|
||||||
|
pokemonSeen: {
|
||||||
|
label_key: "pokemonEncountered",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.pokemonSeen.toString(),
|
||||||
|
},
|
||||||
|
pokemonDefeated: {
|
||||||
|
label_key: "pokemonDefeated",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.pokemonDefeated.toString(),
|
||||||
|
},
|
||||||
|
pokemonCaught: {
|
||||||
|
label_key: "pokemonCaught",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.pokemonCaught.toString(),
|
||||||
|
},
|
||||||
|
pokemonHatched: {
|
||||||
|
label_key: "eggsHatched",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.pokemonHatched.toString(),
|
||||||
|
},
|
||||||
|
subLegendaryPokemonSeen: {
|
||||||
|
label_key: "subLegendsSeen",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.subLegendaryPokemonSeen.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
subLegendaryPokemonCaught: {
|
||||||
|
label_key: "subLegendsCaught",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.subLegendaryPokemonCaught.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
subLegendaryPokemonHatched: {
|
||||||
|
label_key: "subLegendsHatched",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.subLegendaryPokemonHatched.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
legendaryPokemonSeen: {
|
||||||
|
label_key: "legendsSeen",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.legendaryPokemonSeen.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
legendaryPokemonCaught: {
|
||||||
|
label_key: "legendsCaught",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.legendaryPokemonCaught.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
legendaryPokemonHatched: {
|
||||||
|
label_key: "legendsHatched",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.legendaryPokemonHatched.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
mythicalPokemonSeen: {
|
||||||
|
label_key: "mythicalsSeen",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.mythicalPokemonSeen.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
mythicalPokemonCaught: {
|
||||||
|
label_key: "mythicalsCaught",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.mythicalPokemonCaught.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
mythicalPokemonHatched: {
|
||||||
|
label_key: "mythicalsHatched",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.legendaryPokemonHatched.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
shinyPokemonSeen: {
|
||||||
|
label_key: "shiniesSeen",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.shinyPokemonSeen.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
shinyPokemonCaught: {
|
||||||
|
label_key: "shiniesCaught",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.shinyPokemonCaught.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
shinyPokemonHatched: {
|
||||||
|
label_key: "shiniesHatched",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.shinyPokemonHatched.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
pokemonFused: {
|
||||||
|
label_key: "pokemonFused",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.pokemonFused.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
trainersDefeated: {
|
||||||
|
label_key: "trainersDefeated",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.trainersDefeated.toString(),
|
||||||
|
},
|
||||||
|
eggsPulled: {
|
||||||
|
label_key: "eggsPulled",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.eggsPulled.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
rareEggsPulled: {
|
||||||
|
label_key: "rareEggsPulled",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.rareEggsPulled.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
epicEggsPulled: {
|
||||||
|
label_key: "epicEggsPulled",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.epicEggsPulled.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
legendaryEggsPulled: {
|
||||||
|
label_key: "legendaryEggsPulled",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.legendaryEggsPulled.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
|
manaphyEggsPulled: {
|
||||||
|
label_key: "manaphyEggsPulled",
|
||||||
|
sourceFunc: gameData => gameData.gameStats.manaphyEggsPulled.toString(),
|
||||||
|
hidden: true
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export default class GameStatsUiHandler extends UiHandler {
|
export default class GameStatsUiHandler extends UiHandler {
|
||||||
|
@ -110,7 +234,7 @@ export default class GameStatsUiHandler extends UiHandler {
|
||||||
const headerBg = addWindow(this.scene, 0, 0, (this.scene.game.canvas.width / 6) - 2, 24);
|
const headerBg = addWindow(this.scene, 0, 0, (this.scene.game.canvas.width / 6) - 2, 24);
|
||||||
headerBg.setOrigin(0, 0);
|
headerBg.setOrigin(0, 0);
|
||||||
|
|
||||||
const headerText = addTextObject(this.scene, 0, 0, "Stats", TextStyle.SETTINGS_LABEL);
|
const headerText = addTextObject(this.scene, 0, 0, i18next.t("gameStatsUiHandler:stats"), TextStyle.SETTINGS_LABEL);
|
||||||
headerText.setOrigin(0, 0);
|
headerText.setOrigin(0, 0);
|
||||||
headerText.setPositionRelative(headerBg, 8, 4);
|
headerText.setPositionRelative(headerBg, 8, 4);
|
||||||
|
|
||||||
|
@ -127,13 +251,15 @@ export default class GameStatsUiHandler extends UiHandler {
|
||||||
|
|
||||||
this.statsContainer = this.scene.add.container(0, 0);
|
this.statsContainer = this.scene.add.container(0, 0);
|
||||||
|
|
||||||
|
|
||||||
new Array(18).fill(null).map((_, s) => {
|
new Array(18).fill(null).map((_, s) => {
|
||||||
const statLabel = addTextObject(this.scene, 8 + (s % 2 === 1 ? statsBgWidth : 0), 28 + Math.floor(s / 2) * 16, "", TextStyle.SETTINGS_LABEL);
|
|
||||||
|
const statLabel = addTextObject(this.scene, 8 + (s % 2 === 1 ? statsBgWidth : 0), 28 + Math.floor(s / 2) * 16, "", TextStyle.STATS_LABEL);
|
||||||
statLabel.setOrigin(0, 0);
|
statLabel.setOrigin(0, 0);
|
||||||
this.statsContainer.add(statLabel);
|
this.statsContainer.add(statLabel);
|
||||||
this.statLabels.push(statLabel);
|
this.statLabels.push(statLabel);
|
||||||
|
|
||||||
const statValue = addTextObject(this.scene, (statsBgWidth * ((s % 2) + 1)) - 8, statLabel.y, "", TextStyle.WINDOW);
|
const statValue = addTextObject(this.scene, (statsBgWidth * ((s % 2) + 1)) - 8, statLabel.y, "", TextStyle.STATS_VALUE);
|
||||||
statValue.setOrigin(1, 0);
|
statValue.setOrigin(1, 0);
|
||||||
this.statsContainer.add(statValue);
|
this.statsContainer.add(statValue);
|
||||||
this.statValues.push(statValue);
|
this.statValues.push(statValue);
|
||||||
|
@ -173,7 +299,7 @@ export default class GameStatsUiHandler extends UiHandler {
|
||||||
statKeys.forEach((key, s) => {
|
statKeys.forEach((key, s) => {
|
||||||
const stat = displayStats[key] as DisplayStat;
|
const stat = displayStats[key] as DisplayStat;
|
||||||
const value = stat.sourceFunc(this.scene.gameData);
|
const value = stat.sourceFunc(this.scene.gameData);
|
||||||
this.statLabels[s].setText(!stat.hidden || isNaN(parseInt(value)) || parseInt(value) ? stat.label : "???");
|
this.statLabels[s].setText(!stat.hidden || isNaN(parseInt(value)) || parseInt(value) ? i18next.t(`gameStatsUiHandler:${stat.label_key}`) : "???");
|
||||||
this.statValues[s].setText(value);
|
this.statValues[s].setText(value);
|
||||||
});
|
});
|
||||||
if (statKeys.length < 18) {
|
if (statKeys.length < 18) {
|
||||||
|
@ -229,31 +355,3 @@ export default class GameStatsUiHandler extends UiHandler {
|
||||||
this.gameStatsContainer.setVisible(false);
|
this.gameStatsContainer.setVisible(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function initStatsKeys() {
|
|
||||||
const statKeys = Object.keys(displayStats);
|
|
||||||
|
|
||||||
for (const key of statKeys) {
|
|
||||||
if (typeof displayStats[key] === "string") {
|
|
||||||
let label = displayStats[key] as string;
|
|
||||||
let hidden = false;
|
|
||||||
if (label.endsWith("?")) {
|
|
||||||
label = label.slice(0, -1);
|
|
||||||
hidden = true;
|
|
||||||
}
|
|
||||||
displayStats[key] = {
|
|
||||||
label: label,
|
|
||||||
sourceFunc: gameData => gameData.gameStats[key].toString(),
|
|
||||||
hidden: hidden
|
|
||||||
};
|
|
||||||
} else if (displayStats[key] === null) {
|
|
||||||
displayStats[key] = {
|
|
||||||
sourceFunc: gameData => gameData.gameStats[key].toString()
|
|
||||||
};
|
|
||||||
}
|
|
||||||
if (!(displayStats[key] as DisplayStat).label) {
|
|
||||||
const splittableKey = key.replace(/([a-z]{2,})([A-Z]{1}(?:[^A-Z]|$))/g, "$1_$2");
|
|
||||||
(displayStats[key] as DisplayStat).label = Utils.toReadableString(`${splittableKey[0].toUpperCase()}${splittableKey.slice(1)}`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -22,6 +22,8 @@ export enum TextStyle {
|
||||||
SUMMARY_GRAY,
|
SUMMARY_GRAY,
|
||||||
SUMMARY_GREEN,
|
SUMMARY_GREEN,
|
||||||
MONEY,
|
MONEY,
|
||||||
|
STATS_LABEL,
|
||||||
|
STATS_VALUE,
|
||||||
SETTINGS_LABEL,
|
SETTINGS_LABEL,
|
||||||
SETTINGS_SELECTED,
|
SETTINGS_SELECTED,
|
||||||
TOOLTIP_TITLE,
|
TOOLTIP_TITLE,
|
||||||
|
@ -112,6 +114,33 @@ function getTextStyleOptions(style: TextStyle, uiTheme: UiTheme, extraStyleOptio
|
||||||
case TextStyle.WINDOW_ALT:
|
case TextStyle.WINDOW_ALT:
|
||||||
shadowXpos = 3;
|
shadowXpos = 3;
|
||||||
shadowYpos = 3;
|
shadowYpos = 3;
|
||||||
|
break;
|
||||||
|
case TextStyle.STATS_LABEL:
|
||||||
|
let fontSizeLabel = "96px";
|
||||||
|
switch (lang) {
|
||||||
|
case "de":
|
||||||
|
fontSizeLabel = "80px";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fontSizeLabel = "96px";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
styleOptions.fontSize = fontSizeLabel;
|
||||||
|
break;
|
||||||
|
case TextStyle.STATS_VALUE:
|
||||||
|
shadowXpos = 3;
|
||||||
|
shadowYpos = 3;
|
||||||
|
let fontSizeValue = "96px";
|
||||||
|
switch (lang) {
|
||||||
|
case "de":
|
||||||
|
fontSizeValue = "80px";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fontSizeValue = "96px";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
styleOptions.fontSize = fontSizeValue;
|
||||||
|
break;
|
||||||
case TextStyle.MESSAGE:
|
case TextStyle.MESSAGE:
|
||||||
case TextStyle.SETTINGS_LABEL:
|
case TextStyle.SETTINGS_LABEL:
|
||||||
case TextStyle.SETTINGS_SELECTED:
|
case TextStyle.SETTINGS_SELECTED:
|
||||||
|
@ -199,6 +228,10 @@ export function getTextColor(textStyle: TextStyle, shadow?: boolean, uiTheme: Ui
|
||||||
return !shadow ? "#e8e8a8" : "#a0a060";
|
return !shadow ? "#e8e8a8" : "#a0a060";
|
||||||
case TextStyle.SUMMARY_GRAY:
|
case TextStyle.SUMMARY_GRAY:
|
||||||
return !shadow ? "#a0a0a0" : "#636363";
|
return !shadow ? "#a0a0a0" : "#636363";
|
||||||
|
case TextStyle.STATS_LABEL:
|
||||||
|
return !shadow ? "#f8b050" : "#c07800";
|
||||||
|
case TextStyle.STATS_VALUE:
|
||||||
|
return !shadow ? "#f8f8f8" : "#6b5a73";
|
||||||
case TextStyle.SUMMARY_GREEN:
|
case TextStyle.SUMMARY_GREEN:
|
||||||
return !shadow ? "#78c850" : "#306850";
|
return !shadow ? "#78c850" : "#306850";
|
||||||
case TextStyle.SETTINGS_LABEL:
|
case TextStyle.SETTINGS_LABEL:
|
||||||
|
|
20
src/utils.ts
20
src/utils.ts
|
@ -217,6 +217,26 @@ export function formatLargeNumber(count: integer, threshold: integer): string {
|
||||||
return `${ret.slice(0, digits)}${decimalNumber ? `.${decimalNumber}` : ""}${suffix}`;
|
return `${ret.slice(0, digits)}${decimalNumber ? `.${decimalNumber}` : ""}${suffix}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Abbreviations from 10^0 to 10^33
|
||||||
|
const AbbreviationsLargeNumber: string[] = ["", "K", "M", "B", "t", "q", "Q", "s", "S", "o", "n", "d"];
|
||||||
|
|
||||||
|
export function formatFancyLargeNumber(number: number, rounded: number = 2): string {
|
||||||
|
let exponent: number;
|
||||||
|
|
||||||
|
if (number < 1000) {
|
||||||
|
exponent = 0;
|
||||||
|
} else {
|
||||||
|
const maxExp = AbbreviationsLargeNumber.length - 1;
|
||||||
|
|
||||||
|
exponent = Math.floor(Math.log(number) / Math.log(1000));
|
||||||
|
exponent = Math.min(exponent, maxExp);
|
||||||
|
|
||||||
|
number /= Math.pow(1000, exponent);
|
||||||
|
}
|
||||||
|
|
||||||
|
return `${(exponent === 0) ? number : number.toFixed(rounded)}${AbbreviationsLargeNumber[exponent]}`;
|
||||||
|
}
|
||||||
|
|
||||||
export function formatStat(stat: integer, forHp: boolean = false): string {
|
export function formatStat(stat: integer, forHp: boolean = false): string {
|
||||||
return formatLargeNumber(stat, forHp ? 100000 : 1000000);
|
return formatLargeNumber(stat, forHp ? 100000 : 1000000);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue