2024-05-23 17:03:10 +02:00
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" ;
2024-09-07 21:37:37 -07:00
import InputTextPlugin from "phaser3-rex-plugins/plugins/inputtext-plugin" ;
import TransitionImagePackPlugin from "phaser3-rex-plugins/templates/transitionimagepack/transitionimagepack-plugin" ;
2024-10-01 13:55:16 -07:00
import { initI18n } from "./plugins/i18n" ;
2023-03-28 14:54:52 -04:00
2024-05-02 05:44:10 -07:00
// Catch global errors and display them in an alert so users can report the issue.
window . onerror = function ( message , source , lineno , colno , error ) {
2024-05-23 17:03:10 +02:00
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 ;
2024-05-02 05:44:10 -07:00
} ;
// Catch global promise rejections and display them in an alert so users can report the issue.
2024-05-24 01:45:04 +02:00
window . addEventListener ( "unhandledrejection" , ( event ) = > {
2024-05-23 17:03:10 +02:00
// const errorString = `Received unhandled promise rejection. Open browser console and click OK to see details.\nReason: ${event.reason}`;
console . error ( event . reason ) ;
//alert(errorString);
2024-05-02 09:00:36 -04:00
} ) ;
2024-05-02 05:44:10 -07:00
2024-05-28 16:16:14 -05:00
/ * *
* Sets this object ' s position relative to another object with a given offset
* /
2024-08-25 03:46:16 +08:00
const setPositionRelative = function ( guideObject : Phaser.GameObjects.GameObject , x : number , y : number ) {
2024-05-28 16:16:14 -05:00
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 ) ;
2023-03-28 14:54:52 -04:00
} ;
2024-04-05 10:14:49 -04:00
Phaser . GameObjects . Container . prototype . setPositionRelative = setPositionRelative ;
2023-03-28 14:54:52 -04:00
Phaser . GameObjects . Sprite . prototype . setPositionRelative = setPositionRelative ;
Phaser . GameObjects . Image . prototype . setPositionRelative = setPositionRelative ;
2023-06-16 12:13:52 -04:00
Phaser . GameObjects . NineSlice . prototype . setPositionRelative = setPositionRelative ;
2023-03-28 14:54:52 -04:00
Phaser . GameObjects . Text . prototype . setPositionRelative = setPositionRelative ;
2024-01-07 23:17:24 -05:00
Phaser . GameObjects . Rectangle . prototype . setPositionRelative = setPositionRelative ;
2023-03-28 14:54:52 -04:00
2024-05-23 17:03:10 +02:00
document . fonts . load ( "16px emerald" ) . then ( ( ) = > document . fonts . load ( "10px pkmnems" ) ) ;
2023-03-28 14:54:52 -04:00
2024-04-23 22:00:23 -04:00
let game ;
2024-10-27 21:32:30 +01:00
const startGame = async ( manifest? : any ) = > {
2024-10-01 13:55:16 -07:00
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
} ) ;
2024-05-23 17:03:10 +02:00
game . sound . pauseOnBlur = false ;
2024-10-27 21:32:30 +01:00
if ( manifest ) {
game [ "manifest" ] = manifest ;
}
2024-04-23 22:00:23 -04:00
} ;
2024-05-23 17:03:10 +02:00
fetch ( "/manifest.json" )
. then ( res = > res . json ( ) )
. then ( jsonResponse = > {
2024-10-27 21:32:30 +01:00
startGame ( jsonResponse . manifest ) ;
2024-05-23 17:03:10 +02:00
} ) . catch ( ( ) = > {
// Manifest not found (likely local build)
2024-10-27 21:32:30 +01:00
startGame ( ) ;
2024-05-23 17:03:10 +02:00
} ) ;
2023-03-28 14:54:52 -04:00
2024-04-16 06:55:03 +08:00
export default game ;