mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-11-28 22:18:22 +01:00
* move: locales files to `/public` (from `/src`)
* install: i18next-http-backend module
* implement: i18next language lazy-loading
* remove: all `config.ts` files (for locales)
* disable: enConfig import in i18next.d.ts
* remove: console.log from utils.camelCaseToKebabCase()
* remove localization tests
we don't need to test if i18next is working.
This is the job of i18next itself
* mock i18next for tests
* fix: tests that have to use the i18next key now
instead of the english translation
* fix: absolute-avarice-encounter test
* fix: loading mystery-encounter translations
with lazy-load
* fix: 2 mystery encounter translation loading
* replace: i18next mocks any vi.fn() calls
* fix: new namespace usage in ME tests
now using "mysteryEncounters/..."
* fix: delibirdy encounter not being language specific
the encounter was checking if the modifier name includes `Berry` which is only true for english. Instead it has to check if the modifier is an instance of BerryModifier
* fix: the-expert-pokemon-breeder
the new i18n pattern requires a different namespacing which has been adopted
* fix: GTS encounter tests
* add: `MockText.on()`
* fix: berries abound test
* chore: apply review suggestion
from @DayKev
* update i18next.d.ts
* chore: fix i18next.d.ts
* fix: `dialogue-misc` switchup between `en` and `ja`
* move: `SpeciesFormKey` into enum
there was an issue with circular dependencies
* replace: `#app/enums/` with `#enums/` for `SpeciesFormKey` imports
* re-sync locales from `beta`
* rename: `ca_ES` -> `ca-ES`
* rename: `pt_BR` -> `pt-BR`
* rename: `zh_CN` -> `zh-CN`
* rename: `zh_TW` -> `zh-TW`
* fix loading Species-Form-Key in poemon-evo.
* update: i18next `supporterLngs` ...
and remove `nonExplicitSupportedLngs`
* fix: `${namespace}.` -> `${namespace}:`
thanks @MokaStitcher
110 lines
3.7 KiB
TypeScript
110 lines
3.7 KiB
TypeScript
import Phaser from "phaser";
|
|
import InvertPostFX from "./pipelines/invert";
|
|
import { version } from "../package.json";
|
|
import UIPlugin from "phaser3-rex-plugins/templates/ui/ui-plugin";
|
|
import BBCodeTextPlugin from "phaser3-rex-plugins/plugins/bbcodetext-plugin";
|
|
import InputTextPlugin from "phaser3-rex-plugins/plugins/inputtext-plugin";
|
|
import TransitionImagePackPlugin from "phaser3-rex-plugins/templates/transitionimagepack/transitionimagepack-plugin";
|
|
import { initI18n } from "./plugins/i18n";
|
|
|
|
|
|
// Catch global errors and display them in an alert so users can report the issue.
|
|
window.onerror = function (message, source, lineno, colno, error) {
|
|
console.error(error);
|
|
// const errorString = `Received unhandled error. Open browser console and click OK to see details.\nError: ${message}\nSource: ${source}\nLine: ${lineno}\nColumn: ${colno}\nStack: ${error.stack}`;
|
|
//alert(errorString);
|
|
// Avoids logging the error a second time.
|
|
return true;
|
|
};
|
|
|
|
// Catch global promise rejections and display them in an alert so users can report the issue.
|
|
window.addEventListener("unhandledrejection", (event) => {
|
|
// const errorString = `Received unhandled promise rejection. Open browser console and click OK to see details.\nReason: ${event.reason}`;
|
|
console.error(event.reason);
|
|
//alert(errorString);
|
|
});
|
|
|
|
/**
|
|
* Sets this object's position relative to another object with a given offset
|
|
*/
|
|
const setPositionRelative = function (guideObject: Phaser.GameObjects.GameObject, x: number, y: number) {
|
|
const offsetX = guideObject.width * (-0.5 + (0.5 - guideObject.originX));
|
|
const offsetY = guideObject.height * (-0.5 + (0.5 - guideObject.originY));
|
|
this.setPosition(guideObject.x + offsetX + x, guideObject.y + offsetY + y);
|
|
};
|
|
|
|
Phaser.GameObjects.Container.prototype.setPositionRelative = setPositionRelative;
|
|
Phaser.GameObjects.Sprite.prototype.setPositionRelative = setPositionRelative;
|
|
Phaser.GameObjects.Image.prototype.setPositionRelative = setPositionRelative;
|
|
Phaser.GameObjects.NineSlice.prototype.setPositionRelative = setPositionRelative;
|
|
Phaser.GameObjects.Text.prototype.setPositionRelative = setPositionRelative;
|
|
Phaser.GameObjects.Rectangle.prototype.setPositionRelative = setPositionRelative;
|
|
|
|
document.fonts.load("16px emerald").then(() => document.fonts.load("10px pkmnems"));
|
|
|
|
let game;
|
|
|
|
const startGame = async () => {
|
|
await initI18n();
|
|
const LoadingScene = (await import("./loading-scene")).LoadingScene;
|
|
const BattleScene = (await import("./battle-scene")).default;
|
|
game = new Phaser.Game({
|
|
type: Phaser.WEBGL,
|
|
parent: "app",
|
|
scale: {
|
|
width: 1920,
|
|
height: 1080,
|
|
mode: Phaser.Scale.FIT
|
|
},
|
|
plugins: {
|
|
global: [{
|
|
key: "rexInputTextPlugin",
|
|
plugin: InputTextPlugin,
|
|
start: true
|
|
}, {
|
|
key: "rexBBCodeTextPlugin",
|
|
plugin: BBCodeTextPlugin,
|
|
start: true
|
|
}, {
|
|
key: "rexTransitionImagePackPlugin",
|
|
plugin: TransitionImagePackPlugin,
|
|
start: true
|
|
}],
|
|
scene: [{
|
|
key: "rexUI",
|
|
plugin: UIPlugin,
|
|
mapping: "rexUI"
|
|
}]
|
|
},
|
|
input: {
|
|
mouse: {
|
|
target: "app"
|
|
},
|
|
touch: {
|
|
target: "app"
|
|
},
|
|
gamepad: true
|
|
},
|
|
dom: {
|
|
createContainer: true
|
|
},
|
|
pixelArt: true,
|
|
pipeline: [ InvertPostFX ] as unknown as Phaser.Types.Core.PipelineConfig,
|
|
scene: [ LoadingScene, BattleScene ],
|
|
version: version
|
|
});
|
|
game.sound.pauseOnBlur = false;
|
|
};
|
|
|
|
fetch("/manifest.json")
|
|
.then(res => res.json())
|
|
.then(jsonResponse => {
|
|
startGame();
|
|
game["manifest"] = jsonResponse.manifest;
|
|
}).catch(() => {
|
|
// Manifest not found (likely local build)
|
|
startGame();
|
|
});
|
|
|
|
export default game;
|