Dan Albert 030675812e Cite the websocket tutorial I used for reference.
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.
2022-03-01 21:25:32 -08:00

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>
);
};