import React from 'react'; import { hydrateRoot, createRoot } from 'react-dom/client'; // Router import { BrowserRouter as Router } from 'react-router-dom'; // Redux import { Provider } from 'react-redux'; import { IInitialState } from './reducers/index'; import setStore from './setStore'; import config from '../../config'; import './styles/global.scss'; import App from './components/App'; import serviceWorkerRegistration from '../../serviceWorkerRegistration'; declare global { interface Window { __PRELOADED_STATE__?: IInitialState; } } declare global { interface NodeModule { hot?: IHot; } } interface IHot { accept: any } const { env } = config; const preloadedState = window.__PRELOADED_STATE__; const store = setStore({ initialState: preloadedState }); delete window.__PRELOADED_STATE__; const container = document.getElementById('app')!; if(env === 'development') { const root = createRoot(container); root.render( ); } // add "const root" to be able to rerender. env === 'production' && hydrateRoot(container, , // Add this comment to update later app and remove warning /* { onRecoverableError: (error) => { console.error("recoverable", error); } }, */ ); // Use root.render to update later the app /* root.render( ); */ if((env) && (env === 'production')){ serviceWorkerRegistration(); } if(module.hot){ module.hot.accept(); }