-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathclient.js
59 lines (55 loc) · 1.59 KB
/
client.js
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'react-redux';
import { BrowserRouter } from 'react-router-dom';
import { HelmetProvider } from 'react-helmet-async';
import { loadableReady } from '@loadable/component';
import configureStore from 'utils/configureStore';
import App from 'components/App';
import { isDevelopment } from 'config/env';
// eslint-disable-next-line no-underscore-dangle
const initialState = window.__INITIAL_STATE__;
const store = configureStore(initialState);
const root = document.getElementById('root');
loadableReady().then(() => {
if (root) {
ReactDOM.hydrate(
<Provider store={store}>
<BrowserRouter>
<HelmetProvider>
<App />
</HelmetProvider>
</BrowserRouter>
</Provider>,
root
);
}
});
window.addEventListener('load', () => {
if ('serviceWorker' in navigator && navigator.serviceWorker) {
if (!isDevelopment) {
navigator.serviceWorker
.register('/static/javascripts/sw.js', { scope: '/' })
.then(() => {
// SW registered
})
.catch(() => {
// SW registration failed
});
} else {
navigator.serviceWorker.getRegistrations().then((registrations) => {
registrations.forEach((registration) => {
registration.unregister();
});
});
caches.keys().then((keys) => {
const promises = [];
keys.forEach((cacheName) => {
if (cacheName) {
promises.push(caches.delete(cacheName));
}
});
});
}
}
});