File size: 1,044 Bytes
4888678 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
import { useEffect, useRef } from 'react';
import { io } from 'socket.io-client';
import { useAuth } from './useAuth';
export const useSocket = () => {
const { user } = useAuth();
const socket = useRef(null);
useEffect(() => {
if (user && !socket.current) {
const token = localStorage.getItem('token');
socket.current = io(process.env.REACT_APP_SOCKET_URL || 'http://localhost:5000', {
auth: {
token
},
transports: ['websocket']
});
socket.current.on('connect', () => {
console.log('Connected to server');
});
socket.current.on('disconnect', () => {
console.log('Disconnected from server');
});
socket.current.on('connect_error', (error) => {
console.error('Connection error:', error);
});
}
return () => {
if (socket.current) {
socket.current.disconnect();
socket.current = null;
}
};
}, [user]);
return socket.current;
}; |