Replace sleep modal
This commit is contained in:
parent
de04ad09ef
commit
1f8ac16272
@ -95,7 +95,8 @@ export class CheckModal {
|
|||||||
) => {
|
) => {
|
||||||
let accomplished: boolean;
|
let accomplished: boolean;
|
||||||
let optionLabel: string;
|
let optionLabel: string;
|
||||||
let resultMessage: string;
|
let resultMessage: string | null;
|
||||||
|
let endorse = false;
|
||||||
if ((option as ChoiceOption).isChoice) {
|
if ((option as ChoiceOption).isChoice) {
|
||||||
// TODO: Use OOP here
|
// TODO: Use OOP here
|
||||||
option = option as ChoiceOption;
|
option = option as ChoiceOption;
|
||||||
@ -110,6 +111,7 @@ export class CheckModal {
|
|||||||
// hasSkill ||= true;
|
// hasSkill ||= true;
|
||||||
if (hasSkill) {
|
if (hasSkill) {
|
||||||
optionLabel = `[${skillName}] ${option.unlockable}`;
|
optionLabel = `[${skillName}] ${option.unlockable}`;
|
||||||
|
endorse = true;
|
||||||
} else {
|
} else {
|
||||||
optionLabel = `[Needs ${skillName}] ${option.locked}`;
|
optionLabel = `[Needs ${skillName}] ${option.locked}`;
|
||||||
}
|
}
|
||||||
@ -125,7 +127,11 @@ export class CheckModal {
|
|||||||
cb();
|
cb();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
if (resultMessage == null) {
|
||||||
|
this.show(null, null);
|
||||||
|
}
|
||||||
|
}, {endorse});
|
||||||
};
|
};
|
||||||
|
|
||||||
if (options.length == 0) {
|
if (options.length == 0) {
|
||||||
|
12
src/game.ts
12
src/game.ts
@ -4,7 +4,6 @@ import { IGame, Point, Size } from "./engine/datatypes.ts";
|
|||||||
import { getPageLocation, Page } from "./layout.ts";
|
import { getPageLocation, Page } from "./layout.ts";
|
||||||
import { getHotbar, Hotbar } from "./hotbar.ts";
|
import { getHotbar, Hotbar } from "./hotbar.ts";
|
||||||
import { getSkillsModal, SkillsModal } from "./skillsmodal.ts";
|
import { getSkillsModal, SkillsModal } from "./skillsmodal.ts";
|
||||||
import { getSleepModal, SleepModal } from "./sleepmodal.ts";
|
|
||||||
import { getVNModal, VNModal } from "./vnmodal.ts";
|
import { getVNModal, VNModal } from "./vnmodal.ts";
|
||||||
import { Gameplay, getGameplay } from "./gameplay.ts";
|
import { Gameplay, getGameplay } from "./gameplay.ts";
|
||||||
import { getEndgameModal } from "./endgamemodal.ts";
|
import { getEndgameModal } from "./endgamemodal.ts";
|
||||||
@ -37,7 +36,7 @@ export class Game implements IGame {
|
|||||||
camera: MenuCamera;
|
camera: MenuCamera;
|
||||||
page: Page;
|
page: Page;
|
||||||
#mainThing: Gameplay | VNModal | null;
|
#mainThing: Gameplay | VNModal | null;
|
||||||
#bottomThing: CheckModal | SkillsModal | SleepModal | Hotbar | null;
|
#bottomThing: CheckModal | SkillsModal | Hotbar | null;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
this.camera = new MenuCamera({
|
this.camera = new MenuCamera({
|
||||||
@ -123,15 +122,6 @@ export class Game implements IGame {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// between skillsModal and sleepModal, skillsModal wins
|
|
||||||
// this is important because skillsModal can be
|
|
||||||
// activated from sleepModal
|
|
||||||
let sleepModal = getSleepModal();
|
|
||||||
if (sleepModal.isShown) {
|
|
||||||
this.#bottomThing = sleepModal;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// use the hotbar only as a matter of last resort
|
// use the hotbar only as a matter of last resort
|
||||||
this.#bottomThing = getHotbar();
|
this.#bottomThing = getHotbar();
|
||||||
}
|
}
|
||||||
|
@ -3,8 +3,9 @@ import { DrawPile } from "./drawpile.ts";
|
|||||||
import { withCamera } from "./layout.ts";
|
import { withCamera } from "./layout.ts";
|
||||||
import { getSkillsModal } from "./skillsmodal.ts";
|
import { getSkillsModal } from "./skillsmodal.ts";
|
||||||
import { addButton } from "./button.ts";
|
import { addButton } from "./button.ts";
|
||||||
import { getSleepModal } from "./sleepmodal.ts";
|
|
||||||
import {getPlayerProgress} from "./playerprogress.ts";
|
import {getPlayerProgress} from "./playerprogress.ts";
|
||||||
|
import {getStateManager} from "./statemanager.ts";
|
||||||
|
import {getCheckModal} from "./checkmodal.ts";
|
||||||
|
|
||||||
type Button = {
|
type Button = {
|
||||||
label: string;
|
label: string;
|
||||||
@ -46,15 +47,46 @@ export class Hotbar {
|
|||||||
*/
|
*/
|
||||||
buttons.push({
|
buttons.push({
|
||||||
label: "Sleep",
|
label: "Sleep",
|
||||||
cbClick: () => {
|
cbClick: () => { this.#offerSleep(); },
|
||||||
getSleepModal().setShown(true);
|
|
||||||
},
|
|
||||||
enabled: true,
|
enabled: true,
|
||||||
endorse: getPlayerProgress().getBlood() < 100,
|
endorse: getPlayerProgress().getBlood() < 100,
|
||||||
});
|
});
|
||||||
return buttons;
|
return buttons;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#offerSleep() {
|
||||||
|
let bloodAmount = getPlayerProgress().getBlood();
|
||||||
|
let sleepText = "You're exhausted.";
|
||||||
|
if (bloodAmount > 100) {
|
||||||
|
sleepText = "You've got some energy left -- are you sure you want to sleep?";
|
||||||
|
} else if (bloodAmount > 2000) {
|
||||||
|
sleepText = "Are you sure you want to sleep? You have so much energy.";
|
||||||
|
}
|
||||||
|
|
||||||
|
getCheckModal().show(
|
||||||
|
{
|
||||||
|
label: sleepText,
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
isChoice: true,
|
||||||
|
countsAsSuccess: true,
|
||||||
|
unlockable: "Sleep",
|
||||||
|
success: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
isChoice: true,
|
||||||
|
countsAsSuccess: false,
|
||||||
|
unlockable: "Refrain",
|
||||||
|
success: null,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
},
|
||||||
|
() => {
|
||||||
|
getStateManager().advance();
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
update() {
|
update() {
|
||||||
withCamera("Hotbar", () => this.#update());
|
withCamera("Hotbar", () => this.#update());
|
||||||
}
|
}
|
||||||
|
@ -16,14 +16,14 @@ export type ChoiceOption = {
|
|||||||
isChoice: true;
|
isChoice: true;
|
||||||
countsAsSuccess: boolean;
|
countsAsSuccess: boolean;
|
||||||
unlockable: string;
|
unlockable: string;
|
||||||
success: string;
|
success: string | null;
|
||||||
};
|
};
|
||||||
export type CheckDataOption = {
|
export type CheckDataOption = {
|
||||||
skill: () => Skill;
|
skill: () => Skill;
|
||||||
locked: string;
|
locked: string;
|
||||||
failure: string;
|
failure: string;
|
||||||
unlockable: string;
|
unlockable: string;
|
||||||
success: string;
|
success: string | null;
|
||||||
};
|
};
|
||||||
|
|
||||||
export class LoadedNewMap {
|
export class LoadedNewMap {
|
||||||
|
@ -1,77 +0,0 @@
|
|||||||
import { DrawPile } from "./drawpile.ts";
|
|
||||||
import { Point, Rect, Size } from "./engine/datatypes.ts";
|
|
||||||
import { getPartLocation, withCamera } from "./layout.ts";
|
|
||||||
import { addButton } from "./button.ts";
|
|
||||||
import { D } from "./engine/public.ts";
|
|
||||||
import { BG_INSET } from "./colors.ts";
|
|
||||||
import { getSkillsModal } from "./skillsmodal.ts";
|
|
||||||
import { getStateManager } from "./statemanager.ts";
|
|
||||||
|
|
||||||
export class SleepModal {
|
|
||||||
#drawpile: DrawPile;
|
|
||||||
#shown: boolean;
|
|
||||||
|
|
||||||
constructor() {
|
|
||||||
this.#drawpile = new DrawPile();
|
|
||||||
this.#shown = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
get #size(): Size {
|
|
||||||
// We share this logic with SkillModal:
|
|
||||||
// Instead of calculating this here, compute it from outside
|
|
||||||
// as it has to be the same for every bottom modal
|
|
||||||
return getPartLocation("BottomModal").size;
|
|
||||||
}
|
|
||||||
|
|
||||||
get isShown(): boolean {
|
|
||||||
return this.#shown;
|
|
||||||
}
|
|
||||||
|
|
||||||
setShown(shown: boolean) {
|
|
||||||
this.#shown = shown;
|
|
||||||
}
|
|
||||||
|
|
||||||
update() {
|
|
||||||
withCamera("BottomModal", () => this.#update());
|
|
||||||
}
|
|
||||||
|
|
||||||
draw() {
|
|
||||||
withCamera("BottomModal", () => this.#draw());
|
|
||||||
}
|
|
||||||
|
|
||||||
#update() {
|
|
||||||
this.#drawpile.clear();
|
|
||||||
let size = this.#size;
|
|
||||||
this.#drawpile.add(0, () => {
|
|
||||||
D.fillRect(new Point(-4, -4), size.add(new Size(8, 8)), BG_INSET);
|
|
||||||
});
|
|
||||||
|
|
||||||
// add close button
|
|
||||||
let closeRect = new Rect(new Point(0, 96), new Size(80, 32));
|
|
||||||
addButton(this.#drawpile, "Back", closeRect, true, () => {
|
|
||||||
this.setShown(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
let skillsRect = new Rect(new Point(80, 96), new Size(80, 32));
|
|
||||||
addButton(this.#drawpile, "Skills", skillsRect, true, () => {
|
|
||||||
getSkillsModal().setShown(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
let remainingWidth = size.w - 160;
|
|
||||||
let nextRect = new Rect(new Point(160, 96), new Size(remainingWidth, 32));
|
|
||||||
addButton(this.#drawpile, "Sleep (Next Day)", nextRect, true, () => {
|
|
||||||
getStateManager().advance();
|
|
||||||
});
|
|
||||||
|
|
||||||
this.#drawpile.executeOnClick();
|
|
||||||
}
|
|
||||||
|
|
||||||
#draw() {
|
|
||||||
this.#drawpile.draw();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let active = new SleepModal();
|
|
||||||
export function getSleepModal(): SleepModal {
|
|
||||||
return active;
|
|
||||||
}
|
|
@ -1,6 +1,5 @@
|
|||||||
import { getPlayerProgress, initPlayerProgress } from "./playerprogress.ts";
|
import { getPlayerProgress, initPlayerProgress } from "./playerprogress.ts";
|
||||||
import { getHuntMode, HuntMode, initHuntMode } from "./huntmode.ts";
|
import { getHuntMode, HuntMode, initHuntMode } from "./huntmode.ts";
|
||||||
import { getSleepModal } from "./sleepmodal.ts";
|
|
||||||
import { getVNModal } from "./vnmodal.ts";
|
import { getVNModal } from "./vnmodal.ts";
|
||||||
import { getScorer } from "./scorer.ts";
|
import { getScorer } from "./scorer.ts";
|
||||||
import { getEndgameModal } from "./endgamemodal.ts";
|
import { getEndgameModal } from "./endgamemodal.ts";
|
||||||
@ -27,8 +26,6 @@ export class StateManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
advance() {
|
advance() {
|
||||||
getSleepModal().setShown(false);
|
|
||||||
|
|
||||||
if (this.#turn + 1 <= N_TURNS) {
|
if (this.#turn + 1 <= N_TURNS) {
|
||||||
this.#turn += 1;
|
this.#turn += 1;
|
||||||
getPlayerProgress().applyEndOfTurn();
|
getPlayerProgress().applyEndOfTurn();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user