service-worker.js 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  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: 'v5',
  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. /** Handle API requests */
  29. workbox.routing.registerRoute(/\/api\//, workbox.strategies.networkFirst());
  30. /** Handle third party requests */
  31. workbox.routing.registerRoute(
  32. /^https:\/\/gw\.alipayobjects\.com\//,
  33. workbox.strategies.networkFirst(),
  34. );
  35. workbox.routing.registerRoute(
  36. /^https:\/\/cdnjs\.cloudflare\.com\//,
  37. workbox.strategies.networkFirst(),
  38. );
  39. workbox.routing.registerRoute(/\/color.less/, workbox.strategies.networkFirst());
  40. /** Response to client after skipping waiting with MessageChannel */
  41. addEventListener('message', (event) => {
  42. const replyPort = event.ports[0];
  43. const message = event.data;
  44. if (replyPort && message && message.type === 'skip-waiting') {
  45. event.waitUntil(
  46. self.skipWaiting().then(
  47. () => {
  48. replyPort.postMessage({
  49. error: null,
  50. });
  51. },
  52. (error) => {
  53. replyPort.postMessage({
  54. error,
  55. });
  56. },
  57. ),
  58. );
  59. }
  60. });