LasTres/js-src/components/game.tsx

118 lines
5.1 KiB
TypeScript
Raw Normal View History

2023-06-01 08:45:43 +02:00
import * as React from 'react'
import type { PJ } from '@lastres/pj'
import type { Location } from '@lastres/location'
import type { LogLine } from '@lastres/log-line'
import type { ActionHash } from '@lastres/action'
2023-06-08 09:02:32 +02:00
2023-06-01 08:45:43 +02:00
import UpperPanel from '@lastres/components/upper-panel'
import BottomPanel from '@lastres/components/bottom-panel'
import PJSelectionMenu from '@lastres/components/pj-selection-menu'
import OutputPacketInit from '@lastres/output-packet/init'
import OutputPacketPing from '@lastres/output-packet/ping'
import InputPackets from '@lastres/input-packets'
2023-06-01 08:45:43 +02:00
export type SetWebsocketCallback = (websocket: WebSocket | null) => WebSocket | null
2023-06-01 08:45:43 +02:00
export interface GameProps {
2023-06-08 09:02:32 +02:00
setSelectedPJ: (set: PJ | null) => void
selectedPJ: PJ | null
2023-06-01 08:45:43 +02:00
userWantsToCreatePJ: boolean
setUserWantsToCreatePJ: (set: boolean) => void
error: string | null
setError: (set: string | null) => void
websocket: WebSocket | null
setWebsocket: (websocket: WebSocket | null | SetWebsocketCallback) => void
2023-06-01 08:45:43 +02:00
}
export default function Game (props: GameProps): JSX.Element {
const selectedPJ = props.selectedPJ
if (selectedPJ === null) {
2023-06-01 08:45:43 +02:00
return (
<>
<PJSelectionMenu
setSelectedPJ={props.setSelectedPJ}
userWantsToCreatePJ={props.userWantsToCreatePJ}
setUserWantsToCreatePJ={props.setUserWantsToCreatePJ}
error={props.error}
setError={props.setError}/>
</>
)
}
const [teamPJs, setTeamPJs] = React.useState<PJ[] | null>(null)
2023-06-27 07:10:56 +02:00
const [enemyTeamPJs, setEnemyTeamPJs] = React.useState<PJ[] | null>(null)
const [isBattling, setIsBattling] = React.useState<boolean | null>(null)
const [currentLocation, setCurrentLocation] = React.useState<Location | null>(null)
const [connectedLocations, setConnectedLocations] = React.useState<Location[] | null>(null)
const [logLines, setLogLines] = React.useState<LogLine[] | null>(null)
const [error, setError] = React.useState<string | null>(null)
const [scrollLog, setScrollLog] = React.useState<number | null>(null)
2023-06-23 01:39:47 +02:00
const [movingTo, setMovingTo] = React.useState<Location | null>(null)
const [remainingFrames, setRemainingFrames] = React.useState<number | null>(null)
const [actionHash, setActionHash] = React.useState<ActionHash | null>(null)
const logPresentationRef = React.useRef<HTMLDivElement>(null)
const websocket = props.websocket
const setWebsocket = props.setWebsocket
window.setTimeout(() => {
setWebsocket((websocket): WebSocket | null => {
if (websocket === null) {
2023-06-29 09:14:02 +02:00
console.log('Opening websocket');
const locationProtocol = window.location.protocol
if (locationProtocol == null) {
return null
}
const protocol = locationProtocol.match(/https:/) != null ? 'wss' : 'ws'
const webSocket = new WebSocket(`${protocol}://${window.location.host}/ws`)
webSocket.onopen = () => {
new OutputPacketInit(selectedPJ.uuid).send(webSocket)
let interval: number = 0
interval = window.setInterval(() => {
if (webSocket.readyState === WebSocket.CONNECTING) {
return
}
if (webSocket.readyState === WebSocket.OPEN) {
new OutputPacketPing().send(webSocket)
return
}
window.clearInterval(interval)
}, 1000)
}
const inputPackets = new InputPackets(setTeamPJs,
2023-06-27 07:10:56 +02:00
setEnemyTeamPJs, setIsBattling,
setCurrentLocation, setConnectedLocations,
2023-06-27 07:10:56 +02:00
logLines, setLogLines, setError,
setScrollLog, logPresentationRef,
setMovingTo, setRemainingFrames,
setActionHash)
webSocket.onmessage = (event) => {
const packet = JSON.parse(event.data)
inputPackets.handle(packet)
}
webSocket.onerror = (event) => {
console.log(event)
}
2023-06-22 21:54:28 +02:00
webSocket.onclose = (event) => {
2023-06-23 01:39:47 +02:00
console.log('Websocket closed')
2023-06-22 21:54:28 +02:00
setWebsocket(null)
}
return webSocket
}
return websocket
})
2023-06-29 09:14:02 +02:00
}, 300)
2023-06-01 08:45:43 +02:00
return (
<>
<UpperPanel teamPJs={teamPJs}
2023-06-27 07:10:56 +02:00
enemyTeamPJs={enemyTeamPJs}
isBattling={isBattling}
currentLocation={currentLocation}
connectedLocations={connectedLocations}
logLines={logLines}
websocket={websocket}
2023-06-23 01:39:47 +02:00
logPresentationRef={logPresentationRef}
movingTo={movingTo}
remainingFrames={remainingFrames}/>
<BottomPanel actionHash={actionHash} websocket={websocket}/>
2023-06-01 08:45:43 +02:00
</>
)
}