2022-04-22 09:00:14 -06:00
|
|
|
import React from 'react';
|
2022-08-23 08:22:46 -06:00
|
|
|
import { hydrateRoot, createRoot } from 'react-dom/client';
|
2022-04-22 09:00:14 -06:00
|
|
|
// Router
|
|
|
|
import { BrowserRouter as Router } from 'react-router-dom';
|
|
|
|
// Redux
|
|
|
|
import { Provider } from 'react-redux';
|
2022-04-28 09:15:16 -06:00
|
|
|
import { IInitialState } from './reducers/index';
|
2022-04-28 12:15:07 -06:00
|
|
|
import setStore from './setStore';
|
2022-08-30 11:00:36 -06:00
|
|
|
import { config } from '../../config';
|
2022-04-22 09:00:14 -06:00
|
|
|
|
2022-07-06 22:36:26 -06:00
|
|
|
import './styles/global.scss';
|
2022-04-24 23:44:06 -06:00
|
|
|
import App from './components/App';
|
2022-04-25 09:12:43 -06:00
|
|
|
import serviceWorkerRegistration from '../../serviceWorkerRegistration';
|
2022-04-22 09:00:14 -06:00
|
|
|
|
|
|
|
declare global {
|
|
|
|
interface Window {
|
|
|
|
__PRELOADED_STATE__?: IInitialState;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
declare global {
|
|
|
|
interface NodeModule {
|
|
|
|
hot?: IHot;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
interface IHot {
|
|
|
|
accept: any
|
|
|
|
}
|
|
|
|
|
2023-02-10 15:09:27 -06:00
|
|
|
const { ENV, PREFIX_URL } = config;
|
2022-04-24 23:44:06 -06:00
|
|
|
|
2022-04-22 09:00:14 -06:00
|
|
|
const preloadedState = window.__PRELOADED_STATE__;
|
|
|
|
const store = setStore({ initialState: preloadedState });
|
|
|
|
|
|
|
|
delete window.__PRELOADED_STATE__;
|
|
|
|
|
|
|
|
const container = document.getElementById('app')!;
|
|
|
|
|
2022-08-30 11:00:36 -06:00
|
|
|
if(ENV === 'development') {
|
2022-08-23 08:22:46 -06:00
|
|
|
const root = createRoot(container);
|
|
|
|
root.render(
|
|
|
|
<Provider store={store}>
|
2023-02-10 15:09:27 -06:00
|
|
|
<Router basename={PREFIX_URL}>
|
2022-08-23 08:22:46 -06:00
|
|
|
<App />
|
|
|
|
</Router>
|
|
|
|
</Provider>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-04-22 09:00:14 -06:00
|
|
|
// add "const root" to be able to rerender.
|
2022-08-30 11:00:36 -06:00
|
|
|
ENV === 'production' && hydrateRoot(container,
|
2022-04-22 09:00:14 -06:00
|
|
|
<Provider store={store}>
|
2023-02-10 15:09:27 -06:00
|
|
|
<Router basename={PREFIX_URL}>
|
2022-04-22 09:00:14 -06:00
|
|
|
<App />
|
|
|
|
</Router>
|
|
|
|
</Provider>,
|
|
|
|
// 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(
|
|
|
|
<Provider store={store}>
|
|
|
|
<Router>
|
|
|
|
<App />
|
|
|
|
</Router>
|
|
|
|
</Provider>
|
|
|
|
); */
|
|
|
|
|
2022-08-30 11:00:36 -06:00
|
|
|
if((ENV) && (ENV === 'production')){
|
2022-04-24 23:44:06 -06:00
|
|
|
serviceWorkerRegistration();
|
|
|
|
}
|
|
|
|
|
2022-04-22 09:00:14 -06:00
|
|
|
if(module.hot){
|
|
|
|
module.hot.accept();
|
2022-04-24 23:44:06 -06:00
|
|
|
}
|