pokerogue/src/ui/confirm-ui-handler.ts

58 lines
1.6 KiB
TypeScript
Raw Normal View History

import BattleScene from "../battle-scene";
import AbstractOptionSelectUiHandler, { OptionSelectConfig } from "./abstact-option-select-ui-handler";
import { Mode } from "./ui";
2023-11-13 19:29:03 -08:00
export default class ConfirmUiHandler extends AbstractOptionSelectUiHandler {
private switchCheck: boolean;
private switchCheckCursor: integer;
constructor(scene: BattleScene) {
super(scene, Mode.CONFIRM);
}
getWindowWidth(): integer {
return 48;
}
2023-12-30 15:41:25 -08:00
show(args: any[]): boolean {
if (args.length >= 2 && args[0] instanceof Function && args[1] instanceof Function) {
const config: OptionSelectConfig = {
options: [
{
label: 'Yes',
handler: args[0]
},
{
label: 'No',
handler: args[1]
}
2024-04-04 12:22:05 -07:00
],
delay: args.length >= 6 && args[5] !== null ? args[5] as integer : 0
};
super.show([ config ]);
2024-02-06 20:11:00 -08:00
this.switchCheck = args.length >= 3 && args[2] !== null && args[2] as boolean;
2024-02-06 20:11:00 -08:00
const xOffset = (args.length >= 4 && args[3] !== null ? args[3] as number : 0);
const yOffset = (args.length >= 5 && args[4] !== null ? args[4] as number : 0);
2023-12-26 11:49:23 -08:00
2024-02-06 20:11:00 -08:00
this.optionSelectContainer.setPosition((this.scene.game.canvas.width / 6) - 1 + xOffset, -48 + yOffset);
2023-12-26 11:49:23 -08:00
this.setCursor(this.switchCheck ? this.switchCheckCursor : 0);
2023-12-30 15:41:25 -08:00
return true;
}
2023-12-30 15:41:25 -08:00
return false;
}
setCursor(cursor: integer): boolean {
const ret = super.setCursor(cursor);
if (ret && this.switchCheck)
this.switchCheckCursor = this.cursor;
return ret;
}
}