global.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. import { Modal, message } from 'antd';
  2. import { formatMessage } from 'umi/locale';
  3. // Notify user if offline now
  4. window.addEventListener('sw.offline', () => {
  5. message.warning(formatMessage({ id: 'app.pwa.offline' }));
  6. });
  7. // Pop up a prompt on the page asking the user if they want to use the latest version
  8. window.addEventListener('sw.updated', e => {
  9. Modal.confirm({
  10. title: formatMessage({ id: 'app.pwa.serviceworker.updated' }),
  11. content: formatMessage({ id: 'app.pwa.serviceworker.updated.hint' }),
  12. okText: formatMessage({ id: 'app.pwa.serviceworker.updated.ok' }),
  13. onOk: async () => {
  14. // Check if there is sw whose state is waiting in ServiceWorkerRegistration
  15. // https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerRegistration
  16. const worker = e.detail && e.detail.waiting;
  17. if (!worker) {
  18. return Promise.resolve();
  19. }
  20. // Send skip-waiting event to waiting SW with MessageChannel
  21. await new Promise((resolve, reject) => {
  22. const channel = new MessageChannel();
  23. channel.port1.onmessage = event => {
  24. if (event.data.error) {
  25. reject(event.data.error);
  26. } else {
  27. resolve(event.data);
  28. }
  29. };
  30. worker.postMessage({ type: 'skip-waiting' }, [channel.port2]);
  31. });
  32. // Refresh current page to use the updated HTML and other assets after SW has skiped waiting
  33. window.location.reload(true);
  34. return true;
  35. },
  36. });
  37. });