2024-05-23 16:03:10 +01:00
|
|
|
import { default as BattleScene } from "../battle-scene";
|
|
|
|
import UiHandler from "./ui-handler";
|
|
|
|
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";
|
|
|
|
import ConfirmUiHandler from "./confirm-ui-handler";
|
|
|
|
import ModifierSelectUiHandler from "./modifier-select-ui-handler";
|
|
|
|
import BallUiHandler from "./ball-ui-handler";
|
|
|
|
import SummaryUiHandler from "./summary-ui-handler";
|
|
|
|
import StarterSelectUiHandler from "./starter-select-ui-handler";
|
|
|
|
import EvolutionSceneHandler from "./evolution-scene-handler";
|
|
|
|
import TargetSelectUiHandler from "./target-select-ui-handler";
|
|
|
|
import SettingsUiHandler from "./settings-ui-handler";
|
|
|
|
import { TextStyle, addTextObject } from "./text";
|
|
|
|
import AchvBar from "./achv-bar";
|
|
|
|
import MenuUiHandler from "./menu-ui-handler";
|
|
|
|
import AchvsUiHandler from "./achvs-ui-handler";
|
|
|
|
import OptionSelectUiHandler from "./option-select-ui-handler";
|
|
|
|
import EggHatchSceneHandler from "./egg-hatch-scene-handler";
|
|
|
|
import EggListUiHandler from "./egg-list-ui-handler";
|
|
|
|
import EggGachaUiHandler from "./egg-gacha-ui-handler";
|
|
|
|
import VouchersUiHandler from "./vouchers-ui-handler";
|
|
|
|
import { addWindow } from "./ui-theme";
|
|
|
|
import LoginFormUiHandler from "./login-form-ui-handler";
|
|
|
|
import RegistrationFormUiHandler from "./registration-form-ui-handler";
|
|
|
|
import LoadingModalUiHandler from "./loading-modal-ui-handler";
|
2023-12-30 23:41:25 +00:00
|
|
|
import * as Utils from "../utils";
|
2024-05-23 16:03:10 +01:00
|
|
|
import GameStatsUiHandler from "./game-stats-ui-handler";
|
|
|
|
import AwaitableUiHandler from "./awaitable-ui-handler";
|
|
|
|
import SaveSlotSelectUiHandler from "./save-slot-select-ui-handler";
|
|
|
|
import TitleUiHandler from "./title-ui-handler";
|
|
|
|
import SavingIconHandler from "./saving-icon-handler";
|
|
|
|
import UnavailableModalUiHandler from "./unavailable-modal-ui-handler";
|
|
|
|
import OutdatedModalUiHandler from "./outdated-modal-ui-handler";
|
|
|
|
import SessionReloadModalUiHandler from "./session-reload-modal-ui-handler";
|
2024-05-05 15:30:00 +01:00
|
|
|
import {Button} from "../enums/buttons";
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
export enum Mode {
|
2023-04-22 16:46:52 +01:00
|
|
|
MESSAGE,
|
2024-03-21 17:12:05 +00:00
|
|
|
TITLE,
|
2023-03-28 19:54:52 +01:00
|
|
|
COMMAND,
|
|
|
|
FIGHT,
|
2023-04-02 03:59:07 +01:00
|
|
|
BALL,
|
2023-05-18 16:11:06 +01:00
|
|
|
TARGET_SELECT,
|
2023-03-28 19:54:52 +01:00
|
|
|
MODIFIER_SELECT,
|
2024-03-15 19:13:32 +00:00
|
|
|
SAVE_SLOT,
|
2023-04-05 13:35:15 +01:00
|
|
|
PARTY,
|
2023-04-10 00:15:21 +01:00
|
|
|
SUMMARY,
|
2023-04-10 18:54:06 +01:00
|
|
|
STARTER_SELECT,
|
2023-04-13 00:09:15 +01:00
|
|
|
EVOLUTION_SCENE,
|
2023-12-16 04:07:32 +00:00
|
|
|
EGG_HATCH_SCENE,
|
2023-06-01 00:54:57 +01:00
|
|
|
CONFIRM,
|
2023-11-14 03:29:03 +00:00
|
|
|
OPTION_SELECT,
|
2023-11-12 05:31:40 +00:00
|
|
|
MENU,
|
2024-03-15 22:02:05 +00:00
|
|
|
MENU_OPTION_SELECT,
|
2023-11-12 05:31:40 +00:00
|
|
|
SETTINGS,
|
2023-12-20 04:51:48 +00:00
|
|
|
ACHIEVEMENTS,
|
2024-01-11 17:26:32 +00:00
|
|
|
GAME_STATS,
|
2023-12-20 04:51:48 +00:00
|
|
|
VOUCHERS,
|
|
|
|
EGG_LIST,
|
2023-12-30 23:41:25 +00:00
|
|
|
EGG_GACHA,
|
|
|
|
LOGIN_FORM,
|
|
|
|
REGISTRATION_FORM,
|
2024-04-10 06:32:49 +01:00
|
|
|
LOADING,
|
2024-04-21 15:59:50 +01:00
|
|
|
SESSION_RELOAD,
|
2024-04-15 15:09:51 +01:00
|
|
|
UNAVAILABLE,
|
|
|
|
OUTDATED
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
|
2023-04-07 03:24:13 +01:00
|
|
|
const transitionModes = [
|
2024-03-15 19:13:32 +00:00
|
|
|
Mode.SAVE_SLOT,
|
2023-04-07 03:24:13 +01:00
|
|
|
Mode.PARTY,
|
2023-04-10 00:15:21 +01:00
|
|
|
Mode.SUMMARY,
|
|
|
|
Mode.STARTER_SELECT,
|
2023-12-16 04:07:32 +00:00
|
|
|
Mode.EVOLUTION_SCENE,
|
2023-12-20 04:51:48 +00:00
|
|
|
Mode.EGG_HATCH_SCENE,
|
|
|
|
Mode.EGG_LIST,
|
|
|
|
Mode.EGG_GACHA
|
2023-04-10 18:54:06 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
const noTransitionModes = [
|
2024-03-21 17:12:05 +00:00
|
|
|
Mode.TITLE,
|
2023-06-01 00:54:57 +01:00
|
|
|
Mode.CONFIRM,
|
2023-11-14 03:29:03 +00:00
|
|
|
Mode.OPTION_SELECT,
|
2023-11-12 05:31:40 +00:00
|
|
|
Mode.MENU,
|
2024-03-15 22:02:05 +00:00
|
|
|
Mode.MENU_OPTION_SELECT,
|
2023-12-20 04:51:48 +00:00
|
|
|
Mode.SETTINGS,
|
|
|
|
Mode.ACHIEVEMENTS,
|
2024-01-11 17:26:32 +00:00
|
|
|
Mode.GAME_STATS,
|
2023-12-30 23:41:25 +00:00
|
|
|
Mode.VOUCHERS,
|
|
|
|
Mode.LOGIN_FORM,
|
|
|
|
Mode.REGISTRATION_FORM,
|
2024-04-10 06:32:49 +01:00
|
|
|
Mode.LOADING,
|
2024-04-21 15:59:50 +01:00
|
|
|
Mode.SESSION_RELOAD,
|
2024-04-15 15:09:51 +01:00
|
|
|
Mode.UNAVAILABLE,
|
|
|
|
Mode.OUTDATED
|
2023-11-12 05:31:40 +00:00
|
|
|
];
|
|
|
|
|
2023-03-28 19:54:52 +01:00
|
|
|
export default class UI extends Phaser.GameObjects.Container {
|
|
|
|
private mode: Mode;
|
2023-11-12 05:31:40 +00:00
|
|
|
private modeChain: Mode[];
|
2023-03-28 19:54:52 +01:00
|
|
|
private handlers: UiHandler[];
|
2023-04-07 03:24:13 +01:00
|
|
|
private overlay: Phaser.GameObjects.Rectangle;
|
2023-11-12 05:31:40 +00:00
|
|
|
public achvBar: AchvBar;
|
2024-04-04 15:16:29 +01:00
|
|
|
public savingIcon: SavingIconHandler;
|
2023-11-02 04:55:20 +00:00
|
|
|
|
|
|
|
private tooltipContainer: Phaser.GameObjects.Container;
|
|
|
|
private tooltipBg: Phaser.GameObjects.NineSlice;
|
|
|
|
private tooltipTitle: Phaser.GameObjects.Text;
|
|
|
|
private tooltipContent: Phaser.GameObjects.Text;
|
2024-05-24 00:45:04 +01:00
|
|
|
|
2023-04-22 03:59:09 +01:00
|
|
|
private overlayActive: boolean;
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
constructor(scene: BattleScene) {
|
|
|
|
super(scene, 0, scene.game.canvas.height / 6);
|
|
|
|
|
|
|
|
this.mode = Mode.MESSAGE;
|
2023-11-12 05:31:40 +00:00
|
|
|
this.modeChain = [];
|
2023-03-28 19:54:52 +01:00
|
|
|
this.handlers = [
|
|
|
|
new BattleMessageUiHandler(scene),
|
2024-03-21 17:12:05 +00:00
|
|
|
new TitleUiHandler(scene),
|
2023-03-28 19:54:52 +01:00
|
|
|
new CommandUiHandler(scene),
|
|
|
|
new FightUiHandler(scene),
|
2023-04-02 03:59:07 +01:00
|
|
|
new BallUiHandler(scene),
|
2023-05-18 16:11:06 +01:00
|
|
|
new TargetSelectUiHandler(scene),
|
2023-03-28 19:54:52 +01:00
|
|
|
new ModifierSelectUiHandler(scene),
|
2024-03-15 19:13:32 +00:00
|
|
|
new SaveSlotSelectUiHandler(scene),
|
2023-04-05 13:35:15 +01:00
|
|
|
new PartyUiHandler(scene),
|
2023-04-10 00:15:21 +01:00
|
|
|
new SummaryUiHandler(scene),
|
2023-04-10 18:54:06 +01:00
|
|
|
new StarterSelectUiHandler(scene),
|
2023-04-13 00:09:15 +01:00
|
|
|
new EvolutionSceneHandler(scene),
|
2023-12-16 04:07:32 +00:00
|
|
|
new EggHatchSceneHandler(scene),
|
2023-06-01 00:54:57 +01:00
|
|
|
new ConfirmUiHandler(scene),
|
2023-11-14 03:29:03 +00:00
|
|
|
new OptionSelectUiHandler(scene),
|
2023-11-12 05:31:40 +00:00
|
|
|
new MenuUiHandler(scene),
|
2024-03-15 22:02:05 +00:00
|
|
|
new OptionSelectUiHandler(scene, Mode.MENU_OPTION_SELECT),
|
2023-11-12 05:31:40 +00:00
|
|
|
new SettingsUiHandler(scene),
|
2023-12-20 04:51:48 +00:00
|
|
|
new AchvsUiHandler(scene),
|
2024-01-11 17:26:32 +00:00
|
|
|
new GameStatsUiHandler(scene),
|
2023-12-20 04:51:48 +00:00
|
|
|
new VouchersUiHandler(scene),
|
|
|
|
new EggListUiHandler(scene),
|
2023-12-30 23:41:25 +00:00
|
|
|
new EggGachaUiHandler(scene),
|
|
|
|
new LoginFormUiHandler(scene),
|
|
|
|
new RegistrationFormUiHandler(scene),
|
2024-04-10 06:32:49 +01:00
|
|
|
new LoadingModalUiHandler(scene),
|
2024-04-21 15:59:50 +01:00
|
|
|
new SessionReloadModalUiHandler(scene),
|
2024-04-15 15:09:51 +01:00
|
|
|
new UnavailableModalUiHandler(scene),
|
|
|
|
new OutdatedModalUiHandler(scene)
|
2023-03-28 19:54:52 +01:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2023-04-07 05:17:55 +01:00
|
|
|
setup(): void {
|
2024-05-23 16:03:10 +01:00
|
|
|
for (const handler of this.handlers) {
|
2023-03-28 19:54:52 +01:00
|
|
|
handler.setup();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
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-11-02 04:55:20 +00:00
|
|
|
this.setupTooltip();
|
2023-11-12 05:31:40 +00:00
|
|
|
|
|
|
|
this.achvBar = new AchvBar(this.scene as BattleScene);
|
2023-12-20 04:51:48 +00:00
|
|
|
this.achvBar.setup();
|
2024-05-24 00:45:04 +01:00
|
|
|
|
2023-11-12 05:31:40 +00:00
|
|
|
(this.scene as BattleScene).uiContainer.add(this.achvBar);
|
2024-04-04 15:16:29 +01:00
|
|
|
|
|
|
|
this.savingIcon = new SavingIconHandler(this.scene as BattleScene);
|
|
|
|
this.savingIcon.setup();
|
|
|
|
|
|
|
|
(this.scene as BattleScene).uiContainer.add(this.savingIcon);
|
2023-11-02 04:55:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private setupTooltip() {
|
|
|
|
this.tooltipContainer = this.scene.add.container(0, 0);
|
|
|
|
this.tooltipContainer.setVisible(false);
|
|
|
|
|
2023-12-30 23:41:25 +00:00
|
|
|
this.tooltipBg = addWindow(this.scene as BattleScene, 0, 0, 128, 31);
|
2023-11-02 04:55:20 +00:00
|
|
|
this.tooltipBg.setOrigin(0, 0);
|
|
|
|
|
2024-05-23 16:03:10 +01:00
|
|
|
this.tooltipTitle = addTextObject(this.scene, 64, 4, "", TextStyle.TOOLTIP_TITLE);
|
2023-11-02 04:55:20 +00:00
|
|
|
this.tooltipTitle.setOrigin(0.5, 0);
|
|
|
|
|
2024-05-23 16:03:10 +01:00
|
|
|
this.tooltipContent = addTextObject(this.scene, 6, 16, "", TextStyle.TOOLTIP_CONTENT);
|
|
|
|
this.tooltipContent.setWordWrapWidth(696);
|
2023-11-02 04:55:20 +00:00
|
|
|
|
|
|
|
this.tooltipContainer.add(this.tooltipBg);
|
|
|
|
this.tooltipContainer.add(this.tooltipTitle);
|
|
|
|
this.tooltipContainer.add(this.tooltipContent);
|
|
|
|
|
|
|
|
(this.scene as BattleScene).uiContainer.add(this.tooltipContainer);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-04-07 05:17:55 +01:00
|
|
|
getHandler(): UiHandler {
|
2023-03-28 19:54:52 +01:00
|
|
|
return this.handlers[this.mode];
|
|
|
|
}
|
|
|
|
|
2023-04-07 05:17:55 +01:00
|
|
|
getMessageHandler(): BattleMessageUiHandler {
|
2023-03-28 19:54:52 +01:00
|
|
|
return this.handlers[Mode.MESSAGE] as BattleMessageUiHandler;
|
|
|
|
}
|
|
|
|
|
2023-11-12 05:31:40 +00:00
|
|
|
processInput(button: Button): boolean {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (this.overlayActive) {
|
2023-11-12 05:31:40 +00:00
|
|
|
return false;
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-04-07 05:17:55 +01:00
|
|
|
|
2024-02-14 15:44:55 +00:00
|
|
|
const handler = this.getHandler();
|
|
|
|
|
2024-05-23 16:03:10 +01:00
|
|
|
if (handler instanceof AwaitableUiHandler && handler.tutorialActive) {
|
2024-02-14 15:44:55 +00:00
|
|
|
return handler.processTutorialInput(button);
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2024-02-14 15:44:55 +00:00
|
|
|
|
|
|
|
return handler.processInput(button);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-04-10 18:54:06 +01:00
|
|
|
showText(text: string, delay?: integer, callback?: Function, callbackDelay?: integer, prompt?: boolean, promptDelay?: integer): void {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (prompt && text.indexOf("$") > -1) {
|
2024-02-13 23:42:11 +00:00
|
|
|
const messagePages = text.split(/\$/g).map(m => m.trim());
|
|
|
|
let showMessageAndCallback = () => callback();
|
|
|
|
for (let p = messagePages.length - 1; p >= 0; p--) {
|
|
|
|
const originalFunc = showMessageAndCallback;
|
|
|
|
showMessageAndCallback = () => this.showText(messagePages[p], null, originalFunc, null, true);
|
|
|
|
}
|
|
|
|
showMessageAndCallback();
|
|
|
|
} else {
|
|
|
|
const handler = this.getHandler();
|
2024-05-23 16:03:10 +01:00
|
|
|
if (handler instanceof MessageUiHandler) {
|
2024-02-13 23:42:11 +00:00
|
|
|
(handler as MessageUiHandler).showText(text, delay, callback, callbackDelay, prompt, promptDelay);
|
2024-05-23 16:03:10 +01:00
|
|
|
} else {
|
2024-02-13 23:42:11 +00:00
|
|
|
this.getMessageHandler().showText(text, delay, callback, callbackDelay, prompt, promptDelay);
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2024-02-13 23:42:11 +00:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2024-02-13 23:42:11 +00:00
|
|
|
showDialogue(text: string, name: string, delay: integer = 0, callback: Function, callbackDelay?: integer, promptDelay?: integer): void {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (text.indexOf("$") > -1) {
|
2024-01-13 17:24:24 +00:00
|
|
|
const messagePages = text.split(/\$/g).map(m => m.trim());
|
|
|
|
let showMessageAndCallback = () => callback();
|
|
|
|
for (let p = messagePages.length - 1; p >= 0; p--) {
|
|
|
|
const originalFunc = showMessageAndCallback;
|
2024-02-13 23:42:11 +00:00
|
|
|
showMessageAndCallback = () => this.showDialogue(messagePages[p], name, null, originalFunc);
|
2024-01-13 17:24:24 +00:00
|
|
|
}
|
|
|
|
showMessageAndCallback();
|
|
|
|
} else {
|
|
|
|
const handler = this.getHandler();
|
2024-05-23 16:03:10 +01:00
|
|
|
if (handler instanceof MessageUiHandler) {
|
2024-02-13 23:42:11 +00:00
|
|
|
(handler as MessageUiHandler).showDialogue(text, name, delay, callback, callbackDelay, true, promptDelay);
|
2024-05-23 16:03:10 +01:00
|
|
|
} else {
|
2024-02-13 23:42:11 +00:00
|
|
|
this.getMessageHandler().showDialogue(text, name, delay, callback, callbackDelay, true, promptDelay);
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2024-01-13 17:24:24 +00:00
|
|
|
}
|
2023-10-18 23:01:15 +01:00
|
|
|
}
|
|
|
|
|
2023-11-02 04:55:20 +00:00
|
|
|
showTooltip(title: string, content: string, overlap?: boolean): void {
|
|
|
|
this.tooltipContainer.setVisible(true);
|
2024-05-23 16:03:10 +01:00
|
|
|
this.tooltipTitle.setText(title || "");
|
2023-11-02 04:55:20 +00:00
|
|
|
const wrappedContent = this.tooltipContent.runWordWrap(content);
|
|
|
|
this.tooltipContent.setText(wrappedContent);
|
2023-11-04 23:46:48 +00:00
|
|
|
this.tooltipContent.y = title ? 16 : 4;
|
|
|
|
this.tooltipBg.width = Math.min(Math.max(this.tooltipTitle.displayWidth, this.tooltipContent.displayWidth) + 12, 684);
|
2024-05-23 16:03:10 +01:00
|
|
|
this.tooltipBg.height = (title ? 31 : 19) + 10.5 * (wrappedContent.split("\n").length - 1);
|
|
|
|
if (overlap) {
|
|
|
|
(this.scene as BattleScene).uiContainer.moveAbove(this.tooltipContainer, this);
|
|
|
|
} else {
|
|
|
|
(this.scene as BattleScene).uiContainer.moveBelow(this.tooltipContainer, this);
|
|
|
|
}
|
2023-11-02 04:55:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
hideTooltip(): void {
|
|
|
|
this.tooltipContainer.setVisible(false);
|
|
|
|
this.tooltipTitle.clearTint();
|
|
|
|
}
|
|
|
|
|
|
|
|
update(): void {
|
|
|
|
if (this.tooltipContainer.visible) {
|
|
|
|
const reverse = this.scene.game.input.mousePointer.x >= this.scene.game.canvas.width - this.tooltipBg.width * 6 - 12;
|
|
|
|
this.tooltipContainer.setPosition(!reverse ? this.scene.game.input.mousePointer.x / 6 + 2 : this.scene.game.input.mousePointer.x / 6 - this.tooltipBg.width - 2, this.scene.game.input.mousePointer.y / 6 + 2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-07 05:17:55 +01:00
|
|
|
clearText(): void {
|
2023-03-28 19:54:52 +01:00
|
|
|
const handler = this.getHandler();
|
2024-05-23 16:03:10 +01:00
|
|
|
if (handler instanceof MessageUiHandler) {
|
2023-03-28 19:54:52 +01:00
|
|
|
(handler as MessageUiHandler).clearText();
|
2024-05-23 16:03:10 +01:00
|
|
|
} else {
|
2023-03-28 19:54:52 +01:00
|
|
|
this.getMessageHandler().clearText();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
setCursor(cursor: integer): boolean {
|
|
|
|
const changed = this.getHandler().setCursor(cursor);
|
2024-05-23 16:03:10 +01:00
|
|
|
if (changed) {
|
2023-03-28 19:54:52 +01:00
|
|
|
this.playSelect();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-03-28 19:54:52 +01:00
|
|
|
|
|
|
|
return changed;
|
|
|
|
}
|
|
|
|
|
2023-04-07 05:17:55 +01:00
|
|
|
playSelect(): void {
|
2024-05-23 16:03:10 +01:00
|
|
|
(this.scene as BattleScene).playSound("select");
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-04-07 05:17:55 +01:00
|
|
|
playError(): void {
|
2024-05-23 16:03:10 +01:00
|
|
|
(this.scene as BattleScene).playSound("error");
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-04-22 03:59:09 +01:00
|
|
|
fadeOut(duration: integer): Promise<void> {
|
|
|
|
return new Promise(resolve => {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (this.overlayActive) {
|
2024-03-15 19:13:32 +00:00
|
|
|
return resolve();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-04-22 03:59:09 +01:00
|
|
|
this.overlayActive = true;
|
|
|
|
this.overlay.setAlpha(0);
|
|
|
|
this.overlay.setVisible(true);
|
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.overlay,
|
|
|
|
alpha: 1,
|
|
|
|
duration: duration,
|
2024-05-23 16:03:10 +01:00
|
|
|
ease: "Sine.easeOut",
|
2023-04-22 03:59:09 +01:00
|
|
|
onComplete: () => resolve()
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
fadeIn(duration: integer): Promise<void> {
|
|
|
|
return new Promise(resolve => {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (!this.overlayActive) {
|
2024-03-15 19:13:32 +00:00
|
|
|
return resolve();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-04-22 03:59:09 +01:00
|
|
|
this.scene.tweens.add({
|
|
|
|
targets: this.overlay,
|
|
|
|
alpha: 0,
|
|
|
|
duration: duration,
|
2024-05-23 16:03:10 +01:00
|
|
|
ease: "Sine.easeIn",
|
2023-04-22 03:59:09 +01:00
|
|
|
onComplete: () => {
|
|
|
|
this.overlay.setVisible(false);
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
this.overlayActive = false;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-11-12 05:31:40 +00:00
|
|
|
private setModeInternal(mode: Mode, clear: boolean, forceTransition: boolean, chainMode: boolean, args: any[]): Promise<void> {
|
2023-04-07 03:24:13 +01:00
|
|
|
return new Promise(resolve => {
|
2023-04-10 18:54:06 +01:00
|
|
|
if (this.mode === mode && !forceTransition) {
|
2023-04-07 03:24:13 +01:00
|
|
|
resolve();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const doSetMode = () => {
|
2023-04-10 18:54:06 +01:00
|
|
|
if (this.mode !== mode) {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (clear) {
|
2023-04-10 18:54:06 +01:00
|
|
|
this.getHandler().clear();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
|
|
|
if (chainMode && this.mode && !clear) {
|
2023-11-12 05:31:40 +00:00
|
|
|
this.modeChain.push(this.mode);
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-04-10 18:54:06 +01:00
|
|
|
this.mode = mode;
|
2024-05-23 16:03:10 +01:00
|
|
|
const touchControls = document.getElementById("touchControls");
|
|
|
|
if (touchControls) {
|
2023-12-25 20:03:50 +00:00
|
|
|
touchControls.dataset.uiMode = Mode[mode];
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-04-10 18:54:06 +01:00
|
|
|
this.getHandler().show(args);
|
|
|
|
}
|
2023-04-07 03:24:13 +01:00
|
|
|
resolve();
|
|
|
|
};
|
2023-12-20 04:51:48 +00:00
|
|
|
if (((!chainMode && ((transitionModes.indexOf(this.mode) > -1 || transitionModes.indexOf(mode) > -1)
|
|
|
|
&& (noTransitionModes.indexOf(this.mode) === -1 && noTransitionModes.indexOf(mode) === -1)))
|
2024-02-29 04:13:05 +00:00
|
|
|
|| (chainMode && noTransitionModes.indexOf(mode) === -1))) {
|
2023-04-22 03:59:09 +01:00
|
|
|
this.fadeOut(250).then(() => {
|
|
|
|
this.scene.time.delayedCall(100, () => {
|
|
|
|
doSetMode();
|
|
|
|
this.fadeIn(250);
|
|
|
|
});
|
2024-05-23 16:03:10 +01:00
|
|
|
});
|
|
|
|
} else {
|
2023-04-07 03:24:13 +01:00
|
|
|
doSetMode();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-04-07 03:24:13 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-10-26 21:33:59 +01:00
|
|
|
getMode(): Mode {
|
|
|
|
return this.mode;
|
|
|
|
}
|
|
|
|
|
2023-04-07 03:24:13 +01:00
|
|
|
setMode(mode: Mode, ...args: any[]): Promise<void> {
|
2023-11-12 05:31:40 +00:00
|
|
|
return this.setModeInternal(mode, true, false, false, args);
|
2023-04-10 18:54:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
setModeForceTransition(mode: Mode, ...args: any[]): Promise<void> {
|
2023-11-12 05:31:40 +00:00
|
|
|
return this.setModeInternal(mode, true, true, false, args);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
|
|
|
|
2023-04-07 03:24:13 +01:00
|
|
|
setModeWithoutClear(mode: Mode, ...args: any[]): Promise<void> {
|
2023-11-12 05:31:40 +00:00
|
|
|
return this.setModeInternal(mode, false, false, false, args);
|
|
|
|
}
|
|
|
|
|
|
|
|
setOverlayMode(mode: Mode, ...args: any[]): Promise<void> {
|
|
|
|
return this.setModeInternal(mode, false, false, true, args);
|
2023-03-28 19:54:52 +01:00
|
|
|
}
|
2023-10-26 21:33:59 +01:00
|
|
|
|
2023-12-20 04:51:48 +00:00
|
|
|
revertMode(): Promise<boolean> {
|
|
|
|
return new Promise<boolean>(resolve => {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (!this?.modeChain?.length) {
|
2023-12-20 04:51:48 +00:00
|
|
|
return resolve(false);
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-12-20 04:51:48 +00:00
|
|
|
|
|
|
|
const lastMode = this.mode;
|
|
|
|
|
|
|
|
const doRevertMode = () => {
|
|
|
|
this.getHandler().clear();
|
|
|
|
this.mode = this.modeChain.pop();
|
2024-05-23 16:03:10 +01:00
|
|
|
const touchControls = document.getElementById("touchControls");
|
|
|
|
if (touchControls) {
|
2023-12-25 20:06:56 +00:00
|
|
|
touchControls.dataset.uiMode = Mode[this.mode];
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2024-01-10 04:34:43 +00:00
|
|
|
resolve(true);
|
2023-12-20 04:51:48 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if (noTransitionModes.indexOf(lastMode) === -1) {
|
|
|
|
this.fadeOut(250).then(() => {
|
|
|
|
this.scene.time.delayedCall(100, () => {
|
|
|
|
doRevertMode();
|
|
|
|
this.fadeIn(250);
|
|
|
|
});
|
|
|
|
});
|
2024-05-23 16:03:10 +01:00
|
|
|
} else {
|
2023-12-20 04:51:48 +00:00
|
|
|
doRevertMode();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-12-20 04:51:48 +00:00
|
|
|
});
|
2023-10-26 21:33:59 +01:00
|
|
|
}
|
2023-12-30 23:41:25 +00:00
|
|
|
|
|
|
|
revertModes(): Promise<void> {
|
|
|
|
return new Promise<void>(resolve => {
|
2024-05-23 16:03:10 +01:00
|
|
|
if (!this?.modeChain?.length) {
|
2023-12-30 23:41:25 +00:00
|
|
|
return resolve();
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|
2023-12-30 23:41:25 +00:00
|
|
|
this.revertMode().then(success => Utils.executeIf(success, this.revertModes).then(() => resolve()));
|
|
|
|
});
|
|
|
|
}
|
2024-05-23 16:03:10 +01:00
|
|
|
}
|