ui/phase-13: planet inspector — read-only
Plumbs the map → inspector pathway: a click on a planet selects it through the new SelectionStore, the sidebar Inspector tab swaps its empty-state copy for a per-kind read-only field set, and a mobile-only bottom-sheet mirrors the same content over the map. Field projection in api/game-state.ts now surfaces every documented planet field.
This commit is contained in:
@@ -4,8 +4,12 @@
|
||||
// engine container.
|
||||
//
|
||||
// Phase 11 only renders planets, so the helpers keep the report shape
|
||||
// minimal (turn / dimensions / planet vectors). Later phases extend
|
||||
// the helper as ships, fleets, sciences, etc. land.
|
||||
// minimal (turn / dimensions / planet vectors). Phase 13 extended the
|
||||
// fixture with the optional rich planet fields (size, resources,
|
||||
// stockpiles, population, industry, colonists, production, free
|
||||
// industry) so the inspector e2e can drive the read-only display
|
||||
// against realistic values. Later phases extend the helper as ships,
|
||||
// fleets, sciences, etc. land.
|
||||
|
||||
import { Builder } from "flatbuffers";
|
||||
|
||||
@@ -22,9 +26,21 @@ export interface PlanetFixture {
|
||||
name: string;
|
||||
x: number;
|
||||
y: number;
|
||||
size?: number;
|
||||
resources?: number;
|
||||
capital?: number;
|
||||
material?: number;
|
||||
}
|
||||
|
||||
export interface OtherPlanetFixture extends PlanetFixture {
|
||||
export interface InhabitedFixture extends PlanetFixture {
|
||||
population?: number;
|
||||
colonists?: number;
|
||||
industry?: number;
|
||||
production?: string;
|
||||
freeIndustry?: number;
|
||||
}
|
||||
|
||||
export interface OtherPlanetFixture extends InhabitedFixture {
|
||||
owner: string;
|
||||
}
|
||||
|
||||
@@ -32,7 +48,7 @@ export interface ReportFixture {
|
||||
turn: number;
|
||||
mapWidth?: number;
|
||||
mapHeight?: number;
|
||||
localPlanets?: PlanetFixture[];
|
||||
localPlanets?: InhabitedFixture[];
|
||||
otherPlanets?: OtherPlanetFixture[];
|
||||
uninhabitedPlanets?: PlanetFixture[];
|
||||
unidentifiedPlanets?: { number: number; x: number; y: number }[];
|
||||
@@ -43,28 +59,49 @@ export function buildReportPayload(fixture: ReportFixture): Uint8Array {
|
||||
|
||||
const localOffsets = (fixture.localPlanets ?? []).map((planet) => {
|
||||
const name = builder.createString(planet.name);
|
||||
const production =
|
||||
planet.production !== undefined
|
||||
? builder.createString(planet.production)
|
||||
: null;
|
||||
LocalPlanet.startLocalPlanet(builder);
|
||||
LocalPlanet.addNumber(builder, BigInt(planet.number));
|
||||
LocalPlanet.addX(builder, planet.x);
|
||||
LocalPlanet.addY(builder, planet.y);
|
||||
LocalPlanet.addName(builder, name);
|
||||
LocalPlanet.addSize(builder, 10);
|
||||
LocalPlanet.addResources(builder, 0.5);
|
||||
LocalPlanet.addPopulation(builder, 0);
|
||||
LocalPlanet.addIndustry(builder, 0);
|
||||
LocalPlanet.addSize(builder, planet.size ?? 10);
|
||||
LocalPlanet.addResources(builder, planet.resources ?? 0.5);
|
||||
LocalPlanet.addCapital(builder, planet.capital ?? 0);
|
||||
LocalPlanet.addMaterial(builder, planet.material ?? 0);
|
||||
LocalPlanet.addPopulation(builder, planet.population ?? 0);
|
||||
LocalPlanet.addIndustry(builder, planet.industry ?? 0);
|
||||
LocalPlanet.addColonists(builder, planet.colonists ?? 0);
|
||||
if (production !== null) LocalPlanet.addProduction(builder, production);
|
||||
LocalPlanet.addFreeIndustry(builder, planet.freeIndustry ?? 0);
|
||||
return LocalPlanet.endLocalPlanet(builder);
|
||||
});
|
||||
|
||||
const otherOffsets = (fixture.otherPlanets ?? []).map((planet) => {
|
||||
const name = builder.createString(planet.name);
|
||||
const owner = builder.createString(planet.owner);
|
||||
const production =
|
||||
planet.production !== undefined
|
||||
? builder.createString(planet.production)
|
||||
: null;
|
||||
OtherPlanet.startOtherPlanet(builder);
|
||||
OtherPlanet.addNumber(builder, BigInt(planet.number));
|
||||
OtherPlanet.addX(builder, planet.x);
|
||||
OtherPlanet.addY(builder, planet.y);
|
||||
OtherPlanet.addName(builder, name);
|
||||
OtherPlanet.addOwner(builder, owner);
|
||||
OtherPlanet.addSize(builder, 9);
|
||||
OtherPlanet.addSize(builder, planet.size ?? 9);
|
||||
OtherPlanet.addResources(builder, planet.resources ?? 0.5);
|
||||
OtherPlanet.addCapital(builder, planet.capital ?? 0);
|
||||
OtherPlanet.addMaterial(builder, planet.material ?? 0);
|
||||
OtherPlanet.addPopulation(builder, planet.population ?? 0);
|
||||
OtherPlanet.addIndustry(builder, planet.industry ?? 0);
|
||||
OtherPlanet.addColonists(builder, planet.colonists ?? 0);
|
||||
if (production !== null) OtherPlanet.addProduction(builder, production);
|
||||
OtherPlanet.addFreeIndustry(builder, planet.freeIndustry ?? 0);
|
||||
return OtherPlanet.endOtherPlanet(builder);
|
||||
});
|
||||
|
||||
@@ -76,7 +113,10 @@ export function buildReportPayload(fixture: ReportFixture): Uint8Array {
|
||||
UninhabitedPlanet.addX(builder, planet.x);
|
||||
UninhabitedPlanet.addY(builder, planet.y);
|
||||
UninhabitedPlanet.addName(builder, name);
|
||||
UninhabitedPlanet.addSize(builder, 6);
|
||||
UninhabitedPlanet.addSize(builder, planet.size ?? 6);
|
||||
UninhabitedPlanet.addResources(builder, planet.resources ?? 0.5);
|
||||
UninhabitedPlanet.addCapital(builder, planet.capital ?? 0);
|
||||
UninhabitedPlanet.addMaterial(builder, planet.material ?? 0);
|
||||
return UninhabitedPlanet.endUninhabitedPlanet(builder);
|
||||
},
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user