You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
91 lines
2.6 KiB
91 lines
2.6 KiB
import { useIntl } from '@umijs/max';
|
|
import { Button, message, notification } from 'antd';
|
|
import defaultSettings from '../config/defaultSettings';
|
|
|
|
const { pwa } = defaultSettings;
|
|
const isHttps = document.location.protocol === 'https:';
|
|
|
|
const clearCache = () => {
|
|
// remove all caches
|
|
if (window.caches) {
|
|
caches
|
|
.keys()
|
|
.then((keys) => {
|
|
keys.forEach((key) => {
|
|
caches.delete(key);
|
|
});
|
|
})
|
|
.catch((e) => console.log(e));
|
|
}
|
|
};
|
|
|
|
// if pwa is true
|
|
if (pwa) {
|
|
// Notify user if offline now
|
|
window.addEventListener('sw.offline', () => {
|
|
message.warning(useIntl().formatMessage({ id: 'app.pwa.offline' }));
|
|
});
|
|
|
|
// Pop up a prompt on the page asking the user if they want to use the latest version
|
|
window.addEventListener('sw.updated', (event: Event) => {
|
|
const e = event as CustomEvent;
|
|
const reloadSW = async () => {
|
|
// Check if there is sw whose state is waiting in ServiceWorkerRegistration
|
|
// https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerRegistration
|
|
const worker = e.detail && e.detail.waiting;
|
|
if (!worker) {
|
|
return true;
|
|
}
|
|
// Send skip-waiting event to waiting SW with MessageChannel
|
|
await new Promise((resolve, reject) => {
|
|
const channel = new MessageChannel();
|
|
channel.port1.onmessage = (msgEvent) => {
|
|
if (msgEvent.data.error) {
|
|
reject(msgEvent.data.error);
|
|
} else {
|
|
resolve(msgEvent.data);
|
|
}
|
|
};
|
|
worker.postMessage({ type: 'skip-waiting' }, [channel.port2]);
|
|
});
|
|
|
|
clearCache();
|
|
window.location.reload();
|
|
return true;
|
|
};
|
|
const key = `open${Date.now()}`;
|
|
const btn = (
|
|
<Button
|
|
type="primary"
|
|
onClick={() => {
|
|
notification.destroy(key);
|
|
reloadSW();
|
|
}}
|
|
>
|
|
{useIntl().formatMessage({ id: 'app.pwa.serviceworker.updated.ok' })}
|
|
</Button>
|
|
);
|
|
notification.open({
|
|
message: useIntl().formatMessage({ id: 'app.pwa.serviceworker.updated' }),
|
|
description: useIntl().formatMessage({ id: 'app.pwa.serviceworker.updated.hint' }),
|
|
btn,
|
|
key,
|
|
onClose: async () => null,
|
|
});
|
|
});
|
|
} else if ('serviceWorker' in navigator && isHttps) {
|
|
// unregister service worker
|
|
const { serviceWorker } = navigator;
|
|
if (serviceWorker.getRegistrations) {
|
|
serviceWorker.getRegistrations().then((sws) => {
|
|
sws.forEach((sw) => {
|
|
sw.unregister();
|
|
});
|
|
});
|
|
}
|
|
serviceWorker.getRegistration().then((sw) => {
|
|
if (sw) sw.unregister();
|
|
});
|
|
|
|
clearCache();
|
|
}
|
|
|