silphius/app/react/components/pixi/ecs.jsx

87 lines
2.4 KiB
React
Raw Normal View History

2024-06-12 13:19:16 -05:00
import {Container} from '@pixi/react';
2024-07-31 09:29:33 -05:00
import {useCallback, useState} from 'react';
2024-06-10 22:42:30 -05:00
2024-07-31 09:29:33 -05:00
import {useEcsTick} from '@/react/context/ecs.js';
2024-07-20 04:32:33 -05:00
import {useMainEntity} from '@/react/context/main-entity.js';
2024-06-10 22:42:30 -05:00
2024-06-11 18:42:48 -05:00
import Entities from './entities.jsx';
2024-06-18 04:36:44 -05:00
import TargetingGhost from './targeting-ghost.jsx';
2024-06-25 01:46:07 -05:00
import TargetingGrid from './targeting-grid.jsx';
2024-06-11 18:42:48 -05:00
import TileLayer from './tile-layer.jsx';
2024-06-28 16:38:49 -05:00
import Water from './water.jsx';
2024-06-11 15:06:43 -05:00
2024-07-30 12:31:40 -05:00
export default function Ecs({camera, monopolizers, particleWorker, scale}) {
const [mainEntity] = useMainEntity();
2024-07-11 03:09:28 -05:00
const [layers, setLayers] = useState([]);
2024-07-04 15:17:33 -05:00
const [hour, setHour] = useState(10);
2024-07-11 03:09:28 -05:00
const [projected, setProjected] = useState([]);
const [position, setPosition] = useState({x: 0, y: 0});
const [water, setWater] = useState();
2024-07-31 09:29:33 -05:00
const onEcsTick = useCallback((payload, ecs) => {
2024-07-11 03:09:28 -05:00
const entity = ecs.get(mainEntity);
for (const id in payload) {
const update = payload[id];
2024-07-11 03:09:28 -05:00
switch (id) {
case '1': {
const master = ecs.get(1);
if (update.TileLayers) {
setLayers(Object.values(master.TileLayers.$$layersProxies));
}
2024-07-04 15:17:33 -05:00
if (update.Time) {
setHour(Math.round(ecs.get(1).Time.hour * 60) / 60);
}
2024-07-11 03:09:28 -05:00
if (update.Water) {
setWater(master.Water.water);
}
break;
2024-07-04 15:17:33 -05:00
}
2024-06-10 22:42:30 -05:00
}
}
2024-07-11 03:09:28 -05:00
if (entity) {
const {Direction, Position, Wielder} = entity;
setPosition(Position.toJSON());
2024-07-24 09:28:35 -05:00
setProjected(Wielder.activeItem()?.project(Position.tile, Direction.quantize(4)));
2024-07-11 03:09:28 -05:00
}
2024-07-31 09:29:33 -05:00
}, [mainEntity]);
useEcsTick(onEcsTick);
2024-06-10 22:42:30 -05:00
return (
2024-06-24 09:19:24 -05:00
<Container
2024-07-01 13:44:52 -05:00
scale={scale}
2024-07-11 03:09:28 -05:00
x={-camera.x}
y={-camera.y}
2024-06-24 09:19:24 -05:00
>
2024-07-30 12:31:40 -05:00
<Container>
2024-07-11 03:09:28 -05:00
{layers.map((layer, i) => (
2024-07-07 17:34:40 -05:00
<TileLayer
2024-07-11 03:09:28 -05:00
key={i}
tileLayer={layer}
2024-07-07 17:34:40 -05:00
/>
2024-07-11 03:09:28 -05:00
))}
2024-07-05 18:25:57 -05:00
</Container>
2024-07-11 03:09:28 -05:00
{water && layers[0] && (
2024-07-07 17:34:40 -05:00
<Water
2024-07-11 03:09:28 -05:00
tileLayer={layers[0]}
water={water}
2024-07-07 17:34:40 -05:00
/>
2024-07-02 22:43:04 -05:00
)}
2024-07-11 03:09:28 -05:00
{projected && layers[0] && (
2024-06-25 08:41:20 -05:00
<TargetingGrid
2024-07-11 03:09:28 -05:00
tileLayer={layers[0]}
x={position.x}
y={position.y}
2024-06-25 08:41:20 -05:00
/>
2024-06-25 01:46:07 -05:00
)}
2024-07-05 18:25:57 -05:00
<Entities
2024-07-13 17:08:23 -05:00
monopolizers={monopolizers}
2024-07-30 09:56:53 -05:00
particleWorker={particleWorker}
2024-07-05 18:25:57 -05:00
/>
2024-07-11 03:09:28 -05:00
{projected?.length > 0 && layers[0] && (
2024-06-25 06:20:45 -05:00
<TargetingGhost
2024-06-28 08:53:20 -05:00
projected={projected}
2024-07-11 03:09:28 -05:00
tileLayer={layers[0]}
2024-06-25 06:20:45 -05:00
/>
2024-06-24 09:01:30 -05:00
)}
2024-06-11 15:06:43 -05:00
</Container>
2024-06-10 22:42:30 -05:00
)
}