mirror of
https://github.com/dcs-retribution/dcs-retribution.git
synced 2025-11-10 15:41:24 +00:00
Add websocket handling for selected flights.
This commit is contained in:
36
client/src/components/socketprovider/socketprovider.tsx
Normal file
36
client/src/components/socketprovider/socketprovider.tsx
Normal file
@@ -0,0 +1,36 @@
|
||||
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>
|
||||
);
|
||||
};
|
||||
Reference in New Issue
Block a user