diff options
Diffstat (limited to 'public')
-rw-r--r-- | public/sw.js | 49 | ||||
-rw-r--r-- | public/workbox-ea903bce.js | 1023 |
2 files changed, 25 insertions, 1047 deletions
diff --git a/public/sw.js b/public/sw.js index dcbb3a6..9222dc9 100644 --- a/public/sw.js +++ b/public/sw.js @@ -20,24 +20,24 @@ if (!self.define) { Promise.all(s.map(e)).then((e) => n(1 === e.length ? e[0] : e)) }, n = { require: Promise.resolve(s) } - self.define = (s, t, r) => { + self.define = (s, i, t) => { n[s] || (n[s] = Promise.resolve().then(() => { let n = {} - const a = { uri: location.origin + s.slice(1) } + const r = { uri: location.origin + s.slice(1) } return Promise.all( - t.map((s) => { + i.map((s) => { switch (s) { case 'exports': return n case 'module': - return a + return r default: return e(s) } }), ).then((e) => { - const s = r(...e) + const s = t(...e) return n.default || (n.default = s), n }) })) @@ -52,58 +52,59 @@ define('./sw.js', ['./workbox-ea903bce'], function (e) { [ { url: '/_next/static/chunks/4.2dee5d830195ddd06029.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { - url: '/_next/static/chunks/906-f789bd1954ec4d176da1.js', - revision: 'sqy183jmJB5HZRA44nlqt', + url: '/_next/static/chunks/906-7b9696c9b17c64b94384.js', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/d25bd147-65fcc4c92edba8b370fb.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/fb7d5399-0d6001c72a29ebec41eb.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/framework-2191d16384373197bc0a.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/main-1b0f1fd287f08bad6012.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { - url: '/_next/static/chunks/pages/_app-fbd69a3b63bd43d7f1b0.js', - revision: 'sqy183jmJB5HZRA44nlqt', + url: '/_next/static/chunks/pages/_app-6ba3a11e93bdf6a85175.js', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/pages/_error-a0e21b9b223f827fe1f2.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/pages/index-5cea1a6a4f484642ff08.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/polyfills-a54b4f32bdc1ef890ddd.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/_next/static/chunks/webpack-a1ea085630ce50807058.js', - revision: 'sqy183jmJB5HZRA44nlqt', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, - { url: '/_next/static/css/331301db207a91d407e5.css', revision: 'sqy183jmJB5HZRA44nlqt' }, + { url: '/_next/static/css/331301db207a91d407e5.css', revision: 'iq9sQ07m6d_SiAb-0HX08' }, { - url: '/_next/static/sqy183jmJB5HZRA44nlqt/_buildManifest.js', - revision: 'sqy183jmJB5HZRA44nlqt', + url: '/_next/static/iq9sQ07m6d_SiAb-0HX08/_buildManifest.js', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { - url: '/_next/static/sqy183jmJB5HZRA44nlqt/_ssgManifest.js', - revision: 'sqy183jmJB5HZRA44nlqt', + url: '/_next/static/iq9sQ07m6d_SiAb-0HX08/_ssgManifest.js', + revision: 'iq9sQ07m6d_SiAb-0HX08', }, { url: '/favicon.ico', revision: 'c30c7d42707a47a3f4591831641e50dc' }, + { url: '/manifest.json', revision: '6fefee72ca361eb4dfafb128818c8424' }, { url: '/vercel.svg', revision: '4b4f1876502eb6721764637fe5c41702' }, ], { ignoreURLParametersMatching: [] }, @@ -115,7 +116,7 @@ define('./sw.js', ['./workbox-ea903bce'], function (e) { cacheName: 'start-url', plugins: [ { - cacheWillUpdate: async ({ request: e, response: s, event: n, state: t }) => + cacheWillUpdate: async ({ request: e, response: s, event: n, state: i }) => s && 'opaqueredirect' === s.type ? new Response(s.body, { status: 200, statusText: 'OK', headers: s.headers }) : s, diff --git a/public/workbox-ea903bce.js b/public/workbox-ea903bce.js deleted file mode 100644 index 1d33a59..0000000 --- a/public/workbox-ea903bce.js +++ /dev/null @@ -1,1023 +0,0 @@ -define('./workbox-ea903bce.js', ['exports'], function (t) { - 'use strict' - try { - self['workbox:core:6.1.5'] && _() - } catch (t) {} - const e = (t, ...e) => { - let s = t - return e.length > 0 && (s += ` :: ${JSON.stringify(e)}`), s - } - class s extends Error { - constructor(t, s) { - super(e(t, s)), (this.name = t), (this.details = s) - } - } - try { - self['workbox:routing:6.1.5'] && _() - } catch (t) {} - const n = (t) => (t && 'object' == typeof t ? t : { handle: t }) - class i { - constructor(t, e, s = 'GET') { - ;(this.handler = n(e)), (this.match = t), (this.method = s) - } - setCatchHandler(t) { - this.catchHandler = n(t) - } - } - class r extends i { - constructor(t, e, s) { - super( - ({ url: e }) => { - const s = t.exec(e.href) - if (s && (e.origin === location.origin || 0 === s.index)) return s.slice(1) - }, - e, - s, - ) - } - } - class a { - constructor() { - ;(this.t = new Map()), (this.i = new Map()) - } - get routes() { - return this.t - } - addFetchListener() { - self.addEventListener('fetch', (t) => { - const { request: e } = t, - s = this.handleRequest({ request: e, event: t }) - s && t.respondWith(s) - }) - } - addCacheListener() { - self.addEventListener('message', (t) => { - if (t.data && 'CACHE_URLS' === t.data.type) { - const { payload: e } = t.data, - s = Promise.all( - e.urlsToCache.map((e) => { - 'string' == typeof e && (e = [e]) - const s = new Request(...e) - return this.handleRequest({ request: s, event: t }) - }), - ) - t.waitUntil(s), t.ports && t.ports[0] && s.then(() => t.ports[0].postMessage(!0)) - } - }) - } - handleRequest({ request: t, event: e }) { - const s = new URL(t.url, location.href) - if (!s.protocol.startsWith('http')) return - const n = s.origin === location.origin, - { params: i, route: r } = this.findMatchingRoute({ - event: e, - request: t, - sameOrigin: n, - url: s, - }) - let a = r && r.handler - const c = t.method - if ((!a && this.i.has(c) && (a = this.i.get(c)), !a)) return - let o - try { - o = a.handle({ url: s, request: t, event: e, params: i }) - } catch (t) { - o = Promise.reject(t) - } - const h = r && r.catchHandler - return ( - o instanceof Promise && - (this.o || h) && - (o = o.catch(async (n) => { - if (h) - try { - return await h.handle({ url: s, request: t, event: e, params: i }) - } catch (t) { - n = t - } - if (this.o) return this.o.handle({ url: s, request: t, event: e }) - throw n - })), - o - ) - } - findMatchingRoute({ url: t, sameOrigin: e, request: s, event: n }) { - const i = this.t.get(s.method) || [] - for (const r of i) { - let i - const a = r.match({ url: t, sameOrigin: e, request: s, event: n }) - if (a) - return ( - (i = a), - ((Array.isArray(a) && 0 === a.length) || - (a.constructor === Object && 0 === Object.keys(a).length) || - 'boolean' == typeof a) && - (i = void 0), - { route: r, params: i } - ) - } - return {} - } - setDefaultHandler(t, e = 'GET') { - this.i.set(e, n(t)) - } - setCatchHandler(t) { - this.o = n(t) - } - registerRoute(t) { - this.t.has(t.method) || this.t.set(t.method, []), this.t.get(t.method).push(t) - } - unregisterRoute(t) { - if (!this.t.has(t.method)) - throw new s('unregister-route-but-not-found-with-method', { method: t.method }) - const e = this.t.get(t.method).indexOf(t) - if (!(e > -1)) throw new s('unregister-route-route-not-registered') - this.t.get(t.method).splice(e, 1) - } - } - let c - const o = () => (c || ((c = new a()), c.addFetchListener(), c.addCacheListener()), c) - function h(t, e, n) { - let a - if ('string' == typeof t) { - const s = new URL(t, location.href) - a = new i(({ url: t }) => t.href === s.href, e, n) - } else if (t instanceof RegExp) a = new r(t, e, n) - else if ('function' == typeof t) a = new i(t, e, n) - else { - if (!(t instanceof i)) - throw new s('unsupported-route-type', { - moduleName: 'workbox-routing', - funcName: 'registerRoute', - paramName: 'capture', - }) - a = t - } - return o().registerRoute(a), a - } - try { - self['workbox:strategies:6.1.5'] && _() - } catch (t) {} - const u = { - cacheWillUpdate: async ({ response: t }) => (200 === t.status || 0 === t.status ? t : null), - }, - l = { - googleAnalytics: 'googleAnalytics', - precache: 'precache-v2', - prefix: 'workbox', - runtime: 'runtime', - suffix: 'undefined' != typeof registration ? registration.scope : '', - }, - f = (t) => [l.prefix, t, l.suffix].filter((t) => t && t.length > 0).join('-'), - w = (t) => t || f(l.precache), - d = (t) => t || f(l.runtime) - function p() { - return (p = - Object.assign || - function (t) { - for (var e = 1; e < arguments.length; e++) { - var s = arguments[e] - for (var n in s) Object.prototype.hasOwnProperty.call(s, n) && (t[n] = s[n]) - } - return t - }).apply(this, arguments) - } - function y(t, e) { - const s = new URL(t) - for (const t of e) s.searchParams.delete(t) - return s.href - } - class m { - constructor() { - this.promise = new Promise((t, e) => { - ;(this.resolve = t), (this.reject = e) - }) - } - } - const g = new Set() - function R(t) { - return 'string' == typeof t ? new Request(t) : t - } - class v { - constructor(t, e) { - ;(this.h = {}), - Object.assign(this, e), - (this.event = e.event), - (this.u = t), - (this.l = new m()), - (this.p = []), - (this.m = [...t.plugins]), - (this.g = new Map()) - for (const t of this.m) this.g.set(t, {}) - this.event.waitUntil(this.l.promise) - } - async fetch(t) { - const { event: e } = this - let n = R(t) - if ('navigate' === n.mode && e instanceof FetchEvent && e.preloadResponse) { - const t = await e.preloadResponse - if (t) return t - } - const i = this.hasCallback('fetchDidFail') ? n.clone() : null - try { - for (const t of this.iterateCallbacks('requestWillFetch')) - n = await t({ request: n.clone(), event: e }) - } catch (t) { - throw new s('plugin-error-request-will-fetch', { thrownError: t }) - } - const r = n.clone() - try { - let t - t = await fetch(n, 'navigate' === n.mode ? void 0 : this.u.fetchOptions) - for (const s of this.iterateCallbacks('fetchDidSucceed')) - t = await s({ event: e, request: r, response: t }) - return t - } catch (t) { - throw ( - (i && - (await this.runCallbacks('fetchDidFail', { - error: t, - event: e, - originalRequest: i.clone(), - request: r.clone(), - })), - t) - ) - } - } - async fetchAndCachePut(t) { - const e = await this.fetch(t), - s = e.clone() - return this.waitUntil(this.cachePut(t, s)), e - } - async cacheMatch(t) { - const e = R(t) - let s - const { cacheName: n, matchOptions: i } = this.u, - r = await this.getCacheKey(e, 'read'), - a = p({}, i, { cacheName: n }) - s = await caches.match(r, a) - for (const t of this.iterateCallbacks('cachedResponseWillBeUsed')) - s = - (await t({ - cacheName: n, - matchOptions: i, - cachedResponse: s, - request: r, - event: this.event, - })) || void 0 - return s - } - async cachePut(t, e) { - const n = R(t) - var i - await ((i = 0), new Promise((t) => setTimeout(t, i))) - const r = await this.getCacheKey(n, 'write') - if (!e) - throw new s('cache-put-with-no-response', { - url: - ((a = r.url), - new URL(String(a), location.href).href.replace(new RegExp(`^${location.origin}`), '')), - }) - var a - const c = await this.R(e) - if (!c) return !1 - const { cacheName: o, matchOptions: h } = this.u, - u = await self.caches.open(o), - l = this.hasCallback('cacheDidUpdate'), - f = l - ? await (async function (t, e, s, n) { - const i = y(e.url, s) - if (e.url === i) return t.match(e, n) - const r = p({}, n, { ignoreSearch: !0 }), - a = await t.keys(e, r) - for (const e of a) if (i === y(e.url, s)) return t.match(e, n) - })(u, r.clone(), ['__WB_REVISION__'], h) - : null - try { - await u.put(r, l ? c.clone() : c) - } catch (t) { - throw ( - ('QuotaExceededError' === t.name && - (await (async function () { - for (const t of g) await t() - })()), - t) - ) - } - for (const t of this.iterateCallbacks('cacheDidUpdate')) - await t({ - cacheName: o, - oldResponse: f, - newResponse: c.clone(), - request: r, - event: this.event, - }) - return !0 - } - async getCacheKey(t, e) { - if (!this.h[e]) { - let s = t - for (const t of this.iterateCallbacks('cacheKeyWillBeUsed')) - s = R(await t({ mode: e, request: s, event: this.event, params: this.params })) - this.h[e] = s - } - return this.h[e] - } - hasCallback(t) { - for (const e of this.u.plugins) if (t in e) return !0 - return !1 - } - async runCallbacks(t, e) { - for (const s of this.iterateCallbacks(t)) await s(e) - } - *iterateCallbacks(t) { - for (const e of this.u.plugins) - if ('function' == typeof e[t]) { - const s = this.g.get(e), - n = (n) => { - const i = p({}, n, { state: s }) - return e[t](i) - } - yield n - } - } - waitUntil(t) { - return this.p.push(t), t - } - async doneWaiting() { - let t - for (; (t = this.p.shift()); ) await t - } - destroy() { - this.l.resolve() - } - async R(t) { - let e = t, - s = !1 - for (const t of this.iterateCallbacks('cacheWillUpdate')) - if ( - ((e = (await t({ request: this.request, response: e, event: this.event })) || void 0), - (s = !0), - !e) - ) - break - return s || (e && 200 !== e.status && (e = void 0)), e - } - } - class q { - constructor(t = {}) { - ;(this.cacheName = d(t.cacheName)), - (this.plugins = t.plugins || []), - (this.fetchOptions = t.fetchOptions), - (this.matchOptions = t.matchOptions) - } - handle(t) { - const [e] = this.handleAll(t) - return e - } - handleAll(t) { - t instanceof FetchEvent && (t = { event: t, request: t.request }) - const e = t.event, - s = 'string' == typeof t.request ? new Request(t.request) : t.request, - n = 'params' in t ? t.params : void 0, - i = new v(this, { event: e, request: s, params: n }), - r = this.v(i, s, e) - return [r, this.q(r, i, s, e)] - } - async v(t, e, n) { - let i - await t.runCallbacks('handlerWillStart', { event: n, request: e }) - try { - if (((i = await this.U(e, t)), !i || 'error' === i.type)) - throw new s('no-response', { url: e.url }) - } catch (s) { - for (const r of t.iterateCallbacks('handlerDidError')) - if (((i = await r({ error: s, event: n, request: e })), i)) break - if (!i) throw s - } - for (const s of t.iterateCallbacks('handlerWillRespond')) - i = await s({ event: n, request: e, response: i }) - return i - } - async q(t, e, s, n) { - let i, r - try { - i = await t - } catch (r) {} - try { - await e.runCallbacks('handlerDidRespond', { event: n, request: s, response: i }), - await e.doneWaiting() - } catch (t) { - r = t - } - if ( - (await e.runCallbacks('handlerDidComplete', { - event: n, - request: s, - response: i, - error: r, - }), - e.destroy(), - r) - ) - throw r - } - } - function U(t) { - t.then(() => {}) - } - class x { - constructor(t, e, { onupgradeneeded: s, onversionchange: n } = {}) { - ;(this._ = null), - (this.L = t), - (this.N = e), - (this.C = s), - (this.D = n || (() => this.close())) - } - get db() { - return this._ - } - async open() { - if (!this._) - return ( - (this._ = await new Promise((t, e) => { - let s = !1 - setTimeout(() => { - ;(s = !0), e(new Error('The open request was blocked and timed out')) - }, this.OPEN_TIMEOUT) - const n = indexedDB.open(this.L, this.N) - ;(n.onerror = () => e(n.error)), - (n.onupgradeneeded = (t) => { - s - ? (n.transaction.abort(), n.result.close()) - : 'function' == typeof this.C && this.C(t) - }), - (n.onsuccess = () => { - const e = n.result - s ? e.close() : ((e.onversionchange = this.D.bind(this)), t(e)) - }) - })), - this - ) - } - async getKey(t, e) { - return (await this.getAllKeys(t, e, 1))[0] - } - async getAll(t, e, s) { - return await this.getAllMatching(t, { query: e, count: s }) - } - async getAllKeys(t, e, s) { - return (await this.getAllMatching(t, { query: e, count: s, includeKeys: !0 })).map( - (t) => t.key, - ) - } - async getAllMatching( - t, - { index: e, query: s = null, direction: n = 'next', count: i, includeKeys: r = !1 } = {}, - ) { - return await this.transaction([t], 'readonly', (a, c) => { - const o = a.objectStore(t), - h = e ? o.index(e) : o, - u = [], - l = h.openCursor(s, n) - l.onsuccess = () => { - const t = l.result - t ? (u.push(r ? t : t.value), i && u.length >= i ? c(u) : t.continue()) : c(u) - } - }) - } - async transaction(t, e, s) { - return ( - await this.open(), - await new Promise((n, i) => { - const r = this._.transaction(t, e) - ;(r.onabort = () => i(r.error)), (r.oncomplete = () => n()), s(r, (t) => n(t)) - }) - ) - } - async T(t, e, s, ...n) { - return await this.transaction([e], s, (s, i) => { - const r = s.objectStore(e), - a = r[t].apply(r, n) - a.onsuccess = () => i(a.result) - }) - } - close() { - this._ && (this._.close(), (this._ = null)) - } - } - x.prototype.OPEN_TIMEOUT = 2e3 - const b = { - readonly: ['get', 'count', 'getKey', 'getAll', 'getAllKeys'], - readwrite: ['add', 'put', 'clear', 'delete'], - } - for (const [t, e] of Object.entries(b)) - for (const s of e) - s in IDBObjectStore.prototype && - (x.prototype[s] = async function (e, ...n) { - return await this.T(s, e, t, ...n) - }) - try { - self['workbox:expiration:6.1.5'] && _() - } catch (t) {} - const L = 'cache-entries', - N = (t) => { - const e = new URL(t, location.href) - return (e.hash = ''), e.href - } - class C { - constructor(t) { - ;(this.P = t), - (this._ = new x('workbox-expiration', 1, { onupgradeneeded: (t) => this.k(t) })) - } - k(t) { - const e = t.target.result.createObjectStore(L, { keyPath: 'id' }) - e.createIndex('cacheName', 'cacheName', { unique: !1 }), - e.createIndex('timestamp', 'timestamp', { unique: !1 }), - (async (t) => { - await new Promise((e, s) => { - const n = indexedDB.deleteDatabase(t) - ;(n.onerror = () => { - s(n.error) - }), - (n.onblocked = () => { - s(new Error('Delete blocked')) - }), - (n.onsuccess = () => { - e() - }) - }) - })(this.P) - } - async setTimestamp(t, e) { - const s = { url: (t = N(t)), timestamp: e, cacheName: this.P, id: this.K(t) } - await this._.put(L, s) - } - async getTimestamp(t) { - return (await this._.get(L, this.K(t))).timestamp - } - async expireEntries(t, e) { - const s = await this._.transaction(L, 'readwrite', (s, n) => { - const i = s.objectStore(L).index('timestamp').openCursor(null, 'prev'), - r = [] - let a = 0 - i.onsuccess = () => { - const s = i.result - if (s) { - const n = s.value - n.cacheName === this.P && - ((t && n.timestamp < t) || (e && a >= e) ? r.push(s.value) : a++), - s.continue() - } else n(r) - } - }), - n = [] - for (const t of s) await this._.delete(L, t.id), n.push(t.url) - return n - } - K(t) { - return this.P + '|' + N(t) - } - } - class E { - constructor(t, e = {}) { - ;(this.O = !1), - (this.W = !1), - (this.M = e.maxEntries), - (this.A = e.maxAgeSeconds), - (this.S = e.matchOptions), - (this.P = t), - (this.I = new C(t)) - } - async expireEntries() { - if (this.O) return void (this.W = !0) - this.O = !0 - const t = this.A ? Date.now() - 1e3 * this.A : 0, - e = await this.I.expireEntries(t, this.M), - s = await self.caches.open(this.P) - for (const t of e) await s.delete(t, this.S) - ;(this.O = !1), this.W && ((this.W = !1), U(this.expireEntries())) - } - async updateTimestamp(t) { - await this.I.setTimestamp(t, Date.now()) - } - async isURLExpired(t) { - if (this.A) { - return (await this.I.getTimestamp(t)) < Date.now() - 1e3 * this.A - } - return !1 - } - async delete() { - ;(this.W = !1), await this.I.expireEntries(1 / 0) - } - } - function D(t, e) { - const s = e() - return t.waitUntil(s), s - } - try { - self['workbox:precaching:6.1.5'] && _() - } catch (t) {} - function T(t) { - if (!t) throw new s('add-to-cache-list-unexpected-type', { entry: t }) - if ('string' == typeof t) { - const e = new URL(t, location.href) - return { cacheKey: e.href, url: e.href } - } - const { revision: e, url: n } = t - if (!n) throw new s('add-to-cache-list-unexpected-type', { entry: t }) - if (!e) { - const t = new URL(n, location.href) - return { cacheKey: t.href, url: t.href } - } - const i = new URL(n, location.href), - r = new URL(n, location.href) - return i.searchParams.set('__WB_REVISION__', e), { cacheKey: i.href, url: r.href } - } - class P { - constructor() { - ;(this.updatedURLs = []), - (this.notUpdatedURLs = []), - (this.handlerWillStart = async ({ request: t, state: e }) => { - e && (e.originalRequest = t) - }), - (this.cachedResponseWillBeUsed = async ({ event: t, state: e, cachedResponse: s }) => { - if ('install' === t.type) { - const t = e.originalRequest.url - s ? this.notUpdatedURLs.push(t) : this.updatedURLs.push(t) - } - return s - }) - } - } - class k { - constructor({ precacheController: t }) { - ;(this.cacheKeyWillBeUsed = async ({ request: t, params: e }) => { - const s = (e && e.cacheKey) || this.j.getCacheKeyForURL(t.url) - return s ? new Request(s) : t - }), - (this.j = t) - } - } - let K, O - async function W(t, e) { - let n = null - if (t.url) { - n = new URL(t.url).origin - } - if (n !== self.location.origin) throw new s('cross-origin-copy-response', { origin: n }) - const i = t.clone(), - r = { headers: new Headers(i.headers), status: i.status, statusText: i.statusText }, - a = e ? e(r) : r, - c = (function () { - if (void 0 === K) { - const t = new Response('') - if ('body' in t) - try { - new Response(t.body), (K = !0) - } catch (t) { - K = !1 - } - K = !1 - } - return K - })() - ? i.body - : await i.blob() - return new Response(c, a) - } - class M extends q { - constructor(t = {}) { - ;(t.cacheName = w(t.cacheName)), - super(t), - (this.F = !1 !== t.fallbackToNetwork), - this.plugins.push(M.copyRedirectedCacheableResponsesPlugin) - } - async U(t, e) { - const s = await e.cacheMatch(t) - return s || (e.event && 'install' === e.event.type ? await this.B(t, e) : await this.H(t, e)) - } - async H(t, e) { - let n - if (!this.F) throw new s('missing-precache-entry', { cacheName: this.cacheName, url: t.url }) - return (n = await e.fetch(t)), n - } - async B(t, e) { - this.$() - const n = await e.fetch(t) - if (!(await e.cachePut(t, n.clone()))) - throw new s('bad-precaching-response', { url: t.url, status: n.status }) - return n - } - $() { - let t = null, - e = 0 - for (const [s, n] of this.plugins.entries()) - n !== M.copyRedirectedCacheableResponsesPlugin && - (n === M.defaultPrecacheCacheabilityPlugin && (t = s), n.cacheWillUpdate && e++) - 0 === e - ? this.plugins.push(M.defaultPrecacheCacheabilityPlugin) - : e > 1 && null !== t && this.plugins.splice(t, 1) - } - } - ;(M.defaultPrecacheCacheabilityPlugin = { - cacheWillUpdate: async ({ response: t }) => (!t || t.status >= 400 ? null : t), - }), - (M.copyRedirectedCacheableResponsesPlugin = { - cacheWillUpdate: async ({ response: t }) => (t.redirected ? await W(t) : t), - }) - class A { - constructor({ cacheName: t, plugins: e = [], fallbackToNetwork: s = !0 } = {}) { - ;(this.G = new Map()), - (this.V = new Map()), - (this.J = new Map()), - (this.u = new M({ - cacheName: w(t), - plugins: [...e, new k({ precacheController: this })], - fallbackToNetwork: s, - })), - (this.install = this.install.bind(this)), - (this.activate = this.activate.bind(this)) - } - get strategy() { - return this.u - } - precache(t) { - this.addToCacheList(t), - this.X || - (self.addEventListener('install', this.install), - self.addEventListener('activate', this.activate), - (this.X = !0)) - } - addToCacheList(t) { - const e = [] - for (const n of t) { - 'string' == typeof n ? e.push(n) : n && void 0 === n.revision && e.push(n.url) - const { cacheKey: t, url: i } = T(n), - r = 'string' != typeof n && n.revision ? 'reload' : 'default' - if (this.G.has(i) && this.G.get(i) !== t) - throw new s('add-to-cache-list-conflicting-entries', { - firstEntry: this.G.get(i), - secondEntry: t, - }) - if ('string' != typeof n && n.integrity) { - if (this.J.has(t) && this.J.get(t) !== n.integrity) - throw new s('add-to-cache-list-conflicting-integrities', { url: i }) - this.J.set(t, n.integrity) - } - if ((this.G.set(i, t), this.V.set(i, r), e.length > 0)) { - const t = `Workbox is precaching URLs without revision info: ${e.join( - ', ', - )}\nThis is generally NOT safe. Learn more at https://bit.ly/wb-precache` - console.warn(t) - } - } - } - install(t) { - return D(t, async () => { - const e = new P() - this.strategy.plugins.push(e) - for (const [e, s] of this.G) { - const n = this.J.get(s), - i = this.V.get(e), - r = new Request(e, { integrity: n, cache: i, credentials: 'same-origin' }) - await Promise.all( - this.strategy.handleAll({ params: { cacheKey: s }, request: r, event: t }), - ) - } - const { updatedURLs: s, notUpdatedURLs: n } = e - return { updatedURLs: s, notUpdatedURLs: n } - }) - } - activate(t) { - return D(t, async () => { - const t = await self.caches.open(this.strategy.cacheName), - e = await t.keys(), - s = new Set(this.G.values()), - n = [] - for (const i of e) s.has(i.url) || (await t.delete(i), n.push(i.url)) - return { deletedURLs: n } - }) - } - getURLsToCacheKeys() { - return this.G - } - getCachedURLs() { - return [...this.G.keys()] - } - getCacheKeyForURL(t) { - const e = new URL(t, location.href) - return this.G.get(e.href) - } - async matchPrecache(t) { - const e = t instanceof Request ? t.url : t, - s = this.getCacheKeyForURL(e) - if (s) { - return (await self.caches.open(this.strategy.cacheName)).match(s) - } - } - createHandlerBoundToURL(t) { - const e = this.getCacheKeyForURL(t) - if (!e) throw new s('non-precached-url', { url: t }) - return (s) => ( - (s.request = new Request(t)), - (s.params = p({ cacheKey: e }, s.params)), - this.strategy.handle(s) - ) - } - } - const S = () => (O || (O = new A()), O) - class I extends i { - constructor(t, e) { - super(({ request: s }) => { - const n = t.getURLsToCacheKeys() - for (const t of (function* ( - t, - { - ignoreURLParametersMatching: e = [/^utm_/, /^fbclid$/], - directoryIndex: s = 'index.html', - cleanURLs: n = !0, - urlManipulation: i, - } = {}, - ) { - const r = new URL(t, location.href) - ;(r.hash = ''), yield r.href - const a = (function (t, e = []) { - for (const s of [...t.searchParams.keys()]) - e.some((t) => t.test(s)) && t.searchParams.delete(s) - return t - })(r, e) - if ((yield a.href, s && a.pathname.endsWith('/'))) { - const t = new URL(a.href) - ;(t.pathname += s), yield t.href - } - if (n) { - const t = new URL(a.href) - ;(t.pathname += '.html'), yield t.href - } - if (i) { - const t = i({ url: r }) - for (const e of t) yield e.href - } - })(s.url, e)) { - const e = n.get(t) - if (e) return { cacheKey: e } - } - }, t.strategy) - } - } - ;(t.CacheFirst = class extends q { - async U(t, e) { - let n, - i = await e.cacheMatch(t) - if (!i) - try { - i = await e.fetchAndCachePut(t) - } catch (t) { - n = t - } - if (!i) throw new s('no-response', { url: t.url, error: n }) - return i - } - }), - (t.ExpirationPlugin = class { - constructor(t = {}) { - var e - ;(this.cachedResponseWillBeUsed = async ({ - event: t, - request: e, - cacheName: s, - cachedResponse: n, - }) => { - if (!n) return null - const i = this.Y(n), - r = this.Z(s) - U(r.expireEntries()) - const a = r.updateTimestamp(e.url) - if (t) - try { - t.waitUntil(a) - } catch (t) {} - return i ? n : null - }), - (this.cacheDidUpdate = async ({ cacheName: t, request: e }) => { - const s = this.Z(t) - await s.updateTimestamp(e.url), await s.expireEntries() - }), - (this.tt = t), - (this.A = t.maxAgeSeconds), - (this.et = new Map()), - t.purgeOnQuotaError && ((e = () => this.deleteCacheAndMetadata()), g.add(e)) - } - Z(t) { - if (t === d()) throw new s('expire-custom-caches-only') - let e = this.et.get(t) - return e || ((e = new E(t, this.tt)), this.et.set(t, e)), e - } - Y(t) { - if (!this.A) return !0 - const e = this.st(t) - if (null === e) return !0 - return e >= Date.now() - 1e3 * this.A - } - st(t) { - if (!t.headers.has('date')) return null - const e = t.headers.get('date'), - s = new Date(e).getTime() - return isNaN(s) ? null : s - } - async deleteCacheAndMetadata() { - for (const [t, e] of this.et) await self.caches.delete(t), await e.delete() - this.et = new Map() - } - }), - (t.NetworkFirst = class extends q { - constructor(t = {}) { - super(t), - this.plugins.some((t) => 'cacheWillUpdate' in t) || this.plugins.unshift(u), - (this.nt = t.networkTimeoutSeconds || 0) - } - async U(t, e) { - const n = [], - i = [] - let r - if (this.nt) { - const { id: s, promise: a } = this.it({ request: t, logs: n, handler: e }) - ;(r = s), i.push(a) - } - const a = this.rt({ timeoutId: r, request: t, logs: n, handler: e }) - i.push(a) - const c = await e.waitUntil( - (async () => (await e.waitUntil(Promise.race(i))) || (await a))(), - ) - if (!c) throw new s('no-response', { url: t.url }) - return c - } - it({ request: t, logs: e, handler: s }) { - let n - return { - promise: new Promise((e) => { - n = setTimeout(async () => { - e(await s.cacheMatch(t)) - }, 1e3 * this.nt) - }), - id: n, - } - } - async rt({ timeoutId: t, request: e, logs: s, handler: n }) { - let i, r - try { - r = await n.fetchAndCachePut(e) - } catch (t) { - i = t - } - return t && clearTimeout(t), (!i && r) || (r = await n.cacheMatch(e)), r - } - }), - (t.StaleWhileRevalidate = class extends q { - constructor(t) { - super(t), this.plugins.some((t) => 'cacheWillUpdate' in t) || this.plugins.unshift(u) - } - async U(t, e) { - const n = e.fetchAndCachePut(t).catch(() => {}) - let i, - r = await e.cacheMatch(t) - if (r); - else - try { - r = await n - } catch (t) { - i = t - } - if (!r) throw new s('no-response', { url: t.url, error: i }) - return r - } - }), - (t.cleanupOutdatedCaches = function () { - self.addEventListener('activate', (t) => { - const e = w() - t.waitUntil( - (async (t, e = '-precache-') => { - const s = (await self.caches.keys()).filter( - (s) => s.includes(e) && s.includes(self.registration.scope) && s !== t, - ) - return await Promise.all(s.map((t) => self.caches.delete(t))), s - })(e).then((t) => {}), - ) - }) - }), - (t.clientsClaim = function () { - self.addEventListener('activate', () => self.clients.claim()) - }), - (t.precacheAndRoute = function (t, e) { - !(function (t) { - S().precache(t) - })(t), - (function (t) { - const e = S() - h(new I(e, t)) - })(e) - }), - (t.registerRoute = h) -}) |