2024-05-03 18:59:10 +02:00
|
|
|
import BattleScene from "../battle-scene";
|
2024-03-31 21:14:35 -04:00
|
|
|
import { TextStyle, getTextColor } from "./text";
|
2023-03-28 14:54:52 -04:00
|
|
|
import UI, { Mode } from "./ui";
|
2024-05-03 18:59:10 +02:00
|
|
|
import {Button} from "#app/inputs-controller";
|
2023-03-28 14:54:52 -04:00
|
|
|
|
|
|
|
export default abstract class UiHandler {
|
|
|
|
protected scene: BattleScene;
|
|
|
|
protected mode: integer;
|
|
|
|
protected cursor: integer = 0;
|
2023-03-29 00:31:25 -04:00
|
|
|
public active: boolean = false;
|
2023-03-28 14:54:52 -04:00
|
|
|
|
|
|
|
constructor(scene: BattleScene, mode: Mode) {
|
|
|
|
this.scene = scene;
|
|
|
|
this.mode = mode;
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract setup(): void;
|
|
|
|
|
2023-12-30 18:41:25 -05:00
|
|
|
show(_args: any[]): boolean {
|
2023-03-28 14:54:52 -04:00
|
|
|
this.active = true;
|
2023-12-30 18:41:25 -05:00
|
|
|
|
|
|
|
return true;
|
2023-03-28 14:54:52 -04:00
|
|
|
}
|
|
|
|
|
2023-11-12 00:31:40 -05:00
|
|
|
abstract processInput(button: Button): boolean;
|
2023-03-28 14:54:52 -04:00
|
|
|
|
|
|
|
getUi() {
|
|
|
|
return this.scene.ui;
|
|
|
|
}
|
|
|
|
|
2024-03-31 21:14:35 -04:00
|
|
|
getTextColor(style: TextStyle, shadow: boolean = false): string {
|
|
|
|
return getTextColor(style, shadow, this.scene.uiTheme);
|
|
|
|
}
|
|
|
|
|
2023-03-30 23:02:35 -04:00
|
|
|
getCursor(): integer {
|
|
|
|
return this.cursor;
|
|
|
|
}
|
|
|
|
|
2023-03-28 14:54:52 -04:00
|
|
|
setCursor(cursor: integer): boolean {
|
|
|
|
const changed = this.cursor !== cursor;
|
|
|
|
if (changed)
|
|
|
|
this.cursor = cursor;
|
|
|
|
|
|
|
|
return changed;
|
|
|
|
}
|
|
|
|
|
|
|
|
clear() {
|
|
|
|
this.active = false;
|
|
|
|
}
|
|
|
|
}
|