feat: v1 prototype — core game systems #30

Merged
naomi merged 84 commits from feat/prototype into main 2026-03-08 15:53:39 -07:00
2 changed files with 8 additions and 3 deletions
Showing only changes of commit 58e7000954 - Show all commits
+3 -2
View File
@@ -75,8 +75,9 @@ exploreRouter.post("/start", async (context) => {
return context.json({ error: "Exploration area not found in state" }, 404);
}
if (area.status === "in_progress") {
return context.json({ error: "Exploration already in progress" }, 400);
const anyInProgress = state.exploration.areas.some((a) => a.status === "in_progress");
if (anyInProgress) {
return context.json({ error: "An exploration is already in progress" }, 400);
}
if (area.status === "locked") {
@@ -38,6 +38,9 @@ export const ExplorationPanel = (): React.JSX.Element => {
const zoneAreas = EXPLORATION_AREAS.filter((a) => a.zoneId === activeZoneId);
const hasActiveExploration =
explorationState?.areas.some((a) => a.status === "in_progress") ?? false;
const handleStart = async (areaId: string): Promise<void> => {
setPendingAreaId(areaId);
try {
@@ -137,8 +140,9 @@ export const ExplorationPanel = (): React.JSX.Element => {
{status === "available" && (
<button
className="start-quest-button"
disabled={isPending}
disabled={isPending || hasActiveExploration}
onClick={() => { void handleStart(area.id); }}
title={hasActiveExploration ? "An exploration is already in progress" : undefined}
type="button"
>
{isPending ? "Departing..." : `Explore (${formatDuration(area.durationSeconds)})`}