grungnet/src/helpers/useNetworkedState.js

40 lines
978 B
JavaScript
Raw Normal View History

2020-12-08 04:58:01 +00:00
import { useEffect, useState } from "react";
function useNetworkedState(defaultState, session, eventName) {
const [state, _setState] = useState(defaultState);
// Used to control whether the state needs to be sent to the socket
2020-12-08 04:58:01 +00:00
const [dirty, setDirty] = useState(false);
// Update dirty at the same time as state
function setState(update, sync = true) {
_setState(update);
2020-12-08 04:58:01 +00:00
setDirty(sync);
}
useEffect(() => {
2020-12-08 04:58:01 +00:00
if (session.socket && dirty) {
session.socket.emit(eventName, state);
2020-12-08 04:58:01 +00:00
setDirty(false);
}
2020-12-08 04:58:01 +00:00
}, [session.socket, dirty, eventName, state]);
useEffect(() => {
function handleSocketEvent(data) {
_setState(data);
}
if (session.socket) {
session.socket.on(eventName, handleSocketEvent);
}
return () => {
if (session.socket) {
session.socket.off(eventName, handleSocketEvent);
}
};
}, [session.socket]);
return [state, setState];
}
export default useNetworkedState;