service-worker.js 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /* eslint-disable eslint-comments/disable-enable-pair */
  2. /* eslint-disable no-restricted-globals */
  3. /* eslint-disable no-underscore-dangle */
  4. /* globals workbox */
  5. workbox.core.setCacheNameDetails({
  6. prefix: 'antd-pro',
  7. suffix: 'v1',
  8. });
  9. // Control all opened tabs ASAP
  10. workbox.clientsClaim();
  11. /**
  12. * Use precaching list generated by workbox in build process.
  13. * https://developers.google.com/web/tools/workbox/reference-docs/latest/workbox.precaching
  14. */
  15. workbox.precaching.precacheAndRoute(self.__precacheManifest || []);
  16. /**
  17. * Register a navigation route.
  18. * https://developers.google.com/web/tools/workbox/modules/workbox-routing#how_to_register_a_navigation_route
  19. */
  20. workbox.routing.registerNavigationRoute('/index.html');
  21. /**
  22. * Use runtime cache:
  23. * https://developers.google.com/web/tools/workbox/reference-docs/latest/workbox.routing#.registerRoute
  24. *
  25. * Workbox provides all common caching strategies including CacheFirst, NetworkFirst etc.
  26. * https://developers.google.com/web/tools/workbox/reference-docs/latest/workbox.strategies
  27. */
  28. /**
  29. * Handle API requests
  30. */
  31. workbox.routing.registerRoute(/\/api\//, workbox.strategies.networkFirst());
  32. /**
  33. * Handle third party requests
  34. */
  35. workbox.routing.registerRoute(
  36. /^https:\/\/gw\.alipayobjects\.com\//,
  37. workbox.strategies.networkFirst(),
  38. );
  39. workbox.routing.registerRoute(
  40. /^https:\/\/cdnjs\.cloudflare\.com\//,
  41. workbox.strategies.networkFirst(),
  42. );
  43. workbox.routing.registerRoute(/\/color.less/, workbox.strategies.networkFirst());
  44. /**
  45. * Response to client after skipping waiting with MessageChannel
  46. */
  47. addEventListener('message', (event) => {
  48. const replyPort = event.ports[0];
  49. const message = event.data;
  50. if (replyPort && message && message.type === 'skip-waiting') {
  51. event.waitUntil(
  52. self.skipWaiting().then(
  53. () =>
  54. replyPort.postMessage({
  55. error: null,
  56. }),
  57. (error) =>
  58. replyPort.postMessage({
  59. error,
  60. }),
  61. ),
  62. );
  63. }
  64. });