2023-06-01 08:45:43 +02:00
|
|
|
import * as React from 'react'
|
|
|
|
|
2023-06-13 02:43:52 +02:00
|
|
|
import type { PJ } from '@lastres/pj'
|
|
|
|
import type { Location } from '@lastres/location'
|
|
|
|
import type { LogLine } from '@lastres/log-line'
|
2023-06-30 19:59:18 +02:00
|
|
|
import type { ActionHash } from '@lastres/action'
|
2023-07-09 18:41:21 +02:00
|
|
|
import type { TalkNPCs } from '@lastres/talk-npc'
|
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'
|
2023-06-13 02:43:52 +02:00
|
|
|
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
|
|
|
|
2023-06-23 21:30:04 +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
|
2023-06-23 21:30:04 +02:00
|
|
|
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 {
|
2023-06-13 02:43:52 +02:00
|
|
|
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}/>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
2023-06-13 02:43:52 +02:00
|
|
|
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)
|
2023-06-13 02:43:52 +02:00
|
|
|
const [currentLocation, setCurrentLocation] = React.useState<Location | null>(null)
|
|
|
|
const [connectedLocations, setConnectedLocations] = React.useState<Location[] | null>(null)
|
|
|
|
const [logLines, setLogLines] = React.useState<LogLine[] | null>(null)
|
2023-06-18 20:29:42 +02:00
|
|
|
const [error, setError] = React.useState<string | null>(null)
|
2023-06-19 17:15:00 +02:00
|
|
|
const [scrollLog, setScrollLog] = React.useState<number | null>(null)
|
2023-06-23 01:39:47 +02:00
|
|
|
const [movingTo, setMovingTo] = React.useState<Location | null>(null)
|
2023-06-23 02:31:11 +02:00
|
|
|
const [remainingFrames, setRemainingFrames] = React.useState<number | null>(null)
|
2023-06-30 19:59:18 +02:00
|
|
|
const [actionHash, setActionHash] = React.useState<ActionHash | null>(null)
|
2023-07-09 18:41:21 +02:00
|
|
|
const [talkNPCs, setTalkNPCs] = React.useState<TalkNPCs | null>(null)
|
2023-06-19 17:15:00 +02:00
|
|
|
const logPresentationRef = React.useRef<HTMLDivElement>(null)
|
2023-06-23 21:30:04 +02:00
|
|
|
const websocket = props.websocket
|
|
|
|
const setWebsocket = props.setWebsocket
|
2023-06-19 17:15:00 +02:00
|
|
|
window.setTimeout(() => {
|
|
|
|
setWebsocket((websocket): WebSocket | null => {
|
|
|
|
if (websocket === null) {
|
2023-07-09 18:41:21 +02:00
|
|
|
console.log('Opening websocket')
|
2023-06-19 17:15:00 +02:00
|
|
|
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(() => {
|
2023-06-29 09:04:38 +02:00
|
|
|
if (webSocket.readyState === WebSocket.CONNECTING) {
|
|
|
|
return
|
|
|
|
}
|
2023-06-19 17:15:00 +02:00
|
|
|
if (webSocket.readyState === WebSocket.OPEN) {
|
|
|
|
new OutputPacketPing().send(webSocket)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
window.clearInterval(interval)
|
2023-07-09 18:41:21 +02:00
|
|
|
}, 100000)
|
2023-06-19 17:15:00 +02:00
|
|
|
}
|
|
|
|
const inputPackets = new InputPackets(setTeamPJs,
|
2023-06-27 07:10:56 +02:00
|
|
|
setEnemyTeamPJs, setIsBattling,
|
2023-06-19 17:15:00 +02:00
|
|
|
setCurrentLocation, setConnectedLocations,
|
2023-06-27 07:10:56 +02:00
|
|
|
logLines, setLogLines, setError,
|
|
|
|
setScrollLog, logPresentationRef,
|
2023-06-30 19:59:18 +02:00
|
|
|
setMovingTo, setRemainingFrames,
|
2023-07-09 18:41:21 +02:00
|
|
|
setActionHash, setTalkNPCs)
|
2023-06-19 17:15:00 +02:00
|
|
|
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)
|
|
|
|
}
|
2023-06-19 17:15:00 +02:00
|
|
|
return webSocket
|
2023-06-13 02:43:52 +02:00
|
|
|
}
|
2023-06-19 17:15:00 +02:00
|
|
|
return websocket
|
|
|
|
})
|
2023-06-29 09:14:02 +02:00
|
|
|
}, 300)
|
2023-06-01 08:45:43 +02:00
|
|
|
return (
|
|
|
|
<>
|
2023-06-13 02:43:52 +02:00
|
|
|
<UpperPanel teamPJs={teamPJs}
|
2023-06-27 07:10:56 +02:00
|
|
|
enemyTeamPJs={enemyTeamPJs}
|
|
|
|
isBattling={isBattling}
|
2023-06-13 02:43:52 +02:00
|
|
|
currentLocation={currentLocation}
|
|
|
|
connectedLocations={connectedLocations}
|
2023-06-18 20:29:42 +02:00
|
|
|
logLines={logLines}
|
2023-06-19 17:15:00 +02:00
|
|
|
websocket={websocket}
|
2023-06-23 01:39:47 +02:00
|
|
|
logPresentationRef={logPresentationRef}
|
2023-06-23 02:31:11 +02:00
|
|
|
movingTo={movingTo}
|
|
|
|
remainingFrames={remainingFrames}/>
|
2023-07-09 18:41:21 +02:00
|
|
|
<BottomPanel actionHash={actionHash}
|
|
|
|
websocket={websocket}
|
|
|
|
talkNPCs={talkNPCs}/>
|
2023-06-01 08:45:43 +02:00
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|