blob: 9a68d34c6b00d5d39a78432dfc0003c71d6009b4 [file] [log] [blame]
/// <reference types="webpack/module" />
'use strict';
import './index.scss';
import './i18n';
// import config from "../sentry-client.config.json"
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
import { StrictMode } from 'react';
import { render } from 'react-dom';
import { createRoot } from 'react-dom/client';
import { Provider } from 'react-redux';
import { BrowserRouter as Router } from 'react-router-dom';
import socketio from 'socket.io-client';
import { store } from '../redux/store';
import App from './App';
import { SocketProvider } from './contexts/socket.js';
const queryClient = new QueryClient({
defaultOptions: {
queries: {
cacheTime: Infinity, // websocket is responsible to tell when data needs to be updated
},
},
});
const socket = socketio();
const container = document.getElementById('root');
if (!container) {
throw new Error('Failed to get the root element');
}
const root = createRoot(container);
root.render(
<Provider store={store}>
<StrictMode>
<QueryClientProvider client={queryClient}>
<SocketProvider socket={socket}>
<Router>
<App />
</Router>
</SocketProvider>
</QueryClientProvider>
</StrictMode>
</Provider>
);
if (import.meta.webpackHot)
import.meta.webpackHot.accept('./App', () => {
try {
render(<App />, container);
} catch (e) {
location.reload();
}
});