mirror of
https://github.com/dcs-liberation/dcs_liberation.git
synced 2025-11-10 14:22:26 +00:00
This was tricky to work out and most of the tutorials were bad. This one was good, so keep a link around in case we need the reference again.
39 lines
979 B
TypeScript
39 lines
979 B
TypeScript
// Based on https://thenable.io/building-a-use-socket-hook-in-react.
|
|
|
|
import { ReactChild, createContext, useEffect, useState } from "react";
|
|
|
|
import { WEBSOCKET_URL } from "../../api/backend";
|
|
|
|
const socket = new WebSocket(WEBSOCKET_URL);
|
|
|
|
export const SocketContext = createContext(socket);
|
|
|
|
interface SocketProviderProps {
|
|
children: ReactChild;
|
|
}
|
|
|
|
export const SocketProvider = (props: SocketProviderProps) => {
|
|
const [ws, setWs] = useState<WebSocket>(socket);
|
|
useEffect(() => {
|
|
const onClose = () => {
|
|
setWs(new WebSocket(WEBSOCKET_URL));
|
|
};
|
|
|
|
const onError = (error: Event) => {
|
|
console.log(`Websocket error: ${error}`);
|
|
};
|
|
|
|
ws.addEventListener("close", onClose);
|
|
ws.addEventListener("error", onError);
|
|
|
|
return () => {
|
|
ws.removeEventListener("close", onClose);
|
|
ws.removeEventListener("error", onError);
|
|
};
|
|
});
|
|
|
|
return (
|
|
<SocketContext.Provider value={ws}>{props.children}</SocketContext.Provider>
|
|
);
|
|
};
|