jekyll-amp-pwa-plugin 2.1.2 → 5.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (115) hide show
  1. checksums.yaml +4 -4
  2. data/lib/jekyll-amp-pwa-plugin.rb +31 -4
  3. data/lib/vendor/workbox-v5.1.4/workbox-background-sync.dev.js +818 -0
  4. data/lib/vendor/workbox-v5.1.4/workbox-background-sync.dev.js.map +1 -0
  5. data/lib/vendor/workbox-v5.1.4/workbox-background-sync.prod.js +2 -0
  6. data/lib/vendor/workbox-v5.1.4/workbox-background-sync.prod.js.map +1 -0
  7. data/lib/vendor/workbox-v5.1.4/workbox-broadcast-update.dev.js +288 -0
  8. data/lib/vendor/workbox-v5.1.4/workbox-broadcast-update.dev.js.map +1 -0
  9. data/lib/vendor/workbox-v5.1.4/workbox-broadcast-update.prod.js +2 -0
  10. data/lib/vendor/workbox-v5.1.4/workbox-broadcast-update.prod.js.map +1 -0
  11. data/lib/vendor/workbox-v5.1.4/workbox-cacheable-response.dev.js +191 -0
  12. data/lib/vendor/workbox-v5.1.4/workbox-cacheable-response.dev.js.map +1 -0
  13. data/lib/vendor/workbox-v5.1.4/workbox-cacheable-response.prod.js +2 -0
  14. data/lib/vendor/workbox-v5.1.4/workbox-cacheable-response.prod.js.map +1 -0
  15. data/lib/vendor/workbox-v5.1.4/workbox-core.dev.js +1858 -0
  16. data/lib/vendor/workbox-v5.1.4/workbox-core.dev.js.map +1 -0
  17. data/lib/vendor/workbox-v5.1.4/workbox-core.prod.js +2 -0
  18. data/lib/vendor/workbox-v5.1.4/workbox-core.prod.js.map +1 -0
  19. data/lib/vendor/workbox-v5.1.4/workbox-expiration.dev.js +649 -0
  20. data/lib/vendor/workbox-v5.1.4/workbox-expiration.dev.js.map +1 -0
  21. data/lib/vendor/workbox-v5.1.4/workbox-expiration.prod.js +2 -0
  22. data/lib/vendor/workbox-v5.1.4/workbox-expiration.prod.js.map +1 -0
  23. data/lib/vendor/workbox-v5.1.4/workbox-navigation-preload.dev.js +102 -0
  24. data/lib/vendor/workbox-v5.1.4/workbox-navigation-preload.dev.js.map +1 -0
  25. data/lib/vendor/workbox-v5.1.4/workbox-navigation-preload.prod.js +2 -0
  26. data/lib/vendor/workbox-v5.1.4/workbox-navigation-preload.prod.js.map +1 -0
  27. data/lib/vendor/workbox-v5.1.4/workbox-offline-ga.dev.js +235 -0
  28. data/lib/vendor/workbox-v5.1.4/workbox-offline-ga.dev.js.map +1 -0
  29. data/lib/vendor/workbox-v5.1.4/workbox-offline-ga.prod.js +2 -0
  30. data/lib/vendor/workbox-v5.1.4/workbox-offline-ga.prod.js.map +1 -0
  31. data/lib/vendor/workbox-v5.1.4/workbox-precaching.dev.js +1210 -0
  32. data/lib/vendor/workbox-v5.1.4/workbox-precaching.dev.js.map +1 -0
  33. data/lib/vendor/workbox-v5.1.4/workbox-precaching.prod.js +2 -0
  34. data/lib/vendor/workbox-v5.1.4/workbox-precaching.prod.js.map +1 -0
  35. data/lib/vendor/workbox-v5.1.4/workbox-range-requests.dev.js +262 -0
  36. data/lib/vendor/workbox-v5.1.4/workbox-range-requests.dev.js.map +1 -0
  37. data/lib/vendor/workbox-v5.1.4/workbox-range-requests.prod.js +2 -0
  38. data/lib/vendor/workbox-v5.1.4/workbox-range-requests.prod.js.map +1 -0
  39. data/lib/vendor/workbox-v5.1.4/workbox-routing.dev.js +923 -0
  40. data/lib/vendor/workbox-v5.1.4/workbox-routing.dev.js.map +1 -0
  41. data/lib/vendor/workbox-v5.1.4/workbox-routing.prod.js +2 -0
  42. data/lib/vendor/workbox-v5.1.4/workbox-routing.prod.js.map +1 -0
  43. data/lib/vendor/workbox-v5.1.4/workbox-strategies.dev.js +923 -0
  44. data/lib/vendor/workbox-v5.1.4/workbox-strategies.dev.js.map +1 -0
  45. data/lib/vendor/workbox-v5.1.4/workbox-strategies.prod.js +2 -0
  46. data/lib/vendor/workbox-v5.1.4/workbox-strategies.prod.js.map +1 -0
  47. data/lib/vendor/workbox-v5.1.4/workbox-streams.dev.js +318 -0
  48. data/lib/vendor/workbox-v5.1.4/workbox-streams.dev.js.map +1 -0
  49. data/lib/vendor/workbox-v5.1.4/workbox-streams.prod.js +2 -0
  50. data/lib/vendor/workbox-v5.1.4/workbox-streams.prod.js.map +1 -0
  51. data/lib/vendor/workbox-v5.1.4/workbox-sw.js +2 -0
  52. data/lib/vendor/workbox-v5.1.4/workbox-sw.js.map +1 -0
  53. data/lib/vendor/workbox-v5.1.4/workbox-window.dev.es5.mjs +1125 -0
  54. data/lib/vendor/workbox-v5.1.4/workbox-window.dev.es5.mjs.map +1 -0
  55. data/lib/vendor/workbox-v5.1.4/workbox-window.dev.mjs +943 -0
  56. data/lib/vendor/workbox-v5.1.4/workbox-window.dev.mjs.map +1 -0
  57. data/lib/vendor/workbox-v5.1.4/workbox-window.dev.umd.js +1136 -0
  58. data/lib/vendor/workbox-v5.1.4/workbox-window.dev.umd.js.map +1 -0
  59. data/lib/vendor/workbox-v5.1.4/workbox-window.prod.es5.mjs +2 -0
  60. data/lib/vendor/workbox-v5.1.4/workbox-window.prod.es5.mjs.map +1 -0
  61. data/lib/vendor/workbox-v5.1.4/workbox-window.prod.mjs +2 -0
  62. data/lib/vendor/workbox-v5.1.4/workbox-window.prod.mjs.map +1 -0
  63. data/lib/vendor/workbox-v5.1.4/workbox-window.prod.umd.js +2 -0
  64. data/lib/vendor/workbox-v5.1.4/workbox-window.prod.umd.js.map +1 -0
  65. metadata +68 -57
  66. data/lib/vendor/workbox-v3.6.2/workbox-background-sync.dev.js +0 -593
  67. data/lib/vendor/workbox-v3.6.2/workbox-background-sync.dev.js.map +0 -1
  68. data/lib/vendor/workbox-v3.6.2/workbox-background-sync.prod.js +0 -3
  69. data/lib/vendor/workbox-v3.6.2/workbox-background-sync.prod.js.map +0 -1
  70. data/lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.dev.js +0 -395
  71. data/lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.dev.js.map +0 -1
  72. data/lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.prod.js +0 -3
  73. data/lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.prod.js.map +0 -1
  74. data/lib/vendor/workbox-v3.6.2/workbox-cache-expiration.dev.js +0 -740
  75. data/lib/vendor/workbox-v3.6.2/workbox-cache-expiration.dev.js.map +0 -1
  76. data/lib/vendor/workbox-v3.6.2/workbox-cache-expiration.prod.js +0 -3
  77. data/lib/vendor/workbox-v3.6.2/workbox-cache-expiration.prod.js.map +0 -1
  78. data/lib/vendor/workbox-v3.6.2/workbox-cacheable-response.dev.js +0 -236
  79. data/lib/vendor/workbox-v3.6.2/workbox-cacheable-response.dev.js.map +0 -1
  80. data/lib/vendor/workbox-v3.6.2/workbox-cacheable-response.prod.js +0 -3
  81. data/lib/vendor/workbox-v3.6.2/workbox-cacheable-response.prod.js.map +0 -1
  82. data/lib/vendor/workbox-v3.6.2/workbox-core.dev.js +0 -1736
  83. data/lib/vendor/workbox-v3.6.2/workbox-core.dev.js.map +0 -1
  84. data/lib/vendor/workbox-v3.6.2/workbox-core.prod.js +0 -3
  85. data/lib/vendor/workbox-v3.6.2/workbox-core.prod.js.map +0 -1
  86. data/lib/vendor/workbox-v3.6.2/workbox-google-analytics.dev.js +0 -255
  87. data/lib/vendor/workbox-v3.6.2/workbox-google-analytics.dev.js.map +0 -1
  88. data/lib/vendor/workbox-v3.6.2/workbox-google-analytics.prod.js +0 -3
  89. data/lib/vendor/workbox-v3.6.2/workbox-google-analytics.prod.js.map +0 -1
  90. data/lib/vendor/workbox-v3.6.2/workbox-navigation-preload.dev.js +0 -159
  91. data/lib/vendor/workbox-v3.6.2/workbox-navigation-preload.dev.js.map +0 -1
  92. data/lib/vendor/workbox-v3.6.2/workbox-navigation-preload.prod.js +0 -3
  93. data/lib/vendor/workbox-v3.6.2/workbox-navigation-preload.prod.js.map +0 -1
  94. data/lib/vendor/workbox-v3.6.2/workbox-precaching.dev.js +0 -1169
  95. data/lib/vendor/workbox-v3.6.2/workbox-precaching.dev.js.map +0 -1
  96. data/lib/vendor/workbox-v3.6.2/workbox-precaching.prod.js +0 -3
  97. data/lib/vendor/workbox-v3.6.2/workbox-precaching.prod.js.map +0 -1
  98. data/lib/vendor/workbox-v3.6.2/workbox-range-requests.dev.js +0 -299
  99. data/lib/vendor/workbox-v3.6.2/workbox-range-requests.dev.js.map +0 -1
  100. data/lib/vendor/workbox-v3.6.2/workbox-range-requests.prod.js +0 -3
  101. data/lib/vendor/workbox-v3.6.2/workbox-range-requests.prod.js.map +0 -1
  102. data/lib/vendor/workbox-v3.6.2/workbox-routing.dev.js +0 -863
  103. data/lib/vendor/workbox-v3.6.2/workbox-routing.dev.js.map +0 -1
  104. data/lib/vendor/workbox-v3.6.2/workbox-routing.prod.js +0 -3
  105. data/lib/vendor/workbox-v3.6.2/workbox-routing.prod.js.map +0 -1
  106. data/lib/vendor/workbox-v3.6.2/workbox-strategies.dev.js +0 -1172
  107. data/lib/vendor/workbox-v3.6.2/workbox-strategies.dev.js.map +0 -1
  108. data/lib/vendor/workbox-v3.6.2/workbox-strategies.prod.js +0 -3
  109. data/lib/vendor/workbox-v3.6.2/workbox-strategies.prod.js.map +0 -1
  110. data/lib/vendor/workbox-v3.6.2/workbox-streams.dev.js +0 -380
  111. data/lib/vendor/workbox-v3.6.2/workbox-streams.dev.js.map +0 -1
  112. data/lib/vendor/workbox-v3.6.2/workbox-streams.prod.js +0 -3
  113. data/lib/vendor/workbox-v3.6.2/workbox-streams.prod.js.map +0 -1
  114. data/lib/vendor/workbox-v3.6.2/workbox-sw.js +0 -3
  115. data/lib/vendor/workbox-v3.6.2/workbox-sw.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workbox-window.dev.umd.js","sources":["../_version.js","../messageSW.js","../../workbox-core/_version.js","../../workbox-core/_private/Deferred.js","../../workbox-core/_private/dontWaitFor.js","../../workbox-core/_private/logger.js","../utils/WorkboxEventTarget.js","../utils/urlsMatch.js","../utils/WorkboxEvent.js","../Workbox.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:window:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Sends a data object to a service worker via `postMessage` and resolves with\n * a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will not\n * resolve.\n *\n * @param {ServiceWorker} sw The service worker to send the message to.\n * @param {Object} data An object to send to the service worker.\n * @return {Promise<Object|undefined>}\n * @memberof module:workbox-window\n */\nfunction messageSW(sw, data) {\n return new Promise((resolve) => {\n const messageChannel = new MessageChannel();\n messageChannel.port1.onmessage = (event) => {\n resolve(event.data);\n };\n sw.postMessage(data, [messageChannel.port2]);\n });\n}\nexport { messageSW };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A helper function that prevents a promise from being flagged as unused.\n *\n * @private\n **/\nexport function dontWaitFor(promise) {\n // Effective no-op.\n promise.then(() => { });\n}\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst logger = (process.env.NODE_ENV === 'production' ? null : (() => {\n // Don't overwrite this value if it's already set.\n // See https://github.com/GoogleChrome/workbox/pull/2284#issuecomment-560470923\n if (!('__WB_DISABLE_DEV_LOGS' in self)) {\n self.__WB_DISABLE_DEV_LOGS = false;\n }\n let inGroup = false;\n const methodToColorMap = {\n debug: `#7f8c8d`,\n log: `#2ecc71`,\n warn: `#f39c12`,\n error: `#c0392b`,\n groupCollapsed: `#3498db`,\n groupEnd: null,\n };\n const print = function (method, args) {\n if (self.__WB_DISABLE_DEV_LOGS) {\n return;\n }\n if (method === 'groupCollapsed') {\n // Safari doesn't print all console.groupCollapsed() arguments:\n // https://bugs.webkit.org/show_bug.cgi?id=182754\n if (/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) {\n console[method](...args);\n return;\n }\n }\n const styles = [\n `background: ${methodToColorMap[method]}`,\n `border-radius: 0.5em`,\n `color: white`,\n `font-weight: bold`,\n `padding: 2px 0.5em`,\n ];\n // When in a group, the workbox prefix is not displayed.\n const logPrefix = inGroup ? [] : ['%cworkbox', styles.join(';')];\n console[method](...logPrefix, ...args);\n if (method === 'groupCollapsed') {\n inGroup = true;\n }\n if (method === 'groupEnd') {\n inGroup = false;\n }\n };\n const api = {};\n const loggerMethods = Object.keys(methodToColorMap);\n for (const key of loggerMethods) {\n const method = key;\n api[method] = (...args) => {\n print(method, args);\n };\n }\n return api;\n})());\nexport { logger };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\n/**\n * A minimal `EventTarget` shim.\n * This is necessary because not all browsers support constructable\n * `EventTarget`, so using a real `EventTarget` will error.\n * @private\n */\nexport class WorkboxEventTarget {\n constructor() {\n this._eventListenerRegistry = new Map();\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n addEventListener(type, listener) {\n const foo = this._getEventListenersByType(type);\n foo.add(listener);\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n removeEventListener(type, listener) {\n this._getEventListenersByType(type).delete(listener);\n }\n /**\n * @param {Object} event\n * @private\n */\n dispatchEvent(event) {\n event.target = this;\n const listeners = this._getEventListenersByType(event.type);\n for (const listener of listeners) {\n listener(event);\n }\n }\n /**\n * Returns a Set of listeners associated with the passed event type.\n * If no handlers have been registered, an empty Set is returned.\n *\n * @param {string} type The event type.\n * @return {Set<ListenerCallback>} An array of handler functions.\n * @private\n */\n _getEventListenersByType(type) {\n if (!this._eventListenerRegistry.has(type)) {\n this._eventListenerRegistry.set(type, new Set());\n }\n return this._eventListenerRegistry.get(type);\n }\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns true if two URLs have the same `.href` property. The URLS can be\n * relative, and if they are the current location href is used to resolve URLs.\n *\n * @private\n * @param {string} url1\n * @param {string} url2\n * @return {boolean}\n */\nexport function urlsMatch(url1, url2) {\n const { href } = location;\n return new URL(url1, href).href === new URL(url2, href).href;\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A minimal `Event` subclass shim.\n * This doesn't *actually* subclass `Event` because not all browsers support\n * constructable `EventTarget`, and using a real `Event` will error.\n * @private\n */\nexport class WorkboxEvent {\n constructor(type, props) {\n this.type = type;\n Object.assign(this, props);\n }\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { Deferred } from 'workbox-core/_private/Deferred.js';\nimport { dontWaitFor } from 'workbox-core/_private/dontWaitFor.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { messageSW } from './messageSW.js';\nimport { WorkboxEventTarget } from './utils/WorkboxEventTarget.js';\nimport { urlsMatch } from './utils/urlsMatch.js';\nimport { WorkboxEvent } from './utils/WorkboxEvent.js';\nimport './_version.js';\n// The time a SW must be in the waiting phase before we can conclude\n// `skipWaiting()` wasn't called. This 200 amount wasn't scientifically\n// chosen, but it seems to avoid false positives in my testing.\nconst WAITING_TIMEOUT_DURATION = 200;\n// The amount of time after a registration that we can reasonably conclude\n// that the registration didn't trigger an update.\nconst REGISTRATION_TIMEOUT_DURATION = 60000;\n/**\n * A class to aid in handling service worker registration, updates, and\n * reacting to service worker lifecycle events.\n *\n * @fires [message]{@link module:workbox-window.Workbox#message}\n * @fires [installed]{@link module:workbox-window.Workbox#installed}\n * @fires [waiting]{@link module:workbox-window.Workbox#waiting}\n * @fires [controlling]{@link module:workbox-window.Workbox#controlling}\n * @fires [activated]{@link module:workbox-window.Workbox#activated}\n * @fires [redundant]{@link module:workbox-window.Workbox#redundant}\n * @fires [externalinstalled]{@link module:workbox-window.Workbox#externalinstalled}\n * @fires [externalwaiting]{@link module:workbox-window.Workbox#externalwaiting}\n * @fires [externalactivated]{@link module:workbox-window.Workbox#externalactivated}\n * @memberof module:workbox-window\n */\nclass Workbox extends WorkboxEventTarget {\n /**\n * Creates a new Workbox instance with a script URL and service worker\n * options. The script URL and options are the same as those used when\n * calling `navigator.serviceWorker.register(scriptURL, options)`. See:\n * https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/register\n *\n * @param {string} scriptURL The service worker script associated with this\n * instance.\n * @param {Object} [registerOptions] The service worker options associated\n * with this instance.\n */\n constructor(scriptURL, registerOptions = {}) {\n super();\n this._registerOptions = {};\n this._updateFoundCount = 0;\n // Deferreds we can resolve later.\n this._swDeferred = new Deferred();\n this._activeDeferred = new Deferred();\n this._controllingDeferred = new Deferred();\n this._registrationTime = 0;\n this._ownSWs = new Set();\n /**\n * @private\n */\n this._onUpdateFound = () => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const installingSW = registration.installing;\n // If the script URL passed to `navigator.serviceWorker.register()` is\n // different from the current controlling SW's script URL, we know any\n // successful registration calls will trigger an `updatefound` event.\n // But if the registered script URL is the same as the current controlling\n // SW's script URL, we'll only get an `updatefound` event if the file\n // changed since it was last registered. This can be a problem if the user\n // opens up the same page in a different tab, and that page registers\n // a SW that triggers an update. It's a problem because this page has no\n // good way of knowing whether the `updatefound` event came from the SW\n // script it registered or from a registration attempt made by a newer\n // version of the page running in another tab.\n // To minimize the possibility of a false positive, we use the logic here:\n const updateLikelyTriggeredExternally = \n // Since we enforce only calling `register()` once, and since we don't\n // add the `updatefound` event listener until the `register()` call, if\n // `_updateFoundCount` is > 0 then it means this method has already\n // been called, thus this SW must be external\n this._updateFoundCount > 0 ||\n // If the script URL of the installing SW is different from this\n // instance's script URL, we know it's definitely not from our\n // registration.\n !urlsMatch(installingSW.scriptURL, this._scriptURL) ||\n // If all of the above are false, then we use a time-based heuristic:\n // Any `updatefound` event that occurs long after our registration is\n // assumed to be external.\n (performance.now() >\n this._registrationTime + REGISTRATION_TIMEOUT_DURATION) ?\n // If any of the above are not true, we assume the update was\n // triggered by this instance.\n true : false;\n if (updateLikelyTriggeredExternally) {\n this._externalSW = installingSW;\n registration.removeEventListener('updatefound', this._onUpdateFound);\n }\n else {\n // If the update was not triggered externally we know the installing\n // SW is the one we registered, so we set it.\n this._sw = installingSW;\n this._ownSWs.add(installingSW);\n this._swDeferred.resolve(installingSW);\n // The `installing` state isn't something we have a dedicated\n // callback for, but we do log messages for it in development.\n if (process.env.NODE_ENV !== 'production') {\n if (navigator.serviceWorker.controller) {\n logger.log('Updated service worker found. Installing now...');\n }\n else {\n logger.log('Service worker is installing...');\n }\n }\n }\n // Increment the `updatefound` count, so future invocations of this\n // method can be sure they were triggered externally.\n ++this._updateFoundCount;\n // Add a `statechange` listener regardless of whether this update was\n // triggered externally, since we have callbacks for both.\n installingSW.addEventListener('statechange', this._onStateChange);\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onStateChange = (originalEvent) => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const sw = originalEvent.target;\n const { state } = sw;\n const isExternal = sw === this._externalSW;\n const eventPrefix = isExternal ? 'external' : '';\n const eventProps = {\n sw,\n originalEvent\n };\n if (!isExternal && this._isUpdate) {\n eventProps.isUpdate = true;\n }\n this.dispatchEvent(new WorkboxEvent(eventPrefix + state, eventProps));\n if (state === 'installed') {\n // This timeout is used to ignore cases where the service worker calls\n // `skipWaiting()` in the install event, thus moving it directly in the\n // activating state. (Since all service workers *must* go through the\n // waiting phase, the only way to detect `skipWaiting()` called in the\n // install event is to observe that the time spent in the waiting phase\n // is very short.)\n // NOTE: we don't need separate timeouts for the own and external SWs\n // since they can't go through these phases at the same time.\n this._waitingTimeout = self.setTimeout(() => {\n // Ensure the SW is still waiting (it may now be redundant).\n if (state === 'installed' && registration.waiting === sw) {\n this.dispatchEvent(new WorkboxEvent(eventPrefix + 'waiting', eventProps));\n if (process.env.NODE_ENV !== 'production') {\n if (isExternal) {\n logger.warn('An external service worker has installed but is ' +\n 'waiting for this client to close before activating...');\n }\n else {\n logger.warn('The service worker has installed but is waiting ' +\n 'for existing clients to close before activating...');\n }\n }\n }\n }, WAITING_TIMEOUT_DURATION);\n }\n else if (state === 'activating') {\n clearTimeout(this._waitingTimeout);\n if (!isExternal) {\n this._activeDeferred.resolve(sw);\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n switch (state) {\n case 'installed':\n if (isExternal) {\n logger.warn('An external service worker has installed. ' +\n 'You may want to suggest users reload this page.');\n }\n else {\n logger.log('Registered service worker installed.');\n }\n break;\n case 'activated':\n if (isExternal) {\n logger.warn('An external service worker has activated.');\n }\n else {\n logger.log('Registered service worker activated.');\n if (sw !== navigator.serviceWorker.controller) {\n logger.warn('The registered service worker is active but ' +\n 'not yet controlling the page. Reload or run ' +\n '`clients.claim()` in the service worker.');\n }\n }\n break;\n case 'redundant':\n if (sw === this._compatibleControllingSW) {\n logger.log('Previously controlling service worker now redundant!');\n }\n else if (!isExternal) {\n logger.log('Registered service worker now redundant!');\n }\n break;\n }\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onControllerChange = (originalEvent) => {\n const sw = this._sw;\n if (sw === navigator.serviceWorker.controller) {\n this.dispatchEvent(new WorkboxEvent('controlling', {\n sw,\n originalEvent,\n isUpdate: this._isUpdate,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Registered service worker now controlling this page.');\n }\n this._controllingDeferred.resolve(sw);\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onMessage = async (originalEvent) => {\n const { data, source } = originalEvent;\n // Wait until there's an \"own\" service worker. This is used to buffer\n // `message` events that may be received prior to calling `register()`.\n await this.getSW();\n // If the service worker that sent the message is in the list of own\n // service workers for this instance, dispatch a `message` event.\n // NOTE: we check for all previously owned service workers rather than\n // just the current one because some messages (e.g. cache updates) use\n // a timeout when sent and may be delayed long enough for a service worker\n // update to be found.\n if (this._ownSWs.has(source)) {\n this.dispatchEvent(new WorkboxEvent('message', {\n data,\n sw: source,\n originalEvent,\n }));\n }\n };\n this._scriptURL = scriptURL;\n this._registerOptions = registerOptions;\n // Add a message listener immediately since messages received during\n // page load are buffered only until the DOMContentLoaded event:\n // https://github.com/GoogleChrome/workbox/issues/2202\n navigator.serviceWorker.addEventListener('message', this._onMessage);\n }\n /**\n * Registers a service worker for this instances script URL and service\n * worker options. By default this method delays registration until after\n * the window has loaded.\n *\n * @param {Object} [options]\n * @param {Function} [options.immediate=false] Setting this to true will\n * register the service worker immediately, even if the window has\n * not loaded (not recommended).\n */\n async register({ immediate = false } = {}) {\n if (process.env.NODE_ENV !== 'production') {\n if (this._registrationTime) {\n logger.error('Cannot re-register a Workbox instance after it has ' +\n 'been registered. Create a new instance instead.');\n return;\n }\n }\n if (!immediate && document.readyState !== 'complete') {\n await new Promise((res) => window.addEventListener('load', res));\n }\n // Set this flag to true if any service worker was controlling the page\n // at registration time.\n this._isUpdate = Boolean(navigator.serviceWorker.controller);\n // Before registering, attempt to determine if a SW is already controlling\n // the page, and if that SW script (and version, if specified) matches this\n // instance's script.\n this._compatibleControllingSW = this._getControllingSWIfCompatible();\n this._registration = await this._registerScript();\n // If we have a compatible controller, store the controller as the \"own\"\n // SW, resolve active/controlling deferreds and add necessary listeners.\n if (this._compatibleControllingSW) {\n this._sw = this._compatibleControllingSW;\n this._activeDeferred.resolve(this._compatibleControllingSW);\n this._controllingDeferred.resolve(this._compatibleControllingSW);\n this._compatibleControllingSW.addEventListener('statechange', this._onStateChange, { once: true });\n }\n // If there's a waiting service worker with a matching URL before the\n // `updatefound` event fires, it likely means that this site is open\n // in another tab, or the user refreshed the page (and thus the previous\n // page wasn't fully unloaded before this page started loading).\n // https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#waiting\n const waitingSW = this._registration.waiting;\n if (waitingSW && urlsMatch(waitingSW.scriptURL, this._scriptURL)) {\n // Store the waiting SW as the \"own\" Sw, even if it means overwriting\n // a compatible controller.\n this._sw = waitingSW;\n // Run this in the next microtask, so any code that adds an event\n // listener after awaiting `register()` will get this event.\n dontWaitFor(Promise.resolve().then(() => {\n this.dispatchEvent(new WorkboxEvent('waiting', {\n sw: waitingSW,\n wasWaitingBeforeRegister: true,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.warn('A service worker was already waiting to activate ' +\n 'before this script was registered...');\n }\n }));\n }\n // If an \"own\" SW is already set, resolve the deferred.\n if (this._sw) {\n this._swDeferred.resolve(this._sw);\n this._ownSWs.add(this._sw);\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Successfully registered service worker.', this._scriptURL);\n if (navigator.serviceWorker.controller) {\n if (this._compatibleControllingSW) {\n logger.debug('A service worker with the same script URL ' +\n 'is already controlling this page.');\n }\n else {\n logger.debug('A service worker with a different script URL is ' +\n 'currently controlling the page. The browser is now fetching ' +\n 'the new script now...');\n }\n }\n const currentPageIsOutOfScope = () => {\n const scopeURL = new URL(this._registerOptions.scope || this._scriptURL, document.baseURI);\n const scopeURLBasePath = new URL('./', scopeURL.href).pathname;\n return !location.pathname.startsWith(scopeURLBasePath);\n };\n if (currentPageIsOutOfScope()) {\n logger.warn('The current page is not in scope for the registered ' +\n 'service worker. Was this a mistake?');\n }\n }\n this._registration.addEventListener('updatefound', this._onUpdateFound);\n navigator.serviceWorker.addEventListener('controllerchange', this._onControllerChange, { once: true });\n return this._registration;\n }\n /**\n * Checks for updates of the registered service worker.\n */\n async update() {\n if (!this._registration) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error('Cannot update a Workbox instance without ' +\n 'being registered. Register the Workbox instance first.');\n }\n return;\n }\n // Try to update registration\n await this._registration.update();\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is active. If a service worker was already controlling at registration\n * time then it will resolve to that if the script URLs (and optionally\n * script versions) match, otherwise it will wait until an update is found\n * and activates.\n *\n * @return {Promise<ServiceWorker>}\n */\n get active() {\n return this._activeDeferred.promise;\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is controlling the page. If a service worker was already controlling at\n * registration time then it will resolve to that if the script URLs (and\n * optionally script versions) match, otherwise it will wait until an update\n * is found and starts controlling the page.\n * Note: the first time a service worker is installed it will active but\n * not start controlling the page unless `clients.claim()` is called in the\n * service worker.\n *\n * @return {Promise<ServiceWorker>}\n */\n get controlling() {\n return this._controllingDeferred.promise;\n }\n /**\n * Resolves with a reference to a service worker that matches the script URL\n * of this instance, as soon as it's available.\n *\n * If, at registration time, there's already an active or waiting service\n * worker with a matching script URL, it will be used (with the waiting\n * service worker taking precedence over the active service worker if both\n * match, since the waiting service worker would have been registered more\n * recently).\n * If there's no matching active or waiting service worker at registration\n * time then the promise will not resolve until an update is found and starts\n * installing, at which point the installing service worker is used.\n *\n * @return {Promise<ServiceWorker>}\n */\n async getSW() {\n // If `this._sw` is set, resolve with that as we want `getSW()` to\n // return the correct (new) service worker if an update is found.\n return this._sw !== undefined ? this._sw : this._swDeferred.promise;\n }\n /**\n * Sends the passed data object to the service worker registered by this\n * instance (via [`getSW()`]{@link module:workbox-window.Workbox#getSW}) and resolves\n * with a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will never\n * resolve.\n *\n * @param {Object} data An object to send to the service worker\n * @return {Promise<Object>}\n */\n async messageSW(data) {\n const sw = await this.getSW();\n return messageSW(sw, data);\n }\n /**\n * Checks for a service worker already controlling the page and returns\n * it if its script URL matches.\n *\n * @private\n * @return {ServiceWorker|undefined}\n */\n _getControllingSWIfCompatible() {\n const controller = navigator.serviceWorker.controller;\n if (controller && urlsMatch(controller.scriptURL, this._scriptURL)) {\n return controller;\n }\n else {\n return undefined;\n }\n }\n /**\n * Registers a service worker for this instances script URL and register\n * options and tracks the time registration was complete.\n *\n * @private\n */\n async _registerScript() {\n try {\n const reg = await navigator.serviceWorker.register(this._scriptURL, this._registerOptions);\n // Keep track of when registration happened, so it can be used in the\n // `this._onUpdateFound` heuristic. Also use the presence of this\n // property as a way to see if `.register()` has been called.\n this._registrationTime = performance.now();\n return reg;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(error);\n }\n // Re-throw the error.\n throw error;\n }\n }\n}\nexport { Workbox };\n// The jsdoc comments below outline the events this instance may dispatch:\n// -----------------------------------------------------------------------\n/**\n * The `message` event is dispatched any time a `postMessage` is received.\n *\n * @event module:workbox-window.Workbox#message\n * @type {WorkboxEvent}\n * @property {*} data The `data` property from the original `message` event.\n * @property {Event} originalEvent The original [`message`]{@link https://developer.mozilla.org/en-US/docs/Web/API/MessageEvent}\n * event.\n * @property {string} type `message`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `installed` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed`.\n *\n * Then can happen either the very first time a service worker is installed,\n * or after an update to the current service worker is found. In the case\n * of an update being found, the event's `isUpdate` property will be `true`.\n *\n * @event module:workbox-window.Workbox#installed\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `installed`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `waiting` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed` and then doesn't immediately change to `activating`.\n * It may also be dispatched if a service worker with the same\n * [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * was already waiting when the [`register()`]{@link module:workbox-window.Workbox#register}\n * method was called.\n *\n * @event module:workbox-window.Workbox#waiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event|undefined} originalEvent The original\n * [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event, or `undefined` in the case where the service worker was waiting\n * to before `.register()` was called.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {boolean|undefined} wasWaitingBeforeRegister True if a service worker with\n * a matching `scriptURL` was already waiting when this `Workbox`\n * instance called `register()`.\n * @property {string} type `waiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `controlling` event is dispatched if a\n * [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * fires on the service worker [container]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer}\n * and the [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * of the new [controller]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/controller}\n * matches the `scriptURL` of the `Workbox` instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}.\n *\n * @event module:workbox-window.Workbox#controlling\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this service worker was registered.\n * @property {string} type `controlling`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `activated` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#activated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `activated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `redundant` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `redundant`.\n *\n * @event module:workbox-window.Workbox#redundant\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `redundant`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalinstalled` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `installed`.\n *\n * @event module:workbox-window.Workbox#externalinstalled\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalinstalled`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalwaiting` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `waiting`.\n *\n * @event module:workbox-window.Workbox#externalwaiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalwaiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalactivated` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#externalactivated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalactivated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n"],"names":["self","_","e","messageSW","sw","data","Promise","resolve","messageChannel","MessageChannel","port1","onmessage","event","postMessage","port2","Deferred","promise","reject","dontWaitFor","then","logger","process","__WB_DISABLE_DEV_LOGS","inGroup","methodToColorMap","debug","log","warn","error","groupCollapsed","groupEnd","print","method","args","test","navigator","userAgent","console","styles","logPrefix","join","api","loggerMethods","Object","keys","key","WorkboxEventTarget","_eventListenerRegistry","Map","addEventListener","type","listener","foo","_getEventListenersByType","add","removeEventListener","delete","dispatchEvent","target","listeners","has","set","Set","get","urlsMatch","url1","url2","location","href","URL","WorkboxEvent","props","assign","_await","value","direct","WAITING_TIMEOUT_DURATION","_async","f","i","arguments","length","apply","REGISTRATION_TIMEOUT_DURATION","_empty","Workbox","scriptURL","registerOptions","_registerOptions","_updateFoundCount","_swDeferred","_activeDeferred","_controllingDeferred","_registrationTime","_ownSWs","_onUpdateFound","registration","_registration","installingSW","installing","updateLikelyTriggeredExternally","_scriptURL","performance","now","_externalSW","_sw","serviceWorker","controller","_onStateChange","originalEvent","state","isExternal","eventPrefix","eventProps","_isUpdate","isUpdate","_waitingTimeout","setTimeout","waiting","clearTimeout","_compatibleControllingSW","_onControllerChange","_onMessage","source","getSW","register","immediate","document","readyState","res","window","Boolean","_getControllingSWIfCompatible","_registerScript","once","waitingSW","wasWaitingBeforeRegister","currentPageIsOutOfScope","scopeURL","scope","baseURI","scopeURLBasePath","pathname","startsWith","update","undefined","reg","body","result","recover"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ try{self["workbox:window:5.1.4"]&&_()}catch(n){}function n(n,t){return new Promise((function(r){var e=new MessageChannel;e.port1.onmessage=function(n){r(n.data)},n.postMessage(t,[e.port2])}))}function t(n,t){for(var r=0;r<t.length;r++){var e=t[r];e.enumerable=e.enumerable||!1,e.configurable=!0,"value"in e&&(e.writable=!0),Object.defineProperty(n,e.key,e)}}function r(n,t){(null==t||t>n.length)&&(t=n.length);for(var r=0,e=new Array(t);r<t;r++)e[r]=n[r];return e}function e(n,t){var e;if("undefined"==typeof Symbol||null==n[Symbol.iterator]){if(Array.isArray(n)||(e=function(n,t){if(n){if("string"==typeof n)return r(n,t);var e=Object.prototype.toString.call(n).slice(8,-1);return"Object"===e&&n.constructor&&(e=n.constructor.name),"Map"===e||"Set"===e?Array.from(n):"Arguments"===e||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(e)?r(n,t):void 0}}(n))||t&&n&&"number"==typeof n.length){e&&(n=e);var i=0;return function(){return i>=n.length?{done:!0}:{done:!1,value:n[i++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}return(e=n[Symbol.iterator]()).next.bind(e)}try{self["workbox:core:5.1.4"]&&_()}catch(n){}var i=function(){var n=this;this.promise=new Promise((function(t,r){n.resolve=t,n.reject=r}))};function o(n,t){var r=location.href;return new URL(n,r).href===new URL(t,r).href}var u=function(n,t){this.type=n,Object.assign(this,t)};function a(n,t,r){return r?t?t(n):n:(n&&n.then||(n=Promise.resolve(n)),t?n.then(t):n)}function c(){}var f=function(r){var e,c;function f(n,t){var e,c;return void 0===t&&(t={}),(e=r.call(this)||this).t={},e.i=0,e.o=new i,e.u=new i,e.s=new i,e.v=0,e.h=new Set,e.l=function(){var n=e.m,t=n.installing;e.i>0||!o(t.scriptURL,e.g)||performance.now()>e.v+6e4?(e.p=t,n.removeEventListener("updatefound",e.l)):(e.P=t,e.h.add(t),e.o.resolve(t)),++e.i,t.addEventListener("statechange",e.S)},e.S=function(n){var t=e.m,r=n.target,i=r.state,o=r===e.p,a=o?"external":"",c={sw:r,originalEvent:n};!o&&e.j&&(c.isUpdate=!0),e.dispatchEvent(new u(a+i,c)),"installed"===i?e.A=self.setTimeout((function(){"installed"===i&&t.waiting===r&&e.dispatchEvent(new u(a+"waiting",c))}),200):"activating"===i&&(clearTimeout(e.A),o||e.u.resolve(r))},e.O=function(n){var t=e.P;t===navigator.serviceWorker.controller&&(e.dispatchEvent(new u("controlling",{sw:t,originalEvent:n,isUpdate:e.j})),e.s.resolve(t))},e.U=(c=function(n){var t=n.data,r=n.source;return a(e.getSW(),(function(){e.h.has(r)&&e.dispatchEvent(new u("message",{data:t,sw:r,originalEvent:n}))}))},function(){for(var n=[],t=0;t<arguments.length;t++)n[t]=arguments[t];try{return Promise.resolve(c.apply(this,n))}catch(n){return Promise.reject(n)}}),e.g=n,e.t=t,navigator.serviceWorker.addEventListener("message",e.U),e}c=r,(e=f).prototype=Object.create(c.prototype),e.prototype.constructor=e,e.__proto__=c;var v,h,l,m=f.prototype;return m.register=function(n){var t=(void 0===n?{}:n).immediate,r=void 0!==t&&t;try{var e=this;return function(n,t){var r=n();if(r&&r.then)return r.then(t);return t(r)}((function(){if(!r&&"complete"!==document.readyState)return s(new Promise((function(n){return window.addEventListener("load",n)})))}),(function(){return e.j=Boolean(navigator.serviceWorker.controller),e.I=e.M(),a(e.R(),(function(n){e.m=n,e.I&&(e.P=e.I,e.u.resolve(e.I),e.s.resolve(e.I),e.I.addEventListener("statechange",e.S,{once:!0}));var t=e.m.waiting;return t&&o(t.scriptURL,e.g)&&(e.P=t,Promise.resolve().then((function(){e.dispatchEvent(new u("waiting",{sw:t,wasWaitingBeforeRegister:!0}))})).then((function(){}))),e.P&&(e.o.resolve(e.P),e.h.add(e.P)),e.m.addEventListener("updatefound",e.l),navigator.serviceWorker.addEventListener("controllerchange",e.O,{once:!0}),e.m}))}))}catch(n){return Promise.reject(n)}},m.update=function(){try{return this.m?s(this.m.update()):void 0}catch(n){return Promise.reject(n)}},m.getSW=function(){try{return void 0!==this.P?this.P:this.o.promise}catch(n){return Promise.reject(n)}},m.messageSW=function(t){try{return a(this.getSW(),(function(r){return n(r,t)}))}catch(n){return Promise.reject(n)}},m.M=function(){var n=navigator.serviceWorker.controller;return n&&o(n.scriptURL,this.g)?n:void 0},m.R=function(){try{var n=this;return function(n,t){try{var r=n()}catch(n){return t(n)}if(r&&r.then)return r.then(void 0,t);return r}((function(){return a(navigator.serviceWorker.register(n.g,n.t),(function(t){return n.v=performance.now(),t}))}),(function(n){throw n}))}catch(n){return Promise.reject(n)}},v=f,(h=[{key:"active",get:function(){return this.u.promise}},{key:"controlling",get:function(){return this.s.promise}}])&&t(v.prototype,h),l&&t(v,l),f}(function(){function n(){this.k=new Map}var t=n.prototype;return t.addEventListener=function(n,t){this.B(n).add(t)},t.removeEventListener=function(n,t){this.B(n).delete(t)},t.dispatchEvent=function(n){n.target=this;for(var t,r=e(this.B(n.type));!(t=r()).done;){(0,t.value)(n)}},t.B=function(n){return this.k.has(n)||this.k.set(n,new Set),this.k.get(n)},n}());function s(n,t){if(!t)return n&&n.then?n.then(c):Promise.resolve()}export{f as Workbox,n as messageSW};
2
+ //# sourceMappingURL=workbox-window.prod.es5.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workbox-window.prod.es5.mjs","sources":["../_version.js","../messageSW.js","../../workbox-core/_version.js","../../workbox-core/_private/Deferred.js","../utils/urlsMatch.js","../utils/WorkboxEvent.js","../Workbox.js","../../workbox-core/_private/dontWaitFor.js","../utils/WorkboxEventTarget.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:window:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Sends a data object to a service worker via `postMessage` and resolves with\n * a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will not\n * resolve.\n *\n * @param {ServiceWorker} sw The service worker to send the message to.\n * @param {Object} data An object to send to the service worker.\n * @return {Promise<Object|undefined>}\n * @memberof module:workbox-window\n */\nfunction messageSW(sw, data) {\n return new Promise((resolve) => {\n const messageChannel = new MessageChannel();\n messageChannel.port1.onmessage = (event) => {\n resolve(event.data);\n };\n sw.postMessage(data, [messageChannel.port2]);\n });\n}\nexport { messageSW };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns true if two URLs have the same `.href` property. The URLS can be\n * relative, and if they are the current location href is used to resolve URLs.\n *\n * @private\n * @param {string} url1\n * @param {string} url2\n * @return {boolean}\n */\nexport function urlsMatch(url1, url2) {\n const { href } = location;\n return new URL(url1, href).href === new URL(url2, href).href;\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A minimal `Event` subclass shim.\n * This doesn't *actually* subclass `Event` because not all browsers support\n * constructable `EventTarget`, and using a real `Event` will error.\n * @private\n */\nexport class WorkboxEvent {\n constructor(type, props) {\n this.type = type;\n Object.assign(this, props);\n }\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { Deferred } from 'workbox-core/_private/Deferred.js';\nimport { dontWaitFor } from 'workbox-core/_private/dontWaitFor.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { messageSW } from './messageSW.js';\nimport { WorkboxEventTarget } from './utils/WorkboxEventTarget.js';\nimport { urlsMatch } from './utils/urlsMatch.js';\nimport { WorkboxEvent } from './utils/WorkboxEvent.js';\nimport './_version.js';\n// The time a SW must be in the waiting phase before we can conclude\n// `skipWaiting()` wasn't called. This 200 amount wasn't scientifically\n// chosen, but it seems to avoid false positives in my testing.\nconst WAITING_TIMEOUT_DURATION = 200;\n// The amount of time after a registration that we can reasonably conclude\n// that the registration didn't trigger an update.\nconst REGISTRATION_TIMEOUT_DURATION = 60000;\n/**\n * A class to aid in handling service worker registration, updates, and\n * reacting to service worker lifecycle events.\n *\n * @fires [message]{@link module:workbox-window.Workbox#message}\n * @fires [installed]{@link module:workbox-window.Workbox#installed}\n * @fires [waiting]{@link module:workbox-window.Workbox#waiting}\n * @fires [controlling]{@link module:workbox-window.Workbox#controlling}\n * @fires [activated]{@link module:workbox-window.Workbox#activated}\n * @fires [redundant]{@link module:workbox-window.Workbox#redundant}\n * @fires [externalinstalled]{@link module:workbox-window.Workbox#externalinstalled}\n * @fires [externalwaiting]{@link module:workbox-window.Workbox#externalwaiting}\n * @fires [externalactivated]{@link module:workbox-window.Workbox#externalactivated}\n * @memberof module:workbox-window\n */\nclass Workbox extends WorkboxEventTarget {\n /**\n * Creates a new Workbox instance with a script URL and service worker\n * options. The script URL and options are the same as those used when\n * calling `navigator.serviceWorker.register(scriptURL, options)`. See:\n * https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/register\n *\n * @param {string} scriptURL The service worker script associated with this\n * instance.\n * @param {Object} [registerOptions] The service worker options associated\n * with this instance.\n */\n constructor(scriptURL, registerOptions = {}) {\n super();\n this._registerOptions = {};\n this._updateFoundCount = 0;\n // Deferreds we can resolve later.\n this._swDeferred = new Deferred();\n this._activeDeferred = new Deferred();\n this._controllingDeferred = new Deferred();\n this._registrationTime = 0;\n this._ownSWs = new Set();\n /**\n * @private\n */\n this._onUpdateFound = () => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const installingSW = registration.installing;\n // If the script URL passed to `navigator.serviceWorker.register()` is\n // different from the current controlling SW's script URL, we know any\n // successful registration calls will trigger an `updatefound` event.\n // But if the registered script URL is the same as the current controlling\n // SW's script URL, we'll only get an `updatefound` event if the file\n // changed since it was last registered. This can be a problem if the user\n // opens up the same page in a different tab, and that page registers\n // a SW that triggers an update. It's a problem because this page has no\n // good way of knowing whether the `updatefound` event came from the SW\n // script it registered or from a registration attempt made by a newer\n // version of the page running in another tab.\n // To minimize the possibility of a false positive, we use the logic here:\n const updateLikelyTriggeredExternally = \n // Since we enforce only calling `register()` once, and since we don't\n // add the `updatefound` event listener until the `register()` call, if\n // `_updateFoundCount` is > 0 then it means this method has already\n // been called, thus this SW must be external\n this._updateFoundCount > 0 ||\n // If the script URL of the installing SW is different from this\n // instance's script URL, we know it's definitely not from our\n // registration.\n !urlsMatch(installingSW.scriptURL, this._scriptURL) ||\n // If all of the above are false, then we use a time-based heuristic:\n // Any `updatefound` event that occurs long after our registration is\n // assumed to be external.\n (performance.now() >\n this._registrationTime + REGISTRATION_TIMEOUT_DURATION) ?\n // If any of the above are not true, we assume the update was\n // triggered by this instance.\n true : false;\n if (updateLikelyTriggeredExternally) {\n this._externalSW = installingSW;\n registration.removeEventListener('updatefound', this._onUpdateFound);\n }\n else {\n // If the update was not triggered externally we know the installing\n // SW is the one we registered, so we set it.\n this._sw = installingSW;\n this._ownSWs.add(installingSW);\n this._swDeferred.resolve(installingSW);\n // The `installing` state isn't something we have a dedicated\n // callback for, but we do log messages for it in development.\n if (process.env.NODE_ENV !== 'production') {\n if (navigator.serviceWorker.controller) {\n logger.log('Updated service worker found. Installing now...');\n }\n else {\n logger.log('Service worker is installing...');\n }\n }\n }\n // Increment the `updatefound` count, so future invocations of this\n // method can be sure they were triggered externally.\n ++this._updateFoundCount;\n // Add a `statechange` listener regardless of whether this update was\n // triggered externally, since we have callbacks for both.\n installingSW.addEventListener('statechange', this._onStateChange);\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onStateChange = (originalEvent) => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const sw = originalEvent.target;\n const { state } = sw;\n const isExternal = sw === this._externalSW;\n const eventPrefix = isExternal ? 'external' : '';\n const eventProps = {\n sw,\n originalEvent\n };\n if (!isExternal && this._isUpdate) {\n eventProps.isUpdate = true;\n }\n this.dispatchEvent(new WorkboxEvent(eventPrefix + state, eventProps));\n if (state === 'installed') {\n // This timeout is used to ignore cases where the service worker calls\n // `skipWaiting()` in the install event, thus moving it directly in the\n // activating state. (Since all service workers *must* go through the\n // waiting phase, the only way to detect `skipWaiting()` called in the\n // install event is to observe that the time spent in the waiting phase\n // is very short.)\n // NOTE: we don't need separate timeouts for the own and external SWs\n // since they can't go through these phases at the same time.\n this._waitingTimeout = self.setTimeout(() => {\n // Ensure the SW is still waiting (it may now be redundant).\n if (state === 'installed' && registration.waiting === sw) {\n this.dispatchEvent(new WorkboxEvent(eventPrefix + 'waiting', eventProps));\n if (process.env.NODE_ENV !== 'production') {\n if (isExternal) {\n logger.warn('An external service worker has installed but is ' +\n 'waiting for this client to close before activating...');\n }\n else {\n logger.warn('The service worker has installed but is waiting ' +\n 'for existing clients to close before activating...');\n }\n }\n }\n }, WAITING_TIMEOUT_DURATION);\n }\n else if (state === 'activating') {\n clearTimeout(this._waitingTimeout);\n if (!isExternal) {\n this._activeDeferred.resolve(sw);\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n switch (state) {\n case 'installed':\n if (isExternal) {\n logger.warn('An external service worker has installed. ' +\n 'You may want to suggest users reload this page.');\n }\n else {\n logger.log('Registered service worker installed.');\n }\n break;\n case 'activated':\n if (isExternal) {\n logger.warn('An external service worker has activated.');\n }\n else {\n logger.log('Registered service worker activated.');\n if (sw !== navigator.serviceWorker.controller) {\n logger.warn('The registered service worker is active but ' +\n 'not yet controlling the page. Reload or run ' +\n '`clients.claim()` in the service worker.');\n }\n }\n break;\n case 'redundant':\n if (sw === this._compatibleControllingSW) {\n logger.log('Previously controlling service worker now redundant!');\n }\n else if (!isExternal) {\n logger.log('Registered service worker now redundant!');\n }\n break;\n }\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onControllerChange = (originalEvent) => {\n const sw = this._sw;\n if (sw === navigator.serviceWorker.controller) {\n this.dispatchEvent(new WorkboxEvent('controlling', {\n sw,\n originalEvent,\n isUpdate: this._isUpdate,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Registered service worker now controlling this page.');\n }\n this._controllingDeferred.resolve(sw);\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onMessage = async (originalEvent) => {\n const { data, source } = originalEvent;\n // Wait until there's an \"own\" service worker. This is used to buffer\n // `message` events that may be received prior to calling `register()`.\n await this.getSW();\n // If the service worker that sent the message is in the list of own\n // service workers for this instance, dispatch a `message` event.\n // NOTE: we check for all previously owned service workers rather than\n // just the current one because some messages (e.g. cache updates) use\n // a timeout when sent and may be delayed long enough for a service worker\n // update to be found.\n if (this._ownSWs.has(source)) {\n this.dispatchEvent(new WorkboxEvent('message', {\n data,\n sw: source,\n originalEvent,\n }));\n }\n };\n this._scriptURL = scriptURL;\n this._registerOptions = registerOptions;\n // Add a message listener immediately since messages received during\n // page load are buffered only until the DOMContentLoaded event:\n // https://github.com/GoogleChrome/workbox/issues/2202\n navigator.serviceWorker.addEventListener('message', this._onMessage);\n }\n /**\n * Registers a service worker for this instances script URL and service\n * worker options. By default this method delays registration until after\n * the window has loaded.\n *\n * @param {Object} [options]\n * @param {Function} [options.immediate=false] Setting this to true will\n * register the service worker immediately, even if the window has\n * not loaded (not recommended).\n */\n async register({ immediate = false } = {}) {\n if (process.env.NODE_ENV !== 'production') {\n if (this._registrationTime) {\n logger.error('Cannot re-register a Workbox instance after it has ' +\n 'been registered. Create a new instance instead.');\n return;\n }\n }\n if (!immediate && document.readyState !== 'complete') {\n await new Promise((res) => window.addEventListener('load', res));\n }\n // Set this flag to true if any service worker was controlling the page\n // at registration time.\n this._isUpdate = Boolean(navigator.serviceWorker.controller);\n // Before registering, attempt to determine if a SW is already controlling\n // the page, and if that SW script (and version, if specified) matches this\n // instance's script.\n this._compatibleControllingSW = this._getControllingSWIfCompatible();\n this._registration = await this._registerScript();\n // If we have a compatible controller, store the controller as the \"own\"\n // SW, resolve active/controlling deferreds and add necessary listeners.\n if (this._compatibleControllingSW) {\n this._sw = this._compatibleControllingSW;\n this._activeDeferred.resolve(this._compatibleControllingSW);\n this._controllingDeferred.resolve(this._compatibleControllingSW);\n this._compatibleControllingSW.addEventListener('statechange', this._onStateChange, { once: true });\n }\n // If there's a waiting service worker with a matching URL before the\n // `updatefound` event fires, it likely means that this site is open\n // in another tab, or the user refreshed the page (and thus the previous\n // page wasn't fully unloaded before this page started loading).\n // https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#waiting\n const waitingSW = this._registration.waiting;\n if (waitingSW && urlsMatch(waitingSW.scriptURL, this._scriptURL)) {\n // Store the waiting SW as the \"own\" Sw, even if it means overwriting\n // a compatible controller.\n this._sw = waitingSW;\n // Run this in the next microtask, so any code that adds an event\n // listener after awaiting `register()` will get this event.\n dontWaitFor(Promise.resolve().then(() => {\n this.dispatchEvent(new WorkboxEvent('waiting', {\n sw: waitingSW,\n wasWaitingBeforeRegister: true,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.warn('A service worker was already waiting to activate ' +\n 'before this script was registered...');\n }\n }));\n }\n // If an \"own\" SW is already set, resolve the deferred.\n if (this._sw) {\n this._swDeferred.resolve(this._sw);\n this._ownSWs.add(this._sw);\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Successfully registered service worker.', this._scriptURL);\n if (navigator.serviceWorker.controller) {\n if (this._compatibleControllingSW) {\n logger.debug('A service worker with the same script URL ' +\n 'is already controlling this page.');\n }\n else {\n logger.debug('A service worker with a different script URL is ' +\n 'currently controlling the page. The browser is now fetching ' +\n 'the new script now...');\n }\n }\n const currentPageIsOutOfScope = () => {\n const scopeURL = new URL(this._registerOptions.scope || this._scriptURL, document.baseURI);\n const scopeURLBasePath = new URL('./', scopeURL.href).pathname;\n return !location.pathname.startsWith(scopeURLBasePath);\n };\n if (currentPageIsOutOfScope()) {\n logger.warn('The current page is not in scope for the registered ' +\n 'service worker. Was this a mistake?');\n }\n }\n this._registration.addEventListener('updatefound', this._onUpdateFound);\n navigator.serviceWorker.addEventListener('controllerchange', this._onControllerChange, { once: true });\n return this._registration;\n }\n /**\n * Checks for updates of the registered service worker.\n */\n async update() {\n if (!this._registration) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error('Cannot update a Workbox instance without ' +\n 'being registered. Register the Workbox instance first.');\n }\n return;\n }\n // Try to update registration\n await this._registration.update();\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is active. If a service worker was already controlling at registration\n * time then it will resolve to that if the script URLs (and optionally\n * script versions) match, otherwise it will wait until an update is found\n * and activates.\n *\n * @return {Promise<ServiceWorker>}\n */\n get active() {\n return this._activeDeferred.promise;\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is controlling the page. If a service worker was already controlling at\n * registration time then it will resolve to that if the script URLs (and\n * optionally script versions) match, otherwise it will wait until an update\n * is found and starts controlling the page.\n * Note: the first time a service worker is installed it will active but\n * not start controlling the page unless `clients.claim()` is called in the\n * service worker.\n *\n * @return {Promise<ServiceWorker>}\n */\n get controlling() {\n return this._controllingDeferred.promise;\n }\n /**\n * Resolves with a reference to a service worker that matches the script URL\n * of this instance, as soon as it's available.\n *\n * If, at registration time, there's already an active or waiting service\n * worker with a matching script URL, it will be used (with the waiting\n * service worker taking precedence over the active service worker if both\n * match, since the waiting service worker would have been registered more\n * recently).\n * If there's no matching active or waiting service worker at registration\n * time then the promise will not resolve until an update is found and starts\n * installing, at which point the installing service worker is used.\n *\n * @return {Promise<ServiceWorker>}\n */\n async getSW() {\n // If `this._sw` is set, resolve with that as we want `getSW()` to\n // return the correct (new) service worker if an update is found.\n return this._sw !== undefined ? this._sw : this._swDeferred.promise;\n }\n /**\n * Sends the passed data object to the service worker registered by this\n * instance (via [`getSW()`]{@link module:workbox-window.Workbox#getSW}) and resolves\n * with a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will never\n * resolve.\n *\n * @param {Object} data An object to send to the service worker\n * @return {Promise<Object>}\n */\n async messageSW(data) {\n const sw = await this.getSW();\n return messageSW(sw, data);\n }\n /**\n * Checks for a service worker already controlling the page and returns\n * it if its script URL matches.\n *\n * @private\n * @return {ServiceWorker|undefined}\n */\n _getControllingSWIfCompatible() {\n const controller = navigator.serviceWorker.controller;\n if (controller && urlsMatch(controller.scriptURL, this._scriptURL)) {\n return controller;\n }\n else {\n return undefined;\n }\n }\n /**\n * Registers a service worker for this instances script URL and register\n * options and tracks the time registration was complete.\n *\n * @private\n */\n async _registerScript() {\n try {\n const reg = await navigator.serviceWorker.register(this._scriptURL, this._registerOptions);\n // Keep track of when registration happened, so it can be used in the\n // `this._onUpdateFound` heuristic. Also use the presence of this\n // property as a way to see if `.register()` has been called.\n this._registrationTime = performance.now();\n return reg;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(error);\n }\n // Re-throw the error.\n throw error;\n }\n }\n}\nexport { Workbox };\n// The jsdoc comments below outline the events this instance may dispatch:\n// -----------------------------------------------------------------------\n/**\n * The `message` event is dispatched any time a `postMessage` is received.\n *\n * @event module:workbox-window.Workbox#message\n * @type {WorkboxEvent}\n * @property {*} data The `data` property from the original `message` event.\n * @property {Event} originalEvent The original [`message`]{@link https://developer.mozilla.org/en-US/docs/Web/API/MessageEvent}\n * event.\n * @property {string} type `message`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `installed` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed`.\n *\n * Then can happen either the very first time a service worker is installed,\n * or after an update to the current service worker is found. In the case\n * of an update being found, the event's `isUpdate` property will be `true`.\n *\n * @event module:workbox-window.Workbox#installed\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `installed`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `waiting` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed` and then doesn't immediately change to `activating`.\n * It may also be dispatched if a service worker with the same\n * [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * was already waiting when the [`register()`]{@link module:workbox-window.Workbox#register}\n * method was called.\n *\n * @event module:workbox-window.Workbox#waiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event|undefined} originalEvent The original\n * [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event, or `undefined` in the case where the service worker was waiting\n * to before `.register()` was called.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {boolean|undefined} wasWaitingBeforeRegister True if a service worker with\n * a matching `scriptURL` was already waiting when this `Workbox`\n * instance called `register()`.\n * @property {string} type `waiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `controlling` event is dispatched if a\n * [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * fires on the service worker [container]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer}\n * and the [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * of the new [controller]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/controller}\n * matches the `scriptURL` of the `Workbox` instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}.\n *\n * @event module:workbox-window.Workbox#controlling\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this service worker was registered.\n * @property {string} type `controlling`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `activated` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#activated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `activated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `redundant` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `redundant`.\n *\n * @event module:workbox-window.Workbox#redundant\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `redundant`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalinstalled` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `installed`.\n *\n * @event module:workbox-window.Workbox#externalinstalled\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalinstalled`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalwaiting` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `waiting`.\n *\n * @event module:workbox-window.Workbox#externalwaiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalwaiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalactivated` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#externalactivated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalactivated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A helper function that prevents a promise from being flagged as unused.\n *\n * @private\n **/\nexport function dontWaitFor(promise) {\n // Effective no-op.\n promise.then(() => { });\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\n/**\n * A minimal `EventTarget` shim.\n * This is necessary because not all browsers support constructable\n * `EventTarget`, so using a real `EventTarget` will error.\n * @private\n */\nexport class WorkboxEventTarget {\n constructor() {\n this._eventListenerRegistry = new Map();\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n addEventListener(type, listener) {\n const foo = this._getEventListenersByType(type);\n foo.add(listener);\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n removeEventListener(type, listener) {\n this._getEventListenersByType(type).delete(listener);\n }\n /**\n * @param {Object} event\n * @private\n */\n dispatchEvent(event) {\n event.target = this;\n const listeners = this._getEventListenersByType(event.type);\n for (const listener of listeners) {\n listener(event);\n }\n }\n /**\n * Returns a Set of listeners associated with the passed event type.\n * If no handlers have been registered, an empty Set is returned.\n *\n * @param {string} type The event type.\n * @return {Set<ListenerCallback>} An array of handler functions.\n * @private\n */\n _getEventListenersByType(type) {\n if (!this._eventListenerRegistry.has(type)) {\n this._eventListenerRegistry.set(type, new Set());\n }\n return this._eventListenerRegistry.get(type);\n }\n}\n"],"names":["self","_","e","messageSW","sw","data","Promise","resolve","messageChannel","MessageChannel","port1","onmessage","event","postMessage","port2","Deferred","promise","reject","_this","urlsMatch","url1","url2","href","location","URL","WorkboxEvent","type","props","Object","assign","this","_await","value","then","direct","_empty","Workbox","scriptURL","registerOptions","f","_registerOptions","_updateFoundCount","_swDeferred","_activeDeferred","_controllingDeferred","_registrationTime","_ownSWs","Set","_onUpdateFound","registration","_registration","installingSW","installing","_scriptURL","performance","now","_externalSW","removeEventListener","_sw","add","addEventListener","_onStateChange","originalEvent","target","state","isExternal","eventPrefix","eventProps","_isUpdate","isUpdate","dispatchEvent","_waitingTimeout","setTimeout","waiting","clearTimeout","_onControllerChange","navigator","serviceWorker","controller","_onMessage","source","getSW","has","args","i","arguments","length","apply","register","immediate","body","result","document","readyState","res","window","Boolean","_compatibleControllingSW","_this3","_getControllingSWIfCompatible","_registerScript","once","waitingSW","wasWaitingBeforeRegister","update","undefined","recover","_this11","reg","error","_eventListenerRegistry","Map","listener","_getEventListenersByType","delete","set","get"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ try{self["workbox:window:5.1.4"]&&_()}catch(t){}function t(t,s){return new Promise(i=>{const e=new MessageChannel;e.port1.onmessage=t=>{i(t.data)},t.postMessage(s,[e.port2])})}try{self["workbox:core:5.1.4"]&&_()}catch(t){}class s{constructor(){this.promise=new Promise((t,s)=>{this.resolve=t,this.reject=s})}}function i(t,s){const{href:i}=location;return new URL(t,i).href===new URL(s,i).href}class e{constructor(t,s){this.type=t,Object.assign(this,s)}}class h extends class{constructor(){this.t=new Map}addEventListener(t,s){this.s(t).add(s)}removeEventListener(t,s){this.s(t).delete(s)}dispatchEvent(t){t.target=this;const s=this.s(t.type);for(const i of s)i(t)}s(t){return this.t.has(t)||this.t.set(t,new Set),this.t.get(t)}}{constructor(t,h={}){super(),this.i={},this.h=0,this.o=new s,this.g=new s,this.l=new s,this.u=0,this.v=new Set,this.m=()=>{const t=this.p,s=t.installing;this.h>0||!i(s.scriptURL,this.S)||performance.now()>this.u+6e4?(this.L=s,t.removeEventListener("updatefound",this.m)):(this._=s,this.v.add(s),this.o.resolve(s)),++this.h,s.addEventListener("statechange",this.P)},this.P=t=>{const s=this.p,i=t.target,{state:h}=i,n=i===this.L,a=n?"external":"",r={sw:i,originalEvent:t};!n&&this.W&&(r.isUpdate=!0),this.dispatchEvent(new e(a+h,r)),"installed"===h?this.B=self.setTimeout(()=>{"installed"===h&&s.waiting===i&&this.dispatchEvent(new e(a+"waiting",r))},200):"activating"===h&&(clearTimeout(this.B),n||this.g.resolve(i))},this.C=t=>{const s=this._;s===navigator.serviceWorker.controller&&(this.dispatchEvent(new e("controlling",{sw:s,originalEvent:t,isUpdate:this.W})),this.l.resolve(s))},this.R=async t=>{const{data:s,source:i}=t;await this.getSW(),this.v.has(i)&&this.dispatchEvent(new e("message",{data:s,sw:i,originalEvent:t}))},this.S=t,this.i=h,navigator.serviceWorker.addEventListener("message",this.R)}async register({immediate:t=!1}={}){t||"complete"===document.readyState||await new Promise(t=>window.addEventListener("load",t)),this.W=Boolean(navigator.serviceWorker.controller),this.U=this.M(),this.p=await this.T(),this.U&&(this._=this.U,this.g.resolve(this.U),this.l.resolve(this.U),this.U.addEventListener("statechange",this.P,{once:!0}));const s=this.p.waiting;return s&&i(s.scriptURL,this.S)&&(this._=s,Promise.resolve().then(()=>{this.dispatchEvent(new e("waiting",{sw:s,wasWaitingBeforeRegister:!0}))}).then(()=>{})),this._&&(this.o.resolve(this._),this.v.add(this._)),this.p.addEventListener("updatefound",this.m),navigator.serviceWorker.addEventListener("controllerchange",this.C,{once:!0}),this.p}async update(){this.p&&await this.p.update()}get active(){return this.g.promise}get controlling(){return this.l.promise}async getSW(){return void 0!==this._?this._:this.o.promise}async messageSW(s){return t(await this.getSW(),s)}M(){const t=navigator.serviceWorker.controller;return t&&i(t.scriptURL,this.S)?t:void 0}async T(){try{const t=await navigator.serviceWorker.register(this.S,this.i);return this.u=performance.now(),t}catch(t){throw t}}}export{h as Workbox,t as messageSW};
2
+ //# sourceMappingURL=workbox-window.prod.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workbox-window.prod.mjs","sources":["../_version.js","../messageSW.js","../../workbox-core/_version.js","../../workbox-core/_private/Deferred.js","../utils/urlsMatch.js","../utils/WorkboxEvent.js","../Workbox.js","../utils/WorkboxEventTarget.js","../../workbox-core/_private/dontWaitFor.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:window:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Sends a data object to a service worker via `postMessage` and resolves with\n * a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will not\n * resolve.\n *\n * @param {ServiceWorker} sw The service worker to send the message to.\n * @param {Object} data An object to send to the service worker.\n * @return {Promise<Object|undefined>}\n * @memberof module:workbox-window\n */\nfunction messageSW(sw, data) {\n return new Promise((resolve) => {\n const messageChannel = new MessageChannel();\n messageChannel.port1.onmessage = (event) => {\n resolve(event.data);\n };\n sw.postMessage(data, [messageChannel.port2]);\n });\n}\nexport { messageSW };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns true if two URLs have the same `.href` property. The URLS can be\n * relative, and if they are the current location href is used to resolve URLs.\n *\n * @private\n * @param {string} url1\n * @param {string} url2\n * @return {boolean}\n */\nexport function urlsMatch(url1, url2) {\n const { href } = location;\n return new URL(url1, href).href === new URL(url2, href).href;\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A minimal `Event` subclass shim.\n * This doesn't *actually* subclass `Event` because not all browsers support\n * constructable `EventTarget`, and using a real `Event` will error.\n * @private\n */\nexport class WorkboxEvent {\n constructor(type, props) {\n this.type = type;\n Object.assign(this, props);\n }\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { Deferred } from 'workbox-core/_private/Deferred.js';\nimport { dontWaitFor } from 'workbox-core/_private/dontWaitFor.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { messageSW } from './messageSW.js';\nimport { WorkboxEventTarget } from './utils/WorkboxEventTarget.js';\nimport { urlsMatch } from './utils/urlsMatch.js';\nimport { WorkboxEvent } from './utils/WorkboxEvent.js';\nimport './_version.js';\n// The time a SW must be in the waiting phase before we can conclude\n// `skipWaiting()` wasn't called. This 200 amount wasn't scientifically\n// chosen, but it seems to avoid false positives in my testing.\nconst WAITING_TIMEOUT_DURATION = 200;\n// The amount of time after a registration that we can reasonably conclude\n// that the registration didn't trigger an update.\nconst REGISTRATION_TIMEOUT_DURATION = 60000;\n/**\n * A class to aid in handling service worker registration, updates, and\n * reacting to service worker lifecycle events.\n *\n * @fires [message]{@link module:workbox-window.Workbox#message}\n * @fires [installed]{@link module:workbox-window.Workbox#installed}\n * @fires [waiting]{@link module:workbox-window.Workbox#waiting}\n * @fires [controlling]{@link module:workbox-window.Workbox#controlling}\n * @fires [activated]{@link module:workbox-window.Workbox#activated}\n * @fires [redundant]{@link module:workbox-window.Workbox#redundant}\n * @fires [externalinstalled]{@link module:workbox-window.Workbox#externalinstalled}\n * @fires [externalwaiting]{@link module:workbox-window.Workbox#externalwaiting}\n * @fires [externalactivated]{@link module:workbox-window.Workbox#externalactivated}\n * @memberof module:workbox-window\n */\nclass Workbox extends WorkboxEventTarget {\n /**\n * Creates a new Workbox instance with a script URL and service worker\n * options. The script URL and options are the same as those used when\n * calling `navigator.serviceWorker.register(scriptURL, options)`. See:\n * https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/register\n *\n * @param {string} scriptURL The service worker script associated with this\n * instance.\n * @param {Object} [registerOptions] The service worker options associated\n * with this instance.\n */\n constructor(scriptURL, registerOptions = {}) {\n super();\n this._registerOptions = {};\n this._updateFoundCount = 0;\n // Deferreds we can resolve later.\n this._swDeferred = new Deferred();\n this._activeDeferred = new Deferred();\n this._controllingDeferred = new Deferred();\n this._registrationTime = 0;\n this._ownSWs = new Set();\n /**\n * @private\n */\n this._onUpdateFound = () => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const installingSW = registration.installing;\n // If the script URL passed to `navigator.serviceWorker.register()` is\n // different from the current controlling SW's script URL, we know any\n // successful registration calls will trigger an `updatefound` event.\n // But if the registered script URL is the same as the current controlling\n // SW's script URL, we'll only get an `updatefound` event if the file\n // changed since it was last registered. This can be a problem if the user\n // opens up the same page in a different tab, and that page registers\n // a SW that triggers an update. It's a problem because this page has no\n // good way of knowing whether the `updatefound` event came from the SW\n // script it registered or from a registration attempt made by a newer\n // version of the page running in another tab.\n // To minimize the possibility of a false positive, we use the logic here:\n const updateLikelyTriggeredExternally = \n // Since we enforce only calling `register()` once, and since we don't\n // add the `updatefound` event listener until the `register()` call, if\n // `_updateFoundCount` is > 0 then it means this method has already\n // been called, thus this SW must be external\n this._updateFoundCount > 0 ||\n // If the script URL of the installing SW is different from this\n // instance's script URL, we know it's definitely not from our\n // registration.\n !urlsMatch(installingSW.scriptURL, this._scriptURL) ||\n // If all of the above are false, then we use a time-based heuristic:\n // Any `updatefound` event that occurs long after our registration is\n // assumed to be external.\n (performance.now() >\n this._registrationTime + REGISTRATION_TIMEOUT_DURATION) ?\n // If any of the above are not true, we assume the update was\n // triggered by this instance.\n true : false;\n if (updateLikelyTriggeredExternally) {\n this._externalSW = installingSW;\n registration.removeEventListener('updatefound', this._onUpdateFound);\n }\n else {\n // If the update was not triggered externally we know the installing\n // SW is the one we registered, so we set it.\n this._sw = installingSW;\n this._ownSWs.add(installingSW);\n this._swDeferred.resolve(installingSW);\n // The `installing` state isn't something we have a dedicated\n // callback for, but we do log messages for it in development.\n if (process.env.NODE_ENV !== 'production') {\n if (navigator.serviceWorker.controller) {\n logger.log('Updated service worker found. Installing now...');\n }\n else {\n logger.log('Service worker is installing...');\n }\n }\n }\n // Increment the `updatefound` count, so future invocations of this\n // method can be sure they were triggered externally.\n ++this._updateFoundCount;\n // Add a `statechange` listener regardless of whether this update was\n // triggered externally, since we have callbacks for both.\n installingSW.addEventListener('statechange', this._onStateChange);\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onStateChange = (originalEvent) => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const sw = originalEvent.target;\n const { state } = sw;\n const isExternal = sw === this._externalSW;\n const eventPrefix = isExternal ? 'external' : '';\n const eventProps = {\n sw,\n originalEvent\n };\n if (!isExternal && this._isUpdate) {\n eventProps.isUpdate = true;\n }\n this.dispatchEvent(new WorkboxEvent(eventPrefix + state, eventProps));\n if (state === 'installed') {\n // This timeout is used to ignore cases where the service worker calls\n // `skipWaiting()` in the install event, thus moving it directly in the\n // activating state. (Since all service workers *must* go through the\n // waiting phase, the only way to detect `skipWaiting()` called in the\n // install event is to observe that the time spent in the waiting phase\n // is very short.)\n // NOTE: we don't need separate timeouts for the own and external SWs\n // since they can't go through these phases at the same time.\n this._waitingTimeout = self.setTimeout(() => {\n // Ensure the SW is still waiting (it may now be redundant).\n if (state === 'installed' && registration.waiting === sw) {\n this.dispatchEvent(new WorkboxEvent(eventPrefix + 'waiting', eventProps));\n if (process.env.NODE_ENV !== 'production') {\n if (isExternal) {\n logger.warn('An external service worker has installed but is ' +\n 'waiting for this client to close before activating...');\n }\n else {\n logger.warn('The service worker has installed but is waiting ' +\n 'for existing clients to close before activating...');\n }\n }\n }\n }, WAITING_TIMEOUT_DURATION);\n }\n else if (state === 'activating') {\n clearTimeout(this._waitingTimeout);\n if (!isExternal) {\n this._activeDeferred.resolve(sw);\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n switch (state) {\n case 'installed':\n if (isExternal) {\n logger.warn('An external service worker has installed. ' +\n 'You may want to suggest users reload this page.');\n }\n else {\n logger.log('Registered service worker installed.');\n }\n break;\n case 'activated':\n if (isExternal) {\n logger.warn('An external service worker has activated.');\n }\n else {\n logger.log('Registered service worker activated.');\n if (sw !== navigator.serviceWorker.controller) {\n logger.warn('The registered service worker is active but ' +\n 'not yet controlling the page. Reload or run ' +\n '`clients.claim()` in the service worker.');\n }\n }\n break;\n case 'redundant':\n if (sw === this._compatibleControllingSW) {\n logger.log('Previously controlling service worker now redundant!');\n }\n else if (!isExternal) {\n logger.log('Registered service worker now redundant!');\n }\n break;\n }\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onControllerChange = (originalEvent) => {\n const sw = this._sw;\n if (sw === navigator.serviceWorker.controller) {\n this.dispatchEvent(new WorkboxEvent('controlling', {\n sw,\n originalEvent,\n isUpdate: this._isUpdate,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Registered service worker now controlling this page.');\n }\n this._controllingDeferred.resolve(sw);\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onMessage = async (originalEvent) => {\n const { data, source } = originalEvent;\n // Wait until there's an \"own\" service worker. This is used to buffer\n // `message` events that may be received prior to calling `register()`.\n await this.getSW();\n // If the service worker that sent the message is in the list of own\n // service workers for this instance, dispatch a `message` event.\n // NOTE: we check for all previously owned service workers rather than\n // just the current one because some messages (e.g. cache updates) use\n // a timeout when sent and may be delayed long enough for a service worker\n // update to be found.\n if (this._ownSWs.has(source)) {\n this.dispatchEvent(new WorkboxEvent('message', {\n data,\n sw: source,\n originalEvent,\n }));\n }\n };\n this._scriptURL = scriptURL;\n this._registerOptions = registerOptions;\n // Add a message listener immediately since messages received during\n // page load are buffered only until the DOMContentLoaded event:\n // https://github.com/GoogleChrome/workbox/issues/2202\n navigator.serviceWorker.addEventListener('message', this._onMessage);\n }\n /**\n * Registers a service worker for this instances script URL and service\n * worker options. By default this method delays registration until after\n * the window has loaded.\n *\n * @param {Object} [options]\n * @param {Function} [options.immediate=false] Setting this to true will\n * register the service worker immediately, even if the window has\n * not loaded (not recommended).\n */\n async register({ immediate = false } = {}) {\n if (process.env.NODE_ENV !== 'production') {\n if (this._registrationTime) {\n logger.error('Cannot re-register a Workbox instance after it has ' +\n 'been registered. Create a new instance instead.');\n return;\n }\n }\n if (!immediate && document.readyState !== 'complete') {\n await new Promise((res) => window.addEventListener('load', res));\n }\n // Set this flag to true if any service worker was controlling the page\n // at registration time.\n this._isUpdate = Boolean(navigator.serviceWorker.controller);\n // Before registering, attempt to determine if a SW is already controlling\n // the page, and if that SW script (and version, if specified) matches this\n // instance's script.\n this._compatibleControllingSW = this._getControllingSWIfCompatible();\n this._registration = await this._registerScript();\n // If we have a compatible controller, store the controller as the \"own\"\n // SW, resolve active/controlling deferreds and add necessary listeners.\n if (this._compatibleControllingSW) {\n this._sw = this._compatibleControllingSW;\n this._activeDeferred.resolve(this._compatibleControllingSW);\n this._controllingDeferred.resolve(this._compatibleControllingSW);\n this._compatibleControllingSW.addEventListener('statechange', this._onStateChange, { once: true });\n }\n // If there's a waiting service worker with a matching URL before the\n // `updatefound` event fires, it likely means that this site is open\n // in another tab, or the user refreshed the page (and thus the previous\n // page wasn't fully unloaded before this page started loading).\n // https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#waiting\n const waitingSW = this._registration.waiting;\n if (waitingSW && urlsMatch(waitingSW.scriptURL, this._scriptURL)) {\n // Store the waiting SW as the \"own\" Sw, even if it means overwriting\n // a compatible controller.\n this._sw = waitingSW;\n // Run this in the next microtask, so any code that adds an event\n // listener after awaiting `register()` will get this event.\n dontWaitFor(Promise.resolve().then(() => {\n this.dispatchEvent(new WorkboxEvent('waiting', {\n sw: waitingSW,\n wasWaitingBeforeRegister: true,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.warn('A service worker was already waiting to activate ' +\n 'before this script was registered...');\n }\n }));\n }\n // If an \"own\" SW is already set, resolve the deferred.\n if (this._sw) {\n this._swDeferred.resolve(this._sw);\n this._ownSWs.add(this._sw);\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Successfully registered service worker.', this._scriptURL);\n if (navigator.serviceWorker.controller) {\n if (this._compatibleControllingSW) {\n logger.debug('A service worker with the same script URL ' +\n 'is already controlling this page.');\n }\n else {\n logger.debug('A service worker with a different script URL is ' +\n 'currently controlling the page. The browser is now fetching ' +\n 'the new script now...');\n }\n }\n const currentPageIsOutOfScope = () => {\n const scopeURL = new URL(this._registerOptions.scope || this._scriptURL, document.baseURI);\n const scopeURLBasePath = new URL('./', scopeURL.href).pathname;\n return !location.pathname.startsWith(scopeURLBasePath);\n };\n if (currentPageIsOutOfScope()) {\n logger.warn('The current page is not in scope for the registered ' +\n 'service worker. Was this a mistake?');\n }\n }\n this._registration.addEventListener('updatefound', this._onUpdateFound);\n navigator.serviceWorker.addEventListener('controllerchange', this._onControllerChange, { once: true });\n return this._registration;\n }\n /**\n * Checks for updates of the registered service worker.\n */\n async update() {\n if (!this._registration) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error('Cannot update a Workbox instance without ' +\n 'being registered. Register the Workbox instance first.');\n }\n return;\n }\n // Try to update registration\n await this._registration.update();\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is active. If a service worker was already controlling at registration\n * time then it will resolve to that if the script URLs (and optionally\n * script versions) match, otherwise it will wait until an update is found\n * and activates.\n *\n * @return {Promise<ServiceWorker>}\n */\n get active() {\n return this._activeDeferred.promise;\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is controlling the page. If a service worker was already controlling at\n * registration time then it will resolve to that if the script URLs (and\n * optionally script versions) match, otherwise it will wait until an update\n * is found and starts controlling the page.\n * Note: the first time a service worker is installed it will active but\n * not start controlling the page unless `clients.claim()` is called in the\n * service worker.\n *\n * @return {Promise<ServiceWorker>}\n */\n get controlling() {\n return this._controllingDeferred.promise;\n }\n /**\n * Resolves with a reference to a service worker that matches the script URL\n * of this instance, as soon as it's available.\n *\n * If, at registration time, there's already an active or waiting service\n * worker with a matching script URL, it will be used (with the waiting\n * service worker taking precedence over the active service worker if both\n * match, since the waiting service worker would have been registered more\n * recently).\n * If there's no matching active or waiting service worker at registration\n * time then the promise will not resolve until an update is found and starts\n * installing, at which point the installing service worker is used.\n *\n * @return {Promise<ServiceWorker>}\n */\n async getSW() {\n // If `this._sw` is set, resolve with that as we want `getSW()` to\n // return the correct (new) service worker if an update is found.\n return this._sw !== undefined ? this._sw : this._swDeferred.promise;\n }\n /**\n * Sends the passed data object to the service worker registered by this\n * instance (via [`getSW()`]{@link module:workbox-window.Workbox#getSW}) and resolves\n * with a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will never\n * resolve.\n *\n * @param {Object} data An object to send to the service worker\n * @return {Promise<Object>}\n */\n async messageSW(data) {\n const sw = await this.getSW();\n return messageSW(sw, data);\n }\n /**\n * Checks for a service worker already controlling the page and returns\n * it if its script URL matches.\n *\n * @private\n * @return {ServiceWorker|undefined}\n */\n _getControllingSWIfCompatible() {\n const controller = navigator.serviceWorker.controller;\n if (controller && urlsMatch(controller.scriptURL, this._scriptURL)) {\n return controller;\n }\n else {\n return undefined;\n }\n }\n /**\n * Registers a service worker for this instances script URL and register\n * options and tracks the time registration was complete.\n *\n * @private\n */\n async _registerScript() {\n try {\n const reg = await navigator.serviceWorker.register(this._scriptURL, this._registerOptions);\n // Keep track of when registration happened, so it can be used in the\n // `this._onUpdateFound` heuristic. Also use the presence of this\n // property as a way to see if `.register()` has been called.\n this._registrationTime = performance.now();\n return reg;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(error);\n }\n // Re-throw the error.\n throw error;\n }\n }\n}\nexport { Workbox };\n// The jsdoc comments below outline the events this instance may dispatch:\n// -----------------------------------------------------------------------\n/**\n * The `message` event is dispatched any time a `postMessage` is received.\n *\n * @event module:workbox-window.Workbox#message\n * @type {WorkboxEvent}\n * @property {*} data The `data` property from the original `message` event.\n * @property {Event} originalEvent The original [`message`]{@link https://developer.mozilla.org/en-US/docs/Web/API/MessageEvent}\n * event.\n * @property {string} type `message`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `installed` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed`.\n *\n * Then can happen either the very first time a service worker is installed,\n * or after an update to the current service worker is found. In the case\n * of an update being found, the event's `isUpdate` property will be `true`.\n *\n * @event module:workbox-window.Workbox#installed\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `installed`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `waiting` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed` and then doesn't immediately change to `activating`.\n * It may also be dispatched if a service worker with the same\n * [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * was already waiting when the [`register()`]{@link module:workbox-window.Workbox#register}\n * method was called.\n *\n * @event module:workbox-window.Workbox#waiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event|undefined} originalEvent The original\n * [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event, or `undefined` in the case where the service worker was waiting\n * to before `.register()` was called.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {boolean|undefined} wasWaitingBeforeRegister True if a service worker with\n * a matching `scriptURL` was already waiting when this `Workbox`\n * instance called `register()`.\n * @property {string} type `waiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `controlling` event is dispatched if a\n * [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * fires on the service worker [container]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer}\n * and the [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * of the new [controller]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/controller}\n * matches the `scriptURL` of the `Workbox` instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}.\n *\n * @event module:workbox-window.Workbox#controlling\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this service worker was registered.\n * @property {string} type `controlling`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `activated` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#activated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `activated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `redundant` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `redundant`.\n *\n * @event module:workbox-window.Workbox#redundant\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `redundant`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalinstalled` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `installed`.\n *\n * @event module:workbox-window.Workbox#externalinstalled\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalinstalled`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalwaiting` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `waiting`.\n *\n * @event module:workbox-window.Workbox#externalwaiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalwaiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalactivated` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#externalactivated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalactivated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\n/**\n * A minimal `EventTarget` shim.\n * This is necessary because not all browsers support constructable\n * `EventTarget`, so using a real `EventTarget` will error.\n * @private\n */\nexport class WorkboxEventTarget {\n constructor() {\n this._eventListenerRegistry = new Map();\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n addEventListener(type, listener) {\n const foo = this._getEventListenersByType(type);\n foo.add(listener);\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n removeEventListener(type, listener) {\n this._getEventListenersByType(type).delete(listener);\n }\n /**\n * @param {Object} event\n * @private\n */\n dispatchEvent(event) {\n event.target = this;\n const listeners = this._getEventListenersByType(event.type);\n for (const listener of listeners) {\n listener(event);\n }\n }\n /**\n * Returns a Set of listeners associated with the passed event type.\n * If no handlers have been registered, an empty Set is returned.\n *\n * @param {string} type The event type.\n * @return {Set<ListenerCallback>} An array of handler functions.\n * @private\n */\n _getEventListenersByType(type) {\n if (!this._eventListenerRegistry.has(type)) {\n this._eventListenerRegistry.set(type, new Set());\n }\n return this._eventListenerRegistry.get(type);\n }\n}\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A helper function that prevents a promise from being flagged as unused.\n *\n * @private\n **/\nexport function dontWaitFor(promise) {\n // Effective no-op.\n promise.then(() => { });\n}\n"],"names":["self","_","e","messageSW","sw","data","Promise","resolve","messageChannel","MessageChannel","port1","onmessage","event","postMessage","port2","Deferred","constructor","promise","reject","urlsMatch","url1","url2","href","location","URL","WorkboxEvent","type","props","Object","assign","this","Workbox","_eventListenerRegistry","Map","addEventListener","listener","_getEventListenersByType","add","removeEventListener","delete","dispatchEvent","target","listeners","has","set","Set","get","scriptURL","registerOptions","_registerOptions","_updateFoundCount","_swDeferred","_activeDeferred","_controllingDeferred","_registrationTime","_ownSWs","_onUpdateFound","registration","_registration","installingSW","installing","_scriptURL","performance","now","_externalSW","_sw","_onStateChange","originalEvent","state","isExternal","eventPrefix","eventProps","_isUpdate","isUpdate","_waitingTimeout","setTimeout","waiting","clearTimeout","_onControllerChange","navigator","serviceWorker","controller","_onMessage","async","source","getSW","immediate","document","readyState","res","window","Boolean","_compatibleControllingSW","_getControllingSWIfCompatible","_registerScript","once","waitingSW","then","wasWaitingBeforeRegister","update","undefined","reg","register","error"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ !function(n,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((n=n||self).workbox={})}(this,(function(n){"use strict";try{self["workbox:window:5.1.4"]&&_()}catch(n){}function t(n,t){return new Promise((function(r){var e=new MessageChannel;e.port1.onmessage=function(n){r(n.data)},n.postMessage(t,[e.port2])}))}function r(n,t){for(var r=0;r<t.length;r++){var e=t[r];e.enumerable=e.enumerable||!1,e.configurable=!0,"value"in e&&(e.writable=!0),Object.defineProperty(n,e.key,e)}}function e(n,t){(null==t||t>n.length)&&(t=n.length);for(var r=0,e=new Array(t);r<t;r++)e[r]=n[r];return e}function i(n,t){var r;if("undefined"==typeof Symbol||null==n[Symbol.iterator]){if(Array.isArray(n)||(r=function(n,t){if(n){if("string"==typeof n)return e(n,t);var r=Object.prototype.toString.call(n).slice(8,-1);return"Object"===r&&n.constructor&&(r=n.constructor.name),"Map"===r||"Set"===r?Array.from(n):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?e(n,t):void 0}}(n))||t&&n&&"number"==typeof n.length){r&&(n=r);var i=0;return function(){return i>=n.length?{done:!0}:{done:!1,value:n[i++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}return(r=n[Symbol.iterator]()).next.bind(r)}try{self["workbox:core:5.1.4"]&&_()}catch(n){}var o=function(){var n=this;this.promise=new Promise((function(t,r){n.resolve=t,n.reject=r}))};function u(n,t){var r=location.href;return new URL(n,r).href===new URL(t,r).href}var a=function(n,t){this.type=n,Object.assign(this,t)};function c(n,t,r){return r?t?t(n):n:(n&&n.then||(n=Promise.resolve(n)),t?n.then(t):n)}function f(){}var s=function(n){var e,i;function f(t,r){var e,i;return void 0===r&&(r={}),(e=n.call(this)||this).t={},e.i=0,e.o=new o,e.u=new o,e.s=new o,e.v=0,e.h=new Set,e.l=function(){var n=e.m,t=n.installing;e.i>0||!u(t.scriptURL,e.g)||performance.now()>e.v+6e4?(e.p=t,n.removeEventListener("updatefound",e.l)):(e.P=t,e.h.add(t),e.o.resolve(t)),++e.i,t.addEventListener("statechange",e.j)},e.j=function(n){var t=e.m,r=n.target,i=r.state,o=r===e.p,u=o?"external":"",c={sw:r,originalEvent:n};!o&&e.S&&(c.isUpdate=!0),e.dispatchEvent(new a(u+i,c)),"installed"===i?e.O=self.setTimeout((function(){"installed"===i&&t.waiting===r&&e.dispatchEvent(new a(u+"waiting",c))}),200):"activating"===i&&(clearTimeout(e.O),o||e.u.resolve(r))},e.A=function(n){var t=e.P;t===navigator.serviceWorker.controller&&(e.dispatchEvent(new a("controlling",{sw:t,originalEvent:n,isUpdate:e.S})),e.s.resolve(t))},e.M=(i=function(n){var t=n.data,r=n.source;return c(e.getSW(),(function(){e.h.has(r)&&e.dispatchEvent(new a("message",{data:t,sw:r,originalEvent:n}))}))},function(){for(var n=[],t=0;t<arguments.length;t++)n[t]=arguments[t];try{return Promise.resolve(i.apply(this,n))}catch(n){return Promise.reject(n)}}),e.g=t,e.t=r,navigator.serviceWorker.addEventListener("message",e.M),e}i=n,(e=f).prototype=Object.create(i.prototype),e.prototype.constructor=e,e.__proto__=i;var s,h,l,d=f.prototype;return d.register=function(n){var t=(void 0===n?{}:n).immediate,r=void 0!==t&&t;try{var e=this;return function(n,t){var r=n();if(r&&r.then)return r.then(t);return t(r)}((function(){if(!r&&"complete"!==document.readyState)return v(new Promise((function(n){return window.addEventListener("load",n)})))}),(function(){return e.S=Boolean(navigator.serviceWorker.controller),e.U=e._(),c(e.I(),(function(n){e.m=n,e.U&&(e.P=e.U,e.u.resolve(e.U),e.s.resolve(e.U),e.U.addEventListener("statechange",e.j,{once:!0}));var t=e.m.waiting;return t&&u(t.scriptURL,e.g)&&(e.P=t,Promise.resolve().then((function(){e.dispatchEvent(new a("waiting",{sw:t,wasWaitingBeforeRegister:!0}))})).then((function(){}))),e.P&&(e.o.resolve(e.P),e.h.add(e.P)),e.m.addEventListener("updatefound",e.l),navigator.serviceWorker.addEventListener("controllerchange",e.A,{once:!0}),e.m}))}))}catch(n){return Promise.reject(n)}},d.update=function(){try{return this.m?v(this.m.update()):void 0}catch(n){return Promise.reject(n)}},d.getSW=function(){try{return void 0!==this.P?this.P:this.o.promise}catch(n){return Promise.reject(n)}},d.messageSW=function(n){try{return c(this.getSW(),(function(r){return t(r,n)}))}catch(n){return Promise.reject(n)}},d._=function(){var n=navigator.serviceWorker.controller;return n&&u(n.scriptURL,this.g)?n:void 0},d.I=function(){try{var n=this;return function(n,t){try{var r=n()}catch(n){return t(n)}if(r&&r.then)return r.then(void 0,t);return r}((function(){return c(navigator.serviceWorker.register(n.g,n.t),(function(t){return n.v=performance.now(),t}))}),(function(n){throw n}))}catch(n){return Promise.reject(n)}},s=f,(h=[{key:"active",get:function(){return this.u.promise}},{key:"controlling",get:function(){return this.s.promise}}])&&r(s.prototype,h),l&&r(s,l),f}(function(){function n(){this.R=new Map}var t=n.prototype;return t.addEventListener=function(n,t){this.k(n).add(t)},t.removeEventListener=function(n,t){this.k(n).delete(t)},t.dispatchEvent=function(n){n.target=this;for(var t,r=i(this.k(n.type));!(t=r()).done;){(0,t.value)(n)}},t.k=function(n){return this.R.has(n)||this.R.set(n,new Set),this.R.get(n)},n}());function v(n,t){if(!t)return n&&n.then?n.then(f):Promise.resolve()}n.Workbox=s,n.messageSW=t,Object.defineProperty(n,"__esModule",{value:!0})}));
2
+ //# sourceMappingURL=workbox-window.prod.umd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workbox-window.prod.umd.js","sources":["../_version.js","../messageSW.js","../../workbox-core/_version.js","../../workbox-core/_private/Deferred.js","../utils/urlsMatch.js","../utils/WorkboxEvent.js","../Workbox.js","../../workbox-core/_private/dontWaitFor.js","../utils/WorkboxEventTarget.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:window:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Sends a data object to a service worker via `postMessage` and resolves with\n * a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will not\n * resolve.\n *\n * @param {ServiceWorker} sw The service worker to send the message to.\n * @param {Object} data An object to send to the service worker.\n * @return {Promise<Object|undefined>}\n * @memberof module:workbox-window\n */\nfunction messageSW(sw, data) {\n return new Promise((resolve) => {\n const messageChannel = new MessageChannel();\n messageChannel.port1.onmessage = (event) => {\n resolve(event.data);\n };\n sw.postMessage(data, [messageChannel.port2]);\n });\n}\nexport { messageSW };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:5.1.4'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns true if two URLs have the same `.href` property. The URLS can be\n * relative, and if they are the current location href is used to resolve URLs.\n *\n * @private\n * @param {string} url1\n * @param {string} url2\n * @return {boolean}\n */\nexport function urlsMatch(url1, url2) {\n const { href } = location;\n return new URL(url1, href).href === new URL(url2, href).href;\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A minimal `Event` subclass shim.\n * This doesn't *actually* subclass `Event` because not all browsers support\n * constructable `EventTarget`, and using a real `Event` will error.\n * @private\n */\nexport class WorkboxEvent {\n constructor(type, props) {\n this.type = type;\n Object.assign(this, props);\n }\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { Deferred } from 'workbox-core/_private/Deferred.js';\nimport { dontWaitFor } from 'workbox-core/_private/dontWaitFor.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { messageSW } from './messageSW.js';\nimport { WorkboxEventTarget } from './utils/WorkboxEventTarget.js';\nimport { urlsMatch } from './utils/urlsMatch.js';\nimport { WorkboxEvent } from './utils/WorkboxEvent.js';\nimport './_version.js';\n// The time a SW must be in the waiting phase before we can conclude\n// `skipWaiting()` wasn't called. This 200 amount wasn't scientifically\n// chosen, but it seems to avoid false positives in my testing.\nconst WAITING_TIMEOUT_DURATION = 200;\n// The amount of time after a registration that we can reasonably conclude\n// that the registration didn't trigger an update.\nconst REGISTRATION_TIMEOUT_DURATION = 60000;\n/**\n * A class to aid in handling service worker registration, updates, and\n * reacting to service worker lifecycle events.\n *\n * @fires [message]{@link module:workbox-window.Workbox#message}\n * @fires [installed]{@link module:workbox-window.Workbox#installed}\n * @fires [waiting]{@link module:workbox-window.Workbox#waiting}\n * @fires [controlling]{@link module:workbox-window.Workbox#controlling}\n * @fires [activated]{@link module:workbox-window.Workbox#activated}\n * @fires [redundant]{@link module:workbox-window.Workbox#redundant}\n * @fires [externalinstalled]{@link module:workbox-window.Workbox#externalinstalled}\n * @fires [externalwaiting]{@link module:workbox-window.Workbox#externalwaiting}\n * @fires [externalactivated]{@link module:workbox-window.Workbox#externalactivated}\n * @memberof module:workbox-window\n */\nclass Workbox extends WorkboxEventTarget {\n /**\n * Creates a new Workbox instance with a script URL and service worker\n * options. The script URL and options are the same as those used when\n * calling `navigator.serviceWorker.register(scriptURL, options)`. See:\n * https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/register\n *\n * @param {string} scriptURL The service worker script associated with this\n * instance.\n * @param {Object} [registerOptions] The service worker options associated\n * with this instance.\n */\n constructor(scriptURL, registerOptions = {}) {\n super();\n this._registerOptions = {};\n this._updateFoundCount = 0;\n // Deferreds we can resolve later.\n this._swDeferred = new Deferred();\n this._activeDeferred = new Deferred();\n this._controllingDeferred = new Deferred();\n this._registrationTime = 0;\n this._ownSWs = new Set();\n /**\n * @private\n */\n this._onUpdateFound = () => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const installingSW = registration.installing;\n // If the script URL passed to `navigator.serviceWorker.register()` is\n // different from the current controlling SW's script URL, we know any\n // successful registration calls will trigger an `updatefound` event.\n // But if the registered script URL is the same as the current controlling\n // SW's script URL, we'll only get an `updatefound` event if the file\n // changed since it was last registered. This can be a problem if the user\n // opens up the same page in a different tab, and that page registers\n // a SW that triggers an update. It's a problem because this page has no\n // good way of knowing whether the `updatefound` event came from the SW\n // script it registered or from a registration attempt made by a newer\n // version of the page running in another tab.\n // To minimize the possibility of a false positive, we use the logic here:\n const updateLikelyTriggeredExternally = \n // Since we enforce only calling `register()` once, and since we don't\n // add the `updatefound` event listener until the `register()` call, if\n // `_updateFoundCount` is > 0 then it means this method has already\n // been called, thus this SW must be external\n this._updateFoundCount > 0 ||\n // If the script URL of the installing SW is different from this\n // instance's script URL, we know it's definitely not from our\n // registration.\n !urlsMatch(installingSW.scriptURL, this._scriptURL) ||\n // If all of the above are false, then we use a time-based heuristic:\n // Any `updatefound` event that occurs long after our registration is\n // assumed to be external.\n (performance.now() >\n this._registrationTime + REGISTRATION_TIMEOUT_DURATION) ?\n // If any of the above are not true, we assume the update was\n // triggered by this instance.\n true : false;\n if (updateLikelyTriggeredExternally) {\n this._externalSW = installingSW;\n registration.removeEventListener('updatefound', this._onUpdateFound);\n }\n else {\n // If the update was not triggered externally we know the installing\n // SW is the one we registered, so we set it.\n this._sw = installingSW;\n this._ownSWs.add(installingSW);\n this._swDeferred.resolve(installingSW);\n // The `installing` state isn't something we have a dedicated\n // callback for, but we do log messages for it in development.\n if (process.env.NODE_ENV !== 'production') {\n if (navigator.serviceWorker.controller) {\n logger.log('Updated service worker found. Installing now...');\n }\n else {\n logger.log('Service worker is installing...');\n }\n }\n }\n // Increment the `updatefound` count, so future invocations of this\n // method can be sure they were triggered externally.\n ++this._updateFoundCount;\n // Add a `statechange` listener regardless of whether this update was\n // triggered externally, since we have callbacks for both.\n installingSW.addEventListener('statechange', this._onStateChange);\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onStateChange = (originalEvent) => {\n // `this._registration` will never be `undefined` after an update is found.\n const registration = this._registration;\n const sw = originalEvent.target;\n const { state } = sw;\n const isExternal = sw === this._externalSW;\n const eventPrefix = isExternal ? 'external' : '';\n const eventProps = {\n sw,\n originalEvent\n };\n if (!isExternal && this._isUpdate) {\n eventProps.isUpdate = true;\n }\n this.dispatchEvent(new WorkboxEvent(eventPrefix + state, eventProps));\n if (state === 'installed') {\n // This timeout is used to ignore cases where the service worker calls\n // `skipWaiting()` in the install event, thus moving it directly in the\n // activating state. (Since all service workers *must* go through the\n // waiting phase, the only way to detect `skipWaiting()` called in the\n // install event is to observe that the time spent in the waiting phase\n // is very short.)\n // NOTE: we don't need separate timeouts for the own and external SWs\n // since they can't go through these phases at the same time.\n this._waitingTimeout = self.setTimeout(() => {\n // Ensure the SW is still waiting (it may now be redundant).\n if (state === 'installed' && registration.waiting === sw) {\n this.dispatchEvent(new WorkboxEvent(eventPrefix + 'waiting', eventProps));\n if (process.env.NODE_ENV !== 'production') {\n if (isExternal) {\n logger.warn('An external service worker has installed but is ' +\n 'waiting for this client to close before activating...');\n }\n else {\n logger.warn('The service worker has installed but is waiting ' +\n 'for existing clients to close before activating...');\n }\n }\n }\n }, WAITING_TIMEOUT_DURATION);\n }\n else if (state === 'activating') {\n clearTimeout(this._waitingTimeout);\n if (!isExternal) {\n this._activeDeferred.resolve(sw);\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n switch (state) {\n case 'installed':\n if (isExternal) {\n logger.warn('An external service worker has installed. ' +\n 'You may want to suggest users reload this page.');\n }\n else {\n logger.log('Registered service worker installed.');\n }\n break;\n case 'activated':\n if (isExternal) {\n logger.warn('An external service worker has activated.');\n }\n else {\n logger.log('Registered service worker activated.');\n if (sw !== navigator.serviceWorker.controller) {\n logger.warn('The registered service worker is active but ' +\n 'not yet controlling the page. Reload or run ' +\n '`clients.claim()` in the service worker.');\n }\n }\n break;\n case 'redundant':\n if (sw === this._compatibleControllingSW) {\n logger.log('Previously controlling service worker now redundant!');\n }\n else if (!isExternal) {\n logger.log('Registered service worker now redundant!');\n }\n break;\n }\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onControllerChange = (originalEvent) => {\n const sw = this._sw;\n if (sw === navigator.serviceWorker.controller) {\n this.dispatchEvent(new WorkboxEvent('controlling', {\n sw,\n originalEvent,\n isUpdate: this._isUpdate,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Registered service worker now controlling this page.');\n }\n this._controllingDeferred.resolve(sw);\n }\n };\n /**\n * @private\n * @param {Event} originalEvent\n */\n this._onMessage = async (originalEvent) => {\n const { data, source } = originalEvent;\n // Wait until there's an \"own\" service worker. This is used to buffer\n // `message` events that may be received prior to calling `register()`.\n await this.getSW();\n // If the service worker that sent the message is in the list of own\n // service workers for this instance, dispatch a `message` event.\n // NOTE: we check for all previously owned service workers rather than\n // just the current one because some messages (e.g. cache updates) use\n // a timeout when sent and may be delayed long enough for a service worker\n // update to be found.\n if (this._ownSWs.has(source)) {\n this.dispatchEvent(new WorkboxEvent('message', {\n data,\n sw: source,\n originalEvent,\n }));\n }\n };\n this._scriptURL = scriptURL;\n this._registerOptions = registerOptions;\n // Add a message listener immediately since messages received during\n // page load are buffered only until the DOMContentLoaded event:\n // https://github.com/GoogleChrome/workbox/issues/2202\n navigator.serviceWorker.addEventListener('message', this._onMessage);\n }\n /**\n * Registers a service worker for this instances script URL and service\n * worker options. By default this method delays registration until after\n * the window has loaded.\n *\n * @param {Object} [options]\n * @param {Function} [options.immediate=false] Setting this to true will\n * register the service worker immediately, even if the window has\n * not loaded (not recommended).\n */\n async register({ immediate = false } = {}) {\n if (process.env.NODE_ENV !== 'production') {\n if (this._registrationTime) {\n logger.error('Cannot re-register a Workbox instance after it has ' +\n 'been registered. Create a new instance instead.');\n return;\n }\n }\n if (!immediate && document.readyState !== 'complete') {\n await new Promise((res) => window.addEventListener('load', res));\n }\n // Set this flag to true if any service worker was controlling the page\n // at registration time.\n this._isUpdate = Boolean(navigator.serviceWorker.controller);\n // Before registering, attempt to determine if a SW is already controlling\n // the page, and if that SW script (and version, if specified) matches this\n // instance's script.\n this._compatibleControllingSW = this._getControllingSWIfCompatible();\n this._registration = await this._registerScript();\n // If we have a compatible controller, store the controller as the \"own\"\n // SW, resolve active/controlling deferreds and add necessary listeners.\n if (this._compatibleControllingSW) {\n this._sw = this._compatibleControllingSW;\n this._activeDeferred.resolve(this._compatibleControllingSW);\n this._controllingDeferred.resolve(this._compatibleControllingSW);\n this._compatibleControllingSW.addEventListener('statechange', this._onStateChange, { once: true });\n }\n // If there's a waiting service worker with a matching URL before the\n // `updatefound` event fires, it likely means that this site is open\n // in another tab, or the user refreshed the page (and thus the previous\n // page wasn't fully unloaded before this page started loading).\n // https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#waiting\n const waitingSW = this._registration.waiting;\n if (waitingSW && urlsMatch(waitingSW.scriptURL, this._scriptURL)) {\n // Store the waiting SW as the \"own\" Sw, even if it means overwriting\n // a compatible controller.\n this._sw = waitingSW;\n // Run this in the next microtask, so any code that adds an event\n // listener after awaiting `register()` will get this event.\n dontWaitFor(Promise.resolve().then(() => {\n this.dispatchEvent(new WorkboxEvent('waiting', {\n sw: waitingSW,\n wasWaitingBeforeRegister: true,\n }));\n if (process.env.NODE_ENV !== 'production') {\n logger.warn('A service worker was already waiting to activate ' +\n 'before this script was registered...');\n }\n }));\n }\n // If an \"own\" SW is already set, resolve the deferred.\n if (this._sw) {\n this._swDeferred.resolve(this._sw);\n this._ownSWs.add(this._sw);\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Successfully registered service worker.', this._scriptURL);\n if (navigator.serviceWorker.controller) {\n if (this._compatibleControllingSW) {\n logger.debug('A service worker with the same script URL ' +\n 'is already controlling this page.');\n }\n else {\n logger.debug('A service worker with a different script URL is ' +\n 'currently controlling the page. The browser is now fetching ' +\n 'the new script now...');\n }\n }\n const currentPageIsOutOfScope = () => {\n const scopeURL = new URL(this._registerOptions.scope || this._scriptURL, document.baseURI);\n const scopeURLBasePath = new URL('./', scopeURL.href).pathname;\n return !location.pathname.startsWith(scopeURLBasePath);\n };\n if (currentPageIsOutOfScope()) {\n logger.warn('The current page is not in scope for the registered ' +\n 'service worker. Was this a mistake?');\n }\n }\n this._registration.addEventListener('updatefound', this._onUpdateFound);\n navigator.serviceWorker.addEventListener('controllerchange', this._onControllerChange, { once: true });\n return this._registration;\n }\n /**\n * Checks for updates of the registered service worker.\n */\n async update() {\n if (!this._registration) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error('Cannot update a Workbox instance without ' +\n 'being registered. Register the Workbox instance first.');\n }\n return;\n }\n // Try to update registration\n await this._registration.update();\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is active. If a service worker was already controlling at registration\n * time then it will resolve to that if the script URLs (and optionally\n * script versions) match, otherwise it will wait until an update is found\n * and activates.\n *\n * @return {Promise<ServiceWorker>}\n */\n get active() {\n return this._activeDeferred.promise;\n }\n /**\n * Resolves to the service worker registered by this instance as soon as it\n * is controlling the page. If a service worker was already controlling at\n * registration time then it will resolve to that if the script URLs (and\n * optionally script versions) match, otherwise it will wait until an update\n * is found and starts controlling the page.\n * Note: the first time a service worker is installed it will active but\n * not start controlling the page unless `clients.claim()` is called in the\n * service worker.\n *\n * @return {Promise<ServiceWorker>}\n */\n get controlling() {\n return this._controllingDeferred.promise;\n }\n /**\n * Resolves with a reference to a service worker that matches the script URL\n * of this instance, as soon as it's available.\n *\n * If, at registration time, there's already an active or waiting service\n * worker with a matching script URL, it will be used (with the waiting\n * service worker taking precedence over the active service worker if both\n * match, since the waiting service worker would have been registered more\n * recently).\n * If there's no matching active or waiting service worker at registration\n * time then the promise will not resolve until an update is found and starts\n * installing, at which point the installing service worker is used.\n *\n * @return {Promise<ServiceWorker>}\n */\n async getSW() {\n // If `this._sw` is set, resolve with that as we want `getSW()` to\n // return the correct (new) service worker if an update is found.\n return this._sw !== undefined ? this._sw : this._swDeferred.promise;\n }\n /**\n * Sends the passed data object to the service worker registered by this\n * instance (via [`getSW()`]{@link module:workbox-window.Workbox#getSW}) and resolves\n * with a response (if any).\n *\n * A response can be set in a message handler in the service worker by\n * calling `event.ports[0].postMessage(...)`, which will resolve the promise\n * returned by `messageSW()`. If no response is set, the promise will never\n * resolve.\n *\n * @param {Object} data An object to send to the service worker\n * @return {Promise<Object>}\n */\n async messageSW(data) {\n const sw = await this.getSW();\n return messageSW(sw, data);\n }\n /**\n * Checks for a service worker already controlling the page and returns\n * it if its script URL matches.\n *\n * @private\n * @return {ServiceWorker|undefined}\n */\n _getControllingSWIfCompatible() {\n const controller = navigator.serviceWorker.controller;\n if (controller && urlsMatch(controller.scriptURL, this._scriptURL)) {\n return controller;\n }\n else {\n return undefined;\n }\n }\n /**\n * Registers a service worker for this instances script URL and register\n * options and tracks the time registration was complete.\n *\n * @private\n */\n async _registerScript() {\n try {\n const reg = await navigator.serviceWorker.register(this._scriptURL, this._registerOptions);\n // Keep track of when registration happened, so it can be used in the\n // `this._onUpdateFound` heuristic. Also use the presence of this\n // property as a way to see if `.register()` has been called.\n this._registrationTime = performance.now();\n return reg;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(error);\n }\n // Re-throw the error.\n throw error;\n }\n }\n}\nexport { Workbox };\n// The jsdoc comments below outline the events this instance may dispatch:\n// -----------------------------------------------------------------------\n/**\n * The `message` event is dispatched any time a `postMessage` is received.\n *\n * @event module:workbox-window.Workbox#message\n * @type {WorkboxEvent}\n * @property {*} data The `data` property from the original `message` event.\n * @property {Event} originalEvent The original [`message`]{@link https://developer.mozilla.org/en-US/docs/Web/API/MessageEvent}\n * event.\n * @property {string} type `message`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `installed` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed`.\n *\n * Then can happen either the very first time a service worker is installed,\n * or after an update to the current service worker is found. In the case\n * of an update being found, the event's `isUpdate` property will be `true`.\n *\n * @event module:workbox-window.Workbox#installed\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `installed`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `waiting` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `installed` and then doesn't immediately change to `activating`.\n * It may also be dispatched if a service worker with the same\n * [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * was already waiting when the [`register()`]{@link module:workbox-window.Workbox#register}\n * method was called.\n *\n * @event module:workbox-window.Workbox#waiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event|undefined} originalEvent The original\n * [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event, or `undefined` in the case where the service worker was waiting\n * to before `.register()` was called.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {boolean|undefined} wasWaitingBeforeRegister True if a service worker with\n * a matching `scriptURL` was already waiting when this `Workbox`\n * instance called `register()`.\n * @property {string} type `waiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `controlling` event is dispatched if a\n * [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * fires on the service worker [container]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer}\n * and the [`scriptURL`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/scriptURL}\n * of the new [controller]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/controller}\n * matches the `scriptURL` of the `Workbox` instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}.\n *\n * @event module:workbox-window.Workbox#controlling\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`controllerchange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/oncontrollerchange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this service worker was registered.\n * @property {string} type `controlling`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `activated` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#activated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `activated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `redundant` event is dispatched if the state of a\n * [`Workbox`]{@link module:workbox-window.Workbox} instance's\n * [registered service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-precaching#def-registered-sw}\n * changes to `redundant`.\n *\n * @event module:workbox-window.Workbox#redundant\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {boolean|undefined} isUpdate True if a service worker was already\n * controlling when this `Workbox` instance called `register()`.\n * @property {string} type `redundant`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalinstalled` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `installed`.\n *\n * @event module:workbox-window.Workbox#externalinstalled\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalinstalled`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalwaiting` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `waiting`.\n *\n * @event module:workbox-window.Workbox#externalwaiting\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalwaiting`.\n * @property {Workbox} target The `Workbox` instance.\n */\n/**\n * The `externalactivated` event is dispatched if the state of an\n * [external service worker]{@link https://developers.google.com/web/tools/workbox/modules/workbox-window#when_an_unexpected_version_of_the_service_worker_is_found}\n * changes to `activated`.\n *\n * @event module:workbox-window.Workbox#externalactivated\n * @type {WorkboxEvent}\n * @property {ServiceWorker} sw The service worker instance.\n * @property {Event} originalEvent The original [`statechange`]{@link https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker/onstatechange}\n * event.\n * @property {string} type `externalactivated`.\n * @property {Workbox} target The `Workbox` instance.\n */\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A helper function that prevents a promise from being flagged as unused.\n *\n * @private\n **/\nexport function dontWaitFor(promise) {\n // Effective no-op.\n promise.then(() => { });\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\n/**\n * A minimal `EventTarget` shim.\n * This is necessary because not all browsers support constructable\n * `EventTarget`, so using a real `EventTarget` will error.\n * @private\n */\nexport class WorkboxEventTarget {\n constructor() {\n this._eventListenerRegistry = new Map();\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n addEventListener(type, listener) {\n const foo = this._getEventListenersByType(type);\n foo.add(listener);\n }\n /**\n * @param {string} type\n * @param {Function} listener\n * @private\n */\n removeEventListener(type, listener) {\n this._getEventListenersByType(type).delete(listener);\n }\n /**\n * @param {Object} event\n * @private\n */\n dispatchEvent(event) {\n event.target = this;\n const listeners = this._getEventListenersByType(event.type);\n for (const listener of listeners) {\n listener(event);\n }\n }\n /**\n * Returns a Set of listeners associated with the passed event type.\n * If no handlers have been registered, an empty Set is returned.\n *\n * @param {string} type The event type.\n * @return {Set<ListenerCallback>} An array of handler functions.\n * @private\n */\n _getEventListenersByType(type) {\n if (!this._eventListenerRegistry.has(type)) {\n this._eventListenerRegistry.set(type, new Set());\n }\n return this._eventListenerRegistry.get(type);\n }\n}\n"],"names":["self","_","e","messageSW","sw","data","Promise","resolve","messageChannel","MessageChannel","port1","onmessage","event","postMessage","port2","Deferred","promise","reject","_this","urlsMatch","url1","url2","href","location","URL","WorkboxEvent","type","props","Object","assign","this","_await","value","then","direct","_empty","Workbox","scriptURL","registerOptions","f","_registerOptions","_updateFoundCount","_swDeferred","_activeDeferred","_controllingDeferred","_registrationTime","_ownSWs","Set","_onUpdateFound","registration","_registration","installingSW","installing","_scriptURL","performance","now","_externalSW","removeEventListener","_sw","add","addEventListener","_onStateChange","originalEvent","target","state","isExternal","eventPrefix","eventProps","_isUpdate","isUpdate","dispatchEvent","_waitingTimeout","setTimeout","waiting","clearTimeout","_onControllerChange","navigator","serviceWorker","controller","_onMessage","source","getSW","has","args","i","arguments","length","apply","register","immediate","body","result","document","readyState","res","window","Boolean","_compatibleControllingSW","_this3","_getControllingSWIfCompatible","_registerScript","once","waitingSW","wasWaitingBeforeRegister","update","undefined","recover","_this11","reg","error","_eventListenerRegistry","Map","listener","_getEventListenersByType","delete","set","get"],"mappings":"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"}
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: jekyll-amp-pwa-plugin
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.1.2
4
+ version: 5.1.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Walter Perdan
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2018-09-03 00:00:00.000000000 Z
11
+ date: 2021-03-16 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: This plugin provides PWA support for Jekyll with amp. Generate a service
14
14
  worker and provides precache with Google Workbox.
@@ -18,61 +18,73 @@ extensions: []
18
18
  extra_rdoc_files: []
19
19
  files:
20
20
  - lib/jekyll-amp-pwa-plugin.rb
21
- - lib/vendor/workbox-v3.6.2/workbox-background-sync.dev.js
22
- - lib/vendor/workbox-v3.6.2/workbox-background-sync.dev.js.map
23
- - lib/vendor/workbox-v3.6.2/workbox-background-sync.prod.js
24
- - lib/vendor/workbox-v3.6.2/workbox-background-sync.prod.js.map
25
- - lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.dev.js
26
- - lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.dev.js.map
27
- - lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.prod.js
28
- - lib/vendor/workbox-v3.6.2/workbox-broadcast-cache-update.prod.js.map
29
- - lib/vendor/workbox-v3.6.2/workbox-cache-expiration.dev.js
30
- - lib/vendor/workbox-v3.6.2/workbox-cache-expiration.dev.js.map
31
- - lib/vendor/workbox-v3.6.2/workbox-cache-expiration.prod.js
32
- - lib/vendor/workbox-v3.6.2/workbox-cache-expiration.prod.js.map
33
- - lib/vendor/workbox-v3.6.2/workbox-cacheable-response.dev.js
34
- - lib/vendor/workbox-v3.6.2/workbox-cacheable-response.dev.js.map
35
- - lib/vendor/workbox-v3.6.2/workbox-cacheable-response.prod.js
36
- - lib/vendor/workbox-v3.6.2/workbox-cacheable-response.prod.js.map
37
- - lib/vendor/workbox-v3.6.2/workbox-core.dev.js
38
- - lib/vendor/workbox-v3.6.2/workbox-core.dev.js.map
39
- - lib/vendor/workbox-v3.6.2/workbox-core.prod.js
40
- - lib/vendor/workbox-v3.6.2/workbox-core.prod.js.map
41
- - lib/vendor/workbox-v3.6.2/workbox-google-analytics.dev.js
42
- - lib/vendor/workbox-v3.6.2/workbox-google-analytics.dev.js.map
43
- - lib/vendor/workbox-v3.6.2/workbox-google-analytics.prod.js
44
- - lib/vendor/workbox-v3.6.2/workbox-google-analytics.prod.js.map
45
- - lib/vendor/workbox-v3.6.2/workbox-navigation-preload.dev.js
46
- - lib/vendor/workbox-v3.6.2/workbox-navigation-preload.dev.js.map
47
- - lib/vendor/workbox-v3.6.2/workbox-navigation-preload.prod.js
48
- - lib/vendor/workbox-v3.6.2/workbox-navigation-preload.prod.js.map
49
- - lib/vendor/workbox-v3.6.2/workbox-precaching.dev.js
50
- - lib/vendor/workbox-v3.6.2/workbox-precaching.dev.js.map
51
- - lib/vendor/workbox-v3.6.2/workbox-precaching.prod.js
52
- - lib/vendor/workbox-v3.6.2/workbox-precaching.prod.js.map
53
- - lib/vendor/workbox-v3.6.2/workbox-range-requests.dev.js
54
- - lib/vendor/workbox-v3.6.2/workbox-range-requests.dev.js.map
55
- - lib/vendor/workbox-v3.6.2/workbox-range-requests.prod.js
56
- - lib/vendor/workbox-v3.6.2/workbox-range-requests.prod.js.map
57
- - lib/vendor/workbox-v3.6.2/workbox-routing.dev.js
58
- - lib/vendor/workbox-v3.6.2/workbox-routing.dev.js.map
59
- - lib/vendor/workbox-v3.6.2/workbox-routing.prod.js
60
- - lib/vendor/workbox-v3.6.2/workbox-routing.prod.js.map
61
- - lib/vendor/workbox-v3.6.2/workbox-strategies.dev.js
62
- - lib/vendor/workbox-v3.6.2/workbox-strategies.dev.js.map
63
- - lib/vendor/workbox-v3.6.2/workbox-strategies.prod.js
64
- - lib/vendor/workbox-v3.6.2/workbox-strategies.prod.js.map
65
- - lib/vendor/workbox-v3.6.2/workbox-streams.dev.js
66
- - lib/vendor/workbox-v3.6.2/workbox-streams.dev.js.map
67
- - lib/vendor/workbox-v3.6.2/workbox-streams.prod.js
68
- - lib/vendor/workbox-v3.6.2/workbox-streams.prod.js.map
69
- - lib/vendor/workbox-v3.6.2/workbox-sw.js
70
- - lib/vendor/workbox-v3.6.2/workbox-sw.js.map
21
+ - lib/vendor/workbox-v5.1.4/workbox-background-sync.dev.js
22
+ - lib/vendor/workbox-v5.1.4/workbox-background-sync.dev.js.map
23
+ - lib/vendor/workbox-v5.1.4/workbox-background-sync.prod.js
24
+ - lib/vendor/workbox-v5.1.4/workbox-background-sync.prod.js.map
25
+ - lib/vendor/workbox-v5.1.4/workbox-broadcast-update.dev.js
26
+ - lib/vendor/workbox-v5.1.4/workbox-broadcast-update.dev.js.map
27
+ - lib/vendor/workbox-v5.1.4/workbox-broadcast-update.prod.js
28
+ - lib/vendor/workbox-v5.1.4/workbox-broadcast-update.prod.js.map
29
+ - lib/vendor/workbox-v5.1.4/workbox-cacheable-response.dev.js
30
+ - lib/vendor/workbox-v5.1.4/workbox-cacheable-response.dev.js.map
31
+ - lib/vendor/workbox-v5.1.4/workbox-cacheable-response.prod.js
32
+ - lib/vendor/workbox-v5.1.4/workbox-cacheable-response.prod.js.map
33
+ - lib/vendor/workbox-v5.1.4/workbox-core.dev.js
34
+ - lib/vendor/workbox-v5.1.4/workbox-core.dev.js.map
35
+ - lib/vendor/workbox-v5.1.4/workbox-core.prod.js
36
+ - lib/vendor/workbox-v5.1.4/workbox-core.prod.js.map
37
+ - lib/vendor/workbox-v5.1.4/workbox-expiration.dev.js
38
+ - lib/vendor/workbox-v5.1.4/workbox-expiration.dev.js.map
39
+ - lib/vendor/workbox-v5.1.4/workbox-expiration.prod.js
40
+ - lib/vendor/workbox-v5.1.4/workbox-expiration.prod.js.map
41
+ - lib/vendor/workbox-v5.1.4/workbox-navigation-preload.dev.js
42
+ - lib/vendor/workbox-v5.1.4/workbox-navigation-preload.dev.js.map
43
+ - lib/vendor/workbox-v5.1.4/workbox-navigation-preload.prod.js
44
+ - lib/vendor/workbox-v5.1.4/workbox-navigation-preload.prod.js.map
45
+ - lib/vendor/workbox-v5.1.4/workbox-offline-ga.dev.js
46
+ - lib/vendor/workbox-v5.1.4/workbox-offline-ga.dev.js.map
47
+ - lib/vendor/workbox-v5.1.4/workbox-offline-ga.prod.js
48
+ - lib/vendor/workbox-v5.1.4/workbox-offline-ga.prod.js.map
49
+ - lib/vendor/workbox-v5.1.4/workbox-precaching.dev.js
50
+ - lib/vendor/workbox-v5.1.4/workbox-precaching.dev.js.map
51
+ - lib/vendor/workbox-v5.1.4/workbox-precaching.prod.js
52
+ - lib/vendor/workbox-v5.1.4/workbox-precaching.prod.js.map
53
+ - lib/vendor/workbox-v5.1.4/workbox-range-requests.dev.js
54
+ - lib/vendor/workbox-v5.1.4/workbox-range-requests.dev.js.map
55
+ - lib/vendor/workbox-v5.1.4/workbox-range-requests.prod.js
56
+ - lib/vendor/workbox-v5.1.4/workbox-range-requests.prod.js.map
57
+ - lib/vendor/workbox-v5.1.4/workbox-routing.dev.js
58
+ - lib/vendor/workbox-v5.1.4/workbox-routing.dev.js.map
59
+ - lib/vendor/workbox-v5.1.4/workbox-routing.prod.js
60
+ - lib/vendor/workbox-v5.1.4/workbox-routing.prod.js.map
61
+ - lib/vendor/workbox-v5.1.4/workbox-strategies.dev.js
62
+ - lib/vendor/workbox-v5.1.4/workbox-strategies.dev.js.map
63
+ - lib/vendor/workbox-v5.1.4/workbox-strategies.prod.js
64
+ - lib/vendor/workbox-v5.1.4/workbox-strategies.prod.js.map
65
+ - lib/vendor/workbox-v5.1.4/workbox-streams.dev.js
66
+ - lib/vendor/workbox-v5.1.4/workbox-streams.dev.js.map
67
+ - lib/vendor/workbox-v5.1.4/workbox-streams.prod.js
68
+ - lib/vendor/workbox-v5.1.4/workbox-streams.prod.js.map
69
+ - lib/vendor/workbox-v5.1.4/workbox-sw.js
70
+ - lib/vendor/workbox-v5.1.4/workbox-sw.js.map
71
+ - lib/vendor/workbox-v5.1.4/workbox-window.dev.es5.mjs
72
+ - lib/vendor/workbox-v5.1.4/workbox-window.dev.es5.mjs.map
73
+ - lib/vendor/workbox-v5.1.4/workbox-window.dev.mjs
74
+ - lib/vendor/workbox-v5.1.4/workbox-window.dev.mjs.map
75
+ - lib/vendor/workbox-v5.1.4/workbox-window.dev.umd.js
76
+ - lib/vendor/workbox-v5.1.4/workbox-window.dev.umd.js.map
77
+ - lib/vendor/workbox-v5.1.4/workbox-window.prod.es5.mjs
78
+ - lib/vendor/workbox-v5.1.4/workbox-window.prod.es5.mjs.map
79
+ - lib/vendor/workbox-v5.1.4/workbox-window.prod.mjs
80
+ - lib/vendor/workbox-v5.1.4/workbox-window.prod.mjs.map
81
+ - lib/vendor/workbox-v5.1.4/workbox-window.prod.umd.js
82
+ - lib/vendor/workbox-v5.1.4/workbox-window.prod.umd.js.map
71
83
  homepage: https://github.com/kalwalt/jekyll-amp-pwa
72
84
  licenses:
73
85
  - MIT
74
86
  metadata: {}
75
- post_install_message:
87
+ post_install_message:
76
88
  rdoc_options: []
77
89
  require_paths:
78
90
  - lib
@@ -87,9 +99,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
87
99
  - !ruby/object:Gem::Version
88
100
  version: '0'
89
101
  requirements: []
90
- rubyforge_project:
91
- rubygems_version: 2.7.6
92
- signing_key:
102
+ rubygems_version: 3.1.4
103
+ signing_key:
93
104
  specification_version: 4
94
105
  summary: PWA support for Jekyll.
95
106
  test_files: []
@@ -1,593 +0,0 @@
1
- this.workbox = this.workbox || {};
2
- this.workbox.backgroundSync = (function (DBWrapper_mjs,WorkboxError_mjs,logger_mjs,assert_mjs,getFriendlyURL_mjs) {
3
- 'use strict';
4
-
5
- try {
6
- self.workbox.v['workbox:background-sync:3.6.2'] = 1;
7
- } catch (e) {} // eslint-disable-line
8
-
9
- /*
10
- Copyright 2017 Google Inc. All Rights Reserved.
11
- Licensed under the Apache License, Version 2.0 (the "License");
12
- you may not use this file except in compliance with the License.
13
- You may obtain a copy of the License at
14
-
15
- http://www.apache.org/licenses/LICENSE-2.0
16
-
17
- Unless required by applicable law or agreed to in writing, software
18
- distributed under the License is distributed on an "AS IS" BASIS,
19
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- See the License for the specific language governing permissions and
21
- limitations under the License.
22
- */
23
-
24
- const serializableProperties = ['method', 'referrer', 'referrerPolicy', 'mode', 'credentials', 'cache', 'redirect', 'integrity', 'keepalive'];
25
-
26
- /**
27
- * A class to make it easier to serialize and de-serialize requests so they
28
- * can be stored in IndexedDB.
29
- *
30
- * @private
31
- */
32
- class StorableRequest {
33
- /**
34
- * Converts a Request object to a plain object that can be structured
35
- * cloned or JSON-stringified.
36
- *
37
- * @param {Request} request
38
- * @return {Promise<StorableRequest>}
39
- *
40
- * @private
41
- */
42
- static fromRequest(request) {
43
- return babelHelpers.asyncToGenerator(function* () {
44
- const requestInit = { headers: {} };
45
-
46
- // Set the body if present.
47
- if (request.method !== 'GET') {
48
- // Use blob to support non-text request bodies,
49
- // and clone first in case the caller still needs the request.
50
- requestInit.body = yield request.clone().blob();
51
- }
52
-
53
- // Convert the headers from an iterable to an object.
54
- for (const [key, value] of request.headers.entries()) {
55
- requestInit.headers[key] = value;
56
- }
57
-
58
- // Add all other serializable request properties
59
- for (const prop of serializableProperties) {
60
- if (request[prop] !== undefined) {
61
- requestInit[prop] = request[prop];
62
- }
63
- }
64
-
65
- return new StorableRequest({ url: request.url, requestInit });
66
- })();
67
- }
68
-
69
- /**
70
- * Accepts a URL and RequestInit dictionary that can be used to create a
71
- * new Request object. A timestamp is also generated so consumers can
72
- * reference when the object was created.
73
- *
74
- * @param {Object} param1
75
- * @param {string} param1.url
76
- * @param {Object} param1.requestInit
77
- * See: https://fetch.spec.whatwg.org/#requestinit
78
- * @param {number} param1.timestamp The time the request was created,
79
- * defaulting to the current time if not specified.
80
- *
81
- * @private
82
- */
83
- constructor({ url, requestInit, timestamp = Date.now() }) {
84
- this.url = url;
85
- this.requestInit = requestInit;
86
-
87
- // "Private"
88
- this._timestamp = timestamp;
89
- }
90
-
91
- /**
92
- * Gets the private _timestamp property.
93
- *
94
- * @return {number}
95
- *
96
- * @private
97
- */
98
- get timestamp() {
99
- return this._timestamp;
100
- }
101
-
102
- /**
103
- * Coverts this instance to a plain Object.
104
- *
105
- * @return {Object}
106
- *
107
- * @private
108
- */
109
- toObject() {
110
- return {
111
- url: this.url,
112
- timestamp: this.timestamp,
113
- requestInit: this.requestInit
114
- };
115
- }
116
-
117
- /**
118
- * Converts this instance to a Request.
119
- *
120
- * @return {Request}
121
- *
122
- * @private
123
- */
124
- toRequest() {
125
- return new Request(this.url, this.requestInit);
126
- }
127
-
128
- /**
129
- * Creates and returns a deep clone of the instance.
130
- *
131
- * @return {StorableRequest}
132
- *
133
- * @private
134
- */
135
- clone() {
136
- const requestInit = Object.assign({}, this.requestInit);
137
- requestInit.headers = Object.assign({}, this.requestInit.headers);
138
- if (this.requestInit.body) {
139
- requestInit.body = this.requestInit.body.slice();
140
- }
141
-
142
- return new StorableRequest({
143
- url: this.url,
144
- timestamp: this.timestamp,
145
- requestInit
146
- });
147
- }
148
- }
149
-
150
- /*
151
- Copyright 2017 Google Inc. All Rights Reserved.
152
- Licensed under the Apache License, Version 2.0 (the "License");
153
- you may not use this file except in compliance with the License.
154
- You may obtain a copy of the License at
155
-
156
- http://www.apache.org/licenses/LICENSE-2.0
157
-
158
- Unless required by applicable law or agreed to in writing, software
159
- distributed under the License is distributed on an "AS IS" BASIS,
160
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
161
- See the License for the specific language governing permissions and
162
- limitations under the License.
163
- */
164
-
165
- const DB_NAME = 'workbox-background-sync';
166
- const OBJECT_STORE_NAME = 'requests';
167
- const INDEXED_PROP = 'queueName';
168
- const TAG_PREFIX = 'workbox-background-sync';
169
- const MAX_RETENTION_TIME = 60 * 24 * 7; // 7 days in minutes
170
-
171
- /*
172
- Copyright 2017 Google Inc. All Rights Reserved.
173
- Licensed under the Apache License, Version 2.0 (the "License");
174
- you may not use this file except in compliance with the License.
175
- You may obtain a copy of the License at
176
-
177
- http://www.apache.org/licenses/LICENSE-2.0
178
-
179
- Unless required by applicable law or agreed to in writing, software
180
- distributed under the License is distributed on an "AS IS" BASIS,
181
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
182
- See the License for the specific language governing permissions and
183
- limitations under the License.
184
- */
185
-
186
- /**
187
- * A class to manage storing requests from a Queue in IndexedbDB,
188
- * indexed by their queue name for easier access.
189
- *
190
- * @private
191
- */
192
- class QueueStore {
193
- /**
194
- * Associates this instance with a Queue instance, so entries added can be
195
- * identified by their queue name.
196
- *
197
- * @param {Queue} queue
198
- *
199
- * @private
200
- */
201
- constructor(queue) {
202
- this._queue = queue;
203
- this._db = new DBWrapper_mjs.DBWrapper(DB_NAME, 1, {
204
- onupgradeneeded: evt => evt.target.result.createObjectStore(OBJECT_STORE_NAME, { autoIncrement: true }).createIndex(INDEXED_PROP, INDEXED_PROP, { unique: false })
205
- });
206
- }
207
-
208
- /**
209
- * Takes a StorableRequest instance, converts it to an object and adds it
210
- * as an entry in the object store.
211
- *
212
- * @param {StorableRequest} storableRequest
213
- *
214
- * @private
215
- */
216
- addEntry(storableRequest) {
217
- var _this = this;
218
-
219
- return babelHelpers.asyncToGenerator(function* () {
220
- yield _this._db.add(OBJECT_STORE_NAME, {
221
- queueName: _this._queue.name,
222
- storableRequest: storableRequest.toObject()
223
- });
224
- })();
225
- }
226
-
227
- /**
228
- * Gets the oldest entry in the object store, removes it, and returns the
229
- * value as a StorableRequest instance. If no entry exists, it returns
230
- * undefined.
231
- *
232
- * @return {StorableRequest|undefined}
233
- *
234
- * @private
235
- */
236
- getAndRemoveOldestEntry() {
237
- var _this2 = this;
238
-
239
- return babelHelpers.asyncToGenerator(function* () {
240
- const [entry] = yield _this2._db.getAllMatching(OBJECT_STORE_NAME, {
241
- index: INDEXED_PROP,
242
- query: IDBKeyRange.only(_this2._queue.name),
243
- count: 1,
244
- includeKeys: true
245
- });
246
-
247
- if (entry) {
248
- yield _this2._db.delete(OBJECT_STORE_NAME, entry.primaryKey);
249
- return new StorableRequest(entry.value.storableRequest);
250
- }
251
- })();
252
- }
253
- }
254
-
255
- /*
256
- Copyright 2017 Google Inc. All Rights Reserved.
257
- Licensed under the Apache License, Version 2.0 (the "License");
258
- you may not use this file except in compliance with the License.
259
- You may obtain a copy of the License at
260
-
261
- http://www.apache.org/licenses/LICENSE-2.0
262
-
263
- Unless required by applicable law or agreed to in writing, software
264
- distributed under the License is distributed on an "AS IS" BASIS,
265
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
266
- See the License for the specific language governing permissions and
267
- limitations under the License.
268
- */
269
-
270
- const queueNames = new Set();
271
-
272
- /**
273
- * A class to manage storing failed requests in IndexedDB and retrying them
274
- * later. All parts of the storing and replaying process are observable via
275
- * callbacks.
276
- *
277
- * @memberof workbox.backgroundSync
278
- */
279
- class Queue {
280
- /**
281
- * Creates an instance of Queue with the given options
282
- *
283
- * @param {string} name The unique name for this queue. This name must be
284
- * unique as it's used to register sync events and store requests
285
- * in IndexedDB specific to this instance. An error will be thrown if
286
- * a duplicate name is detected.
287
- * @param {Object} [options]
288
- * @param {Object} [options.callbacks] Callbacks to observe the lifecycle of
289
- * queued requests. Use these to respond to or modify the requests
290
- * during the replay process.
291
- * @param {function(StorableRequest):undefined}
292
- * [options.callbacks.requestWillEnqueue]
293
- * Invoked immediately before the request is stored to IndexedDB. Use
294
- * this callback to modify request data at store time.
295
- * @param {function(StorableRequest):undefined}
296
- * [options.callbacks.requestWillReplay]
297
- * Invoked immediately before the request is re-fetched. Use this
298
- * callback to modify request data at fetch time.
299
- * @param {function(Array<StorableRequest>):undefined}
300
- * [options.callbacks.queueDidReplay]
301
- * Invoked after all requests in the queue have successfully replayed.
302
- * @param {number} [options.maxRetentionTime = 7 days] The amount of time (in
303
- * minutes) a request may be retried. After this amount of time has
304
- * passed, the request will be deleted from the queue.
305
- */
306
- constructor(name, {
307
- callbacks = {},
308
- maxRetentionTime = MAX_RETENTION_TIME
309
- } = {}) {
310
- // Ensure the store name is not already being used
311
- if (queueNames.has(name)) {
312
- throw new WorkboxError_mjs.WorkboxError('duplicate-queue-name', { name });
313
- } else {
314
- queueNames.add(name);
315
- }
316
-
317
- this._name = name;
318
- this._callbacks = callbacks;
319
- this._maxRetentionTime = maxRetentionTime;
320
- this._queueStore = new QueueStore(this);
321
-
322
- this._addSyncListener();
323
- }
324
-
325
- /**
326
- * @return {string}
327
- */
328
- get name() {
329
- return this._name;
330
- }
331
-
332
- /**
333
- * Stores the passed request into IndexedDB. The database used is
334
- * `workbox-background-sync` and the object store name is the same as
335
- * the name this instance was created with (to guarantee it's unique).
336
- *
337
- * @param {Request} request The request object to store.
338
- */
339
- addRequest(request) {
340
- var _this = this;
341
-
342
- return babelHelpers.asyncToGenerator(function* () {
343
- {
344
- assert_mjs.assert.isInstance(request, Request, {
345
- moduleName: 'workbox-background-sync',
346
- className: 'Queue',
347
- funcName: 'addRequest',
348
- paramName: 'request'
349
- });
350
- }
351
-
352
- const storableRequest = yield StorableRequest.fromRequest(request.clone());
353
- yield _this._runCallback('requestWillEnqueue', storableRequest);
354
- yield _this._queueStore.addEntry(storableRequest);
355
- yield _this._registerSync();
356
- {
357
- logger_mjs.logger.log(`Request for '${getFriendlyURL_mjs.getFriendlyURL(storableRequest.url)}' has been
358
- added to background sync queue '${_this._name}'.`);
359
- }
360
- })();
361
- }
362
-
363
- /**
364
- * Retrieves all stored requests in IndexedDB and retries them. If the
365
- * queue contained requests that were successfully replayed, the
366
- * `queueDidReplay` callback is invoked (which implies the queue is
367
- * now empty). If any of the requests fail, a new sync registration is
368
- * created to retry again later.
369
- */
370
- replayRequests() {
371
- var _this2 = this;
372
-
373
- return babelHelpers.asyncToGenerator(function* () {
374
- const now = Date.now();
375
- const replayedRequests = [];
376
- const failedRequests = [];
377
-
378
- let storableRequest;
379
- while (storableRequest = yield _this2._queueStore.getAndRemoveOldestEntry()) {
380
- // Make a copy so the unmodified request can be stored
381
- // in the event of a replay failure.
382
- const storableRequestClone = storableRequest.clone();
383
-
384
- // Ignore requests older than maxRetentionTime.
385
- const maxRetentionTimeInMs = _this2._maxRetentionTime * 60 * 1000;
386
- if (now - storableRequest.timestamp > maxRetentionTimeInMs) {
387
- continue;
388
- }
389
-
390
- yield _this2._runCallback('requestWillReplay', storableRequest);
391
-
392
- const replay = { request: storableRequest.toRequest() };
393
-
394
- try {
395
- // Clone the request before fetching so callbacks get an unused one.
396
- replay.response = yield fetch(replay.request.clone());
397
- {
398
- logger_mjs.logger.log(`Request for '${getFriendlyURL_mjs.getFriendlyURL(storableRequest.url)}'
399
- has been replayed`);
400
- }
401
- } catch (err) {
402
- {
403
- logger_mjs.logger.log(`Request for '${getFriendlyURL_mjs.getFriendlyURL(storableRequest.url)}'
404
- failed to replay`);
405
- }
406
- replay.error = err;
407
- failedRequests.push(storableRequestClone);
408
- }
409
-
410
- replayedRequests.push(replay);
411
- }
412
-
413
- yield _this2._runCallback('queueDidReplay', replayedRequests);
414
-
415
- // If any requests failed, put the failed requests back in the queue
416
- // and rethrow the failed requests count.
417
- if (failedRequests.length) {
418
- yield Promise.all(failedRequests.map(function (storableRequest) {
419
- return _this2._queueStore.addEntry(storableRequest);
420
- }));
421
-
422
- throw new WorkboxError_mjs.WorkboxError('queue-replay-failed', { name: _this2._name, count: failedRequests.length });
423
- }
424
- })();
425
- }
426
-
427
- /**
428
- * Runs the passed callback if it exists.
429
- *
430
- * @private
431
- * @param {string} name The name of the callback on this._callbacks.
432
- * @param {...*} args The arguments to invoke the callback with.
433
- */
434
- _runCallback(name, ...args) {
435
- var _this3 = this;
436
-
437
- return babelHelpers.asyncToGenerator(function* () {
438
- if (typeof _this3._callbacks[name] === 'function') {
439
- yield _this3._callbacks[name].apply(null, args);
440
- }
441
- })();
442
- }
443
-
444
- /**
445
- * In sync-supporting browsers, this adds a listener for the sync event.
446
- * In non-sync-supporting browsers, this will retry the queue on service
447
- * worker startup.
448
- *
449
- * @private
450
- */
451
- _addSyncListener() {
452
- if ('sync' in registration) {
453
- self.addEventListener('sync', event => {
454
- if (event.tag === `${TAG_PREFIX}:${this._name}`) {
455
- {
456
- logger_mjs.logger.log(`Background sync for tag '${event.tag}'
457
- has been received, starting replay now`);
458
- }
459
- event.waitUntil(this.replayRequests());
460
- }
461
- });
462
- } else {
463
- {
464
- logger_mjs.logger.log(`Background sync replaying without background sync event`);
465
- }
466
- // If the browser doesn't support background sync, retry
467
- // every time the service worker starts up as a fallback.
468
- this.replayRequests();
469
- }
470
- }
471
-
472
- /**
473
- * Registers a sync event with a tag unique to this instance.
474
- *
475
- * @private
476
- */
477
- _registerSync() {
478
- var _this4 = this;
479
-
480
- return babelHelpers.asyncToGenerator(function* () {
481
- if ('sync' in registration) {
482
- try {
483
- yield registration.sync.register(`${TAG_PREFIX}:${_this4._name}`);
484
- } catch (err) {
485
- // This means the registration failed for some reason, possibly due to
486
- // the user disabling it.
487
- {
488
- logger_mjs.logger.warn(`Unable to register sync event for '${_this4._name}'.`, err);
489
- }
490
- }
491
- }
492
- })();
493
- }
494
-
495
- /**
496
- * Returns the set of queue names. This is primarily used to reset the list
497
- * of queue names in tests.
498
- *
499
- * @return {Set}
500
- *
501
- * @private
502
- */
503
- static get _queueNames() {
504
- return queueNames;
505
- }
506
- }
507
-
508
- /*
509
- Copyright 2017 Google Inc. All Rights Reserved.
510
- Licensed under the Apache License, Version 2.0 (the "License");
511
- you may not use this file except in compliance with the License.
512
- You may obtain a copy of the License at
513
-
514
- http://www.apache.org/licenses/LICENSE-2.0
515
-
516
- Unless required by applicable law or agreed to in writing, software
517
- distributed under the License is distributed on an "AS IS" BASIS,
518
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
519
- See the License for the specific language governing permissions and
520
- limitations under the License.
521
- */
522
-
523
- /**
524
- * A class implementing the `fetchDidFail` lifecycle callback. This makes it
525
- * easier to add failed requests to a background sync Queue.
526
- *
527
- * @memberof workbox.backgroundSync
528
- */
529
- class Plugin {
530
- /**
531
- * @param {...*} queueArgs Args to forward to the composed Queue instance.
532
- * See the [Queue]{@link workbox.backgroundSync.Queue} documentation for
533
- * parameter details.
534
- */
535
- constructor(...queueArgs) {
536
- this._queue = new Queue(...queueArgs);
537
- this.fetchDidFail = this.fetchDidFail.bind(this);
538
- }
539
-
540
- /**
541
- * @param {Object} options
542
- * @param {Request} options.request
543
- * @private
544
- */
545
- fetchDidFail({ request }) {
546
- var _this = this;
547
-
548
- return babelHelpers.asyncToGenerator(function* () {
549
- yield _this._queue.addRequest(request);
550
- })();
551
- }
552
- }
553
-
554
- /*
555
- Copyright 2017 Google Inc. All Rights Reserved.
556
- Licensed under the Apache License, Version 2.0 (the "License");
557
- you may not use this file except in compliance with the License.
558
- You may obtain a copy of the License at
559
-
560
- http://www.apache.org/licenses/LICENSE-2.0
561
-
562
- Unless required by applicable law or agreed to in writing, software
563
- distributed under the License is distributed on an "AS IS" BASIS,
564
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
565
- See the License for the specific language governing permissions and
566
- limitations under the License.
567
- */
568
-
569
- var publicAPI = /*#__PURE__*/Object.freeze({
570
- Queue: Queue,
571
- Plugin: Plugin
572
- });
573
-
574
- /*
575
- Copyright 2017 Google Inc. All Rights Reserved.
576
- Licensed under the Apache License, Version 2.0 (the "License");
577
- you may not use this file except in compliance with the License.
578
- You may obtain a copy of the License at
579
-
580
- http://www.apache.org/licenses/LICENSE-2.0
581
-
582
- Unless required by applicable law or agreed to in writing, software
583
- distributed under the License is distributed on an "AS IS" BASIS,
584
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
585
- See the License for the specific language governing permissions and
586
- limitations under the License.
587
- */
588
-
589
- return publicAPI;
590
-
591
- }(workbox.core._private,workbox.core._private,workbox.core._private,workbox.core._private,workbox.core._private));
592
-
593
- //# sourceMappingURL=workbox-background-sync.dev.js.map