2023-03-28 19:54:52 +01:00
|
|
|
import { default as BattleScene } from '../battle-scene';
|
|
|
|
import UiHandler from './uiHandler';
|
|
|
|
import BattleMessageUiHandler from './battle-message-ui-handler';
|
|
|
|
import CommandUiHandler from './command-ui-handler';
|
|
|
|
import PartyUiHandler from './party-ui-handler';
|
|
|
|
import FightUiHandler from './fight-ui-handler';
|
|
|
|
import MessageUiHandler from './message-ui-handler';
|
2023-04-07 03:24:13 +01:00
|
|
|
import ConfirmUiHandler from './confirm-ui-handler';
|
2023-03-28 19:54:52 +01:00
|
|
|
import ModifierSelectUiHandler from './modifier-select-ui-handler';
|
2023-04-02 03:59:07 +01:00
|
|
|
import BallUiHandler from './ball-ui-handler';
|
2023-04-05 13:35:15 +01:00
|
|
|
import SummaryUiHandler from './summary-ui-handler';
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
export enum Mode {
|
|
|
|
MESSAGE = 0,
|
|
|
|
COMMAND,
|
|
|
|
FIGHT,
|
2023-04-02 03:59:07 +01:00
|
|
|
BALL,
|
2023-04-07 03:24:13 +01:00
|
|
|
CONFIRM,
|
2023-03-28 19:54:52 +01:00
|
|
|
MODIFIER_SELECT,
|
2023-04-05 13:35:15 +01:00
|
|
|
PARTY,
|
|
|
|
SUMMARY
|
2023-03-28 19:54:52 +01:00
|
|
|
};
|
|
|
|
|
2023-04-07 03:24:13 +01:00
|
|
|
const transitionModes = [
|
|
|
|
Mode.PARTY,
|
|
|
|
Mode.SUMMARY
|
|
|
|
];
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
export default class UI extends Phaser.GameObjects.Container {
|
|
|
|
private mode: Mode;
|
|
|
|
private handlers: UiHandler[];
|
2023-04-07 03:24:13 +01:00
|
|
|
private overlay: Phaser.GameObjects.Rectangle;
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
constructor(scene: BattleScene) {
|
|
|
|
super(scene, 0, scene.game.canvas.height / 6);
|
|
|
|
|
|
|
|
this.mode = Mode.MESSAGE;
|
|
|
|
this.handlers = [
|
|
|
|
new BattleMessageUiHandler(scene),
|
|
|
|
new CommandUiHandler(scene),
|
|
|
|
new FightUiHandler(scene),
|
2023-04-02 03:59:07 +01:00
|
|
|
new BallUiHandler(scene),
|
2023-04-07 03:24:13 +01:00
|
|
|
new ConfirmUiHandler(scene),
|
2023-03-28 19:54:52 +01:00
|
|
|
new ModifierSelectUiHandler(scene),
|
2023-04-05 13:35:15 +01:00
|
|
|
new PartyUiHandler(scene),
|
|
|
|
new SummaryUiHandler(scene)
|
2023-03-28 19:54:52 +01:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
setup() {
|
|
|
|
for (let handler of this.handlers) {
|
|
|
|
handler.setup();
|
|
|
|
}
|
2023-04-07 03:24:13 +01:00
|
|
|
this.overlay = this.scene.add.rectangle(0, 0, this.scene.game.canvas.width / 6, this.scene.game.canvas.height / 6, 0);
|
|
|
|
this.overlay.setOrigin(0, 0);
|
|
|
|
(this.scene as BattleScene).uiContainer.add(this.overlay);
|
|
|
|
this.overlay.setVisible(false);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
getHandler() {
|
|
|
|
return this.handlers[this.mode];
|
|
|
|
}
|
|
|
|
|
|
|
|
getMessageHandler() {
|
|
|
|
return this.handlers[Mode.MESSAGE] as BattleMessageUiHandler;
|
|
|
|
}
|
|
|
|
|
|
|
|
processInput(keyCode: integer) {
|
|
|
|
this.getHandler().processInput(keyCode);
|
|
|
|
}
|
|
|
|
|
|
|
|
showText(text: string, delay?: integer, callback?: Function, callbackDelay?: integer, prompt?: boolean) {
|
|
|
|
const handler = this.getHandler();
|
|
|
|
if (handler instanceof MessageUiHandler)
|
|
|
|
(handler as MessageUiHandler).showText(text, delay, callback, callbackDelay, prompt);
|
|
|
|
else
|
|
|
|
this.getMessageHandler().showText(text, delay, callback, callbackDelay, prompt);
|
|
|
|
}
|
|
|
|
|
|
|
|
clearText() {
|
|
|
|
const handler = this.getHandler();
|
|
|
|
if (handler instanceof MessageUiHandler)
|
|
|
|
(handler as MessageUiHandler).clearText();
|
|
|
|
else
|
|
|
|
this.getMessageHandler().clearText();
|
|
|
|
}
|
|
|
|
|
|
|
|
setCursor(cursor: integer): boolean {
|
|
|
|
const changed = this.getHandler().setCursor(cursor);
|
|
|
|
if (changed)
|
|
|
|
this.playSelect();
|
|
|
|
|
|
|
|
return changed;
|
|
|
|
}
|
|
|
|
|
|
|
|
playSelect() {
|
|
|
|
this.scene.sound.play('select');
|
|
|
|
}
|
|
|
|
|
|
|
|
playError() {
|
|
|
|
this.scene.sound.play('error');
|
|
|
|
}
|
|
|
|
|
2023-04-07 03:24:13 +01:00
|
|
|
private setModeInternal(mode: Mode, clear: boolean, args: any[]): Promise<void> {
|
|
|
|
return new Promise(resolve => {
|
|
|
|
if (this.mode === mode) {
|
|
|
|
resolve();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const doSetMode = () => {
|
|
|
|
this.getHandler().clear();
|
|
|
|
this.mode = mode;
|
|
|
|
this.getHandler().show(args);
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
if (transitionModes.indexOf(this.mode) > -1 || transitionModes.indexOf(mode) > -1) {
|
|
|
|
this.overlay.setAlpha(0);
|
|
|
|
this.overlay.setVisible(true);
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.overlay,
|
|
|
|
alpha: 1,
|
|
|
|
duration: 250,
|
|
|
|
onComplete: () => {
|
|
|
|
this.scene.time.delayedCall(250, () => {
|
|
|
|
doSetMode();
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.overlay,
|
|
|
|
alpha: 0,
|
|
|
|
duration: 250,
|
|
|
|
onComplete: () => this.overlay.setVisible(false)
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else
|
|
|
|
doSetMode();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
setMode(mode: Mode, ...args: any[]): Promise<void> {
|
|
|
|
return this.setModeInternal(mode, true, args);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-04-07 03:24:13 +01:00
|
|
|
setModeWithoutClear(mode: Mode, ...args: any[]): Promise<void> {
|
|
|
|
return this.setModeInternal(mode, false, args);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
}
|