2024-05-05 14:08:44 +02:00
|
|
|
import {useEffect, useState} from 'react';
|
2024-04-30 10:52:29 +02:00
|
|
|
import {makeApiUrl, useMyWebSocket} from './serverCalls.tsx';
|
2024-05-04 14:25:37 +02:00
|
|
|
import {ReadyState} from 'react-use-websocket';
|
2024-05-05 14:08:44 +02:00
|
|
|
import PixelGridCanvas from './components/PixelGridCanvas.tsx';
|
2024-04-07 00:33:54 +02:00
|
|
|
|
2024-04-11 20:48:21 +02:00
|
|
|
|
2024-05-06 14:06:53 +02:00
|
|
|
export default function ClientScreen({player}: {
|
2024-04-28 12:53:18 +02:00
|
|
|
player: string | null
|
2024-04-16 00:07:44 +02:00
|
|
|
}) {
|
2024-05-04 14:25:37 +02:00
|
|
|
const [shouldSendMessage, setShouldSendMessage] = useState(false);
|
2024-04-07 00:33:54 +02:00
|
|
|
|
2024-04-21 14:34:45 +02:00
|
|
|
const url = makeApiUrl('/screen', 'ws');
|
2024-04-28 12:53:18 +02:00
|
|
|
if (player && player !== '')
|
|
|
|
url.searchParams.set('playerName', player);
|
2024-04-16 00:07:44 +02:00
|
|
|
|
2024-04-07 00:33:54 +02:00
|
|
|
const {
|
|
|
|
lastMessage,
|
|
|
|
sendMessage,
|
2024-05-04 14:25:37 +02:00
|
|
|
getWebSocket,
|
|
|
|
readyState
|
|
|
|
} = useMyWebSocket(url.toString(), {
|
2024-05-05 14:08:44 +02:00
|
|
|
onOpen: _ => setShouldSendMessage(true),
|
|
|
|
onMessage: _ => setShouldSendMessage(true)
|
2024-05-04 14:25:37 +02:00
|
|
|
});
|
2024-04-07 00:33:54 +02:00
|
|
|
|
|
|
|
const socket = getWebSocket();
|
|
|
|
if (socket)
|
|
|
|
(socket as WebSocket).binaryType = 'arraybuffer';
|
|
|
|
|
2024-05-04 14:25:37 +02:00
|
|
|
useEffect(() => {
|
|
|
|
if (!shouldSendMessage || readyState !== ReadyState.OPEN)
|
|
|
|
return;
|
|
|
|
setShouldSendMessage(false);
|
|
|
|
sendMessage('');
|
|
|
|
}, [readyState, shouldSendMessage]);
|
|
|
|
|
2024-05-05 14:08:44 +02:00
|
|
|
if (!lastMessage)
|
|
|
|
return <></>;
|
2024-05-04 14:25:37 +02:00
|
|
|
|
2024-05-05 14:08:44 +02:00
|
|
|
const pixels = new Uint8ClampedArray(lastMessage.data);
|
2024-05-06 14:06:53 +02:00
|
|
|
return <PixelGridCanvas pixels={pixels}/>;
|
2024-04-07 00:33:54 +02:00
|
|
|
}
|