From d211b86e193dd43f1569410d3dbea2d09b4b7c5e Mon Sep 17 00:00:00 2001 From: Guz <43732358+Guz013@users.noreply.github.com> Date: Fri, 8 Apr 2022 20:27:29 -0300 Subject: [PATCH] interface base --- .vscode/settings.json | 7 + package.json | 4 + pnpm-lock.yaml | 169 ++ public/noflash.js | 42 + public/sw.js | 115 +- public/sw.js.map | 1 + public/workbox-3d9e5b44.js | 1 - public/workbox-56d5d59b.js | 2744 +++++++++++++++++++++++ public/workbox-56d5d59b.js.map | 1 + src/components/button/socialButtons.jsx | 23 + src/components/button/themeButton.jsx | 44 + src/components/footer.jsx | 11 + src/components/sideBar.jsx | 127 ++ src/libs/hooks/useWinSize.ts | 22 + src/pages/_app.tsx | 13 +- src/pages/_document.tsx | 19 + src/pages/index.tsx | 77 +- src/styles/globals.css | 14 + tailwind.config.js | 1 + tsconfig.json | 3 +- 20 files changed, 3356 insertions(+), 82 deletions(-) create mode 100644 .vscode/settings.json create mode 100644 public/noflash.js create mode 100644 public/sw.js.map delete mode 100644 public/workbox-3d9e5b44.js create mode 100644 public/workbox-56d5d59b.js create mode 100644 public/workbox-56d5d59b.js.map create mode 100644 src/components/button/socialButtons.jsx create mode 100644 src/components/button/themeButton.jsx create mode 100644 src/components/footer.jsx create mode 100644 src/components/sideBar.jsx create mode 100644 src/libs/hooks/useWinSize.ts create mode 100644 src/pages/_document.tsx diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..a404d48 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,7 @@ +{ + "cSpell.words": [ + "heroicons", + "Swipeable" + ], + "typescript.tsdk": "node_modules\\typescript\\lib" +} diff --git a/package.json b/package.json index c456e73..f8d9e09 100644 --- a/package.json +++ b/package.json @@ -20,9 +20,11 @@ }, "devDependencies": { "@babel/core": ">=7.0.0 <8.0.0", + "@heroicons/react": "^1.0.6", "@prefresh/babel-plugin": "^0.4.0", "@types/node": "17.0.4", "@types/react": "17.0.38", + "@use-gesture/react": "^10.2.11", "autoprefixer": "^10.4.4", "cssnano": "^5.1.7", "eslint": "^8.12.0", @@ -32,6 +34,8 @@ "postcss-import": "^14.1.0", "prettier": "^2.6.1", "prettier-plugin-tailwindcss": "^0.1.8", + "react-spring": "^9.4.4", + "react-swipeable": "^6.2.1", "tailwindcss": "^3.0.23", "typescript": "4.5.4", "webpack": ">=5.9.0 <6.0.0" diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index bb45056..181dba3 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -2,9 +2,11 @@ lockfileVersion: 5.3 specifiers: '@babel/core': '>=7.0.0 <8.0.0' + '@heroicons/react': ^1.0.6 '@prefresh/babel-plugin': ^0.4.0 '@types/node': 17.0.4 '@types/react': 17.0.38 + '@use-gesture/react': ^10.2.11 autoprefixer: ^10.4.4 cssnano: ^5.1.7 eslint: ^8.12.0 @@ -18,7 +20,9 @@ specifiers: prettier-plugin-tailwindcss: ^0.1.8 react: ^18.0.0 react-dom: ^18.0.0 + react-spring: ^9.4.4 react-ssr-prepass: ^1.5.0 + react-swipeable: ^6.2.1 tailwindcss: ^3.0.23 typescript: 4.5.4 use-dark-mode: ^2.3.1 @@ -34,9 +38,11 @@ dependencies: devDependencies: '@babel/core': 7.17.8 + '@heroicons/react': 1.0.6_react@18.0.0 '@prefresh/babel-plugin': 0.4.3 '@types/node': 17.0.4 '@types/react': 17.0.38 + '@use-gesture/react': 10.2.11_react@18.0.0 autoprefixer: 10.4.4_postcss@8.4.12 cssnano: 5.1.7_postcss@8.4.12 eslint: 8.12.0 @@ -46,6 +52,8 @@ devDependencies: postcss-import: 14.1.0_postcss@8.4.12 prettier: 2.6.1 prettier-plugin-tailwindcss: 0.1.8_prettier@2.6.1 + react-spring: 9.4.4_react-dom@18.0.0+react@18.0.0 + react-swipeable: 6.2.1_react@18.0.0 tailwindcss: 3.0.23_autoprefixer@10.4.4 typescript: 4.5.4 webpack: 5.71.0 @@ -1198,6 +1206,14 @@ packages: - supports-color dev: true + /@heroicons/react/1.0.6_react@18.0.0: + resolution: {integrity: sha512-JJCXydOFWMDpCP4q13iEplA503MQO3xLoZiKum+955ZCtHINWnx26CUxVxxFQu/uLb4LW3ge15ZpzIkXKkJ8oQ==} + peerDependencies: + react: '>= 16' + dependencies: + react: 18.0.0 + dev: true + /@humanwhocodes/config-array/0.9.5: resolution: {integrity: sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==} engines: {node: '>=10.10.0'} @@ -1366,6 +1382,117 @@ packages: resolution: {integrity: sha512-fYAWbU1WDSLn108kKY4eDaaeUcnszFqXjgaGKYXNZ5NLulpRTpsrY+Sbfo9q8LDpWrBpqIgzjrwNnvglWI1xNQ==} dev: true + /@react-spring/animated/9.4.4_react@18.0.0: + resolution: {integrity: sha512-e9xnuBaUTD+NolKikUmrGWjX8AVCPyj1GcEgjgq9E+0sXKv46UY7cm2EmB6mUDTxWIDVKebARY++xT4nGDraBQ==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 + dependencies: + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + dev: true + + /@react-spring/core/9.4.4_react@18.0.0: + resolution: {integrity: sha512-llgb0ljFyjMB0JhWsaFHOi9XFT8n1jBMVs1IFY2ipIBerWIRWrgUmIpakLPHTa4c4jwqTaDSwX90s2a0iN7dxQ==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 + dependencies: + '@react-spring/animated': 9.4.4_react@18.0.0 + '@react-spring/rafz': 9.4.4 + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + dev: true + + /@react-spring/konva/9.4.4_react@18.0.0: + resolution: {integrity: sha512-ZHwsf4l/W5YzK8TwlvGXL9SYiHxxC6iEOAKStRs8WV6VuBvTFgIoGK5RNOTbsRC2N/spNWnN6JViz1PNbgrB+A==} + peerDependencies: + konva: '>=2.6' + react: ^16.8.0 || ^17.0.0 + react-konva: ^16.8.0 || ^17.0.0 + dependencies: + '@react-spring/animated': 9.4.4_react@18.0.0 + '@react-spring/core': 9.4.4_react@18.0.0 + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + dev: true + + /@react-spring/native/9.4.4_react@18.0.0: + resolution: {integrity: sha512-p0/JI59JVkgVjnoLvu+cpEgEkE0B3RDvzT1oNaCAx0ePaGQo4ICAS8PyOgPvN5IHUOy59CBLSMNnFyHV+IgaGQ==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 + react-native: '>=0.58' + dependencies: + '@react-spring/animated': 9.4.4_react@18.0.0 + '@react-spring/core': 9.4.4_react@18.0.0 + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + dev: true + + /@react-spring/rafz/9.4.4: + resolution: {integrity: sha512-5ki/sQ06Mdf8AuFstSt5zbNNicRT4LZogiJttDAww1ozhuvemafNWEHxhzcULgCPCDu2s7HsroaISV7+GQWrhw==} + dev: true + + /@react-spring/shared/9.4.4_react@18.0.0: + resolution: {integrity: sha512-ySVgScDZlhm/+Iy2smY9i/DDrShArY0j6zjTS/Re1lasKnhq8qigoGiAxe8xMPJNlCaj3uczCqHy3TY9bKRtfQ==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 + dependencies: + '@react-spring/rafz': 9.4.4 + '@react-spring/types': 9.4.4 + react: 18.0.0 + dev: true + + /@react-spring/three/9.4.4_react@18.0.0: + resolution: {integrity: sha512-z77ohxg8zG0CcZJojzfoJTTrjSbIyefNz2RlId68/4IypnOs1p8kB2Q1p+wX4KyWORpLg8ivsPcjtwBjGwfDtg==} + peerDependencies: + '@react-three/fiber': '>=6.0' + react: '>=16.11' + three: '>=0.126' + dependencies: + '@react-spring/animated': 9.4.4_react@18.0.0 + '@react-spring/core': 9.4.4_react@18.0.0 + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + dev: true + + /@react-spring/types/9.4.4: + resolution: {integrity: sha512-KpxKt/D//q/t/6FBcde/RE36LKp8PpWu7kFEMLwpzMGl9RpcexunmYOQJWwmJWtkQjgE1YRr7DzBMryz6La1cQ==} + dev: true + + /@react-spring/web/9.4.4_react-dom@18.0.0+react@18.0.0: + resolution: {integrity: sha512-iJmOLdhcuizriUlu/xqBc5y8KaFts+UI+iC+GxyTwBtzxA9czKiSAZW2ESuhG8stafa3jncwjfTQQp84KN36cw==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 + react-dom: ^16.8.0 || ^17.0.0 + dependencies: + '@react-spring/animated': 9.4.4_react@18.0.0 + '@react-spring/core': 9.4.4_react@18.0.0 + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + react-dom: 18.0.0_react@18.0.0 + dev: true + + /@react-spring/zdog/9.4.4_react-dom@18.0.0+react@18.0.0: + resolution: {integrity: sha512-qmD8zRcodbQKTAFVMdgW2pYIZP1KttDnz2S2JEc7kx8I8F5ljn9czgRl5c4w9HJ0dpO8VTfPq4sKa4tlUL23yg==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 + react-dom: ^16.8.0 || ^17.0.0 + react-zdog: '>=1.0' + zdog: '>=1.0' + dependencies: + '@react-spring/animated': 9.4.4_react@18.0.0 + '@react-spring/core': 9.4.4_react@18.0.0 + '@react-spring/shared': 9.4.4_react@18.0.0 + '@react-spring/types': 9.4.4 + react: 18.0.0 + react-dom: 18.0.0_react@18.0.0 + dev: true + /@rollup/plugin-babel/5.3.1_@babel+core@7.17.8+rollup@2.70.1: resolution: {integrity: sha512-WFfdLWU/xVWKeRQnKmIAQULUI7Il0gZnBIH/ZFO069wYIfPu+8zrfp/KMW0atmELoRDq8FbiP3VCss9MhCut7Q==} engines: {node: '>= 10.0.0'} @@ -1573,6 +1700,19 @@ packages: eslint-visitor-keys: 3.3.0 dev: true + /@use-gesture/core/10.2.11: + resolution: {integrity: sha512-5YeVrT9prf9UeaAO+2fIuiKdZ01uVBvVsjG79berGZPTHVkz01eFX2ODWJG05uQTqmRw6olz1J80yt6qcGPdvA==} + dev: true + + /@use-gesture/react/10.2.11_react@18.0.0: + resolution: {integrity: sha512-yATjHv6ZNe9Jar1YtJvcb6KxwpcGGW/X8FEUY6xo2mDxHkP7dCsnhZZm7I+giGlrJKBMvpVBARsbUhwQP6v6nA==} + peerDependencies: + react: '>= 16.8.0' + dependencies: + '@use-gesture/core': 10.2.11 + react: 18.0.0 + dev: true + /@use-it/event-listener/0.1.7_react@18.0.0: resolution: {integrity: sha512-hgfExDzUU9uTRTPDCpw2s9jWTxcxmpJya3fK5ADpf5VDpSy8WYwY/kh28XE0tUcbsljeP8wfan48QvAQTSSa3Q==} peerDependencies: @@ -4129,6 +4269,27 @@ packages: resolution: {integrity: sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==} dev: true + /react-spring/9.4.4_react-dom@18.0.0+react@18.0.0: + resolution: {integrity: sha512-VOqilh9DJBsS6Pf550YLhdReS3j9a2AQVh7NcsNtWoxTYIeuErWi6ym0++6bBhQp4yT5xvVvUDaJ8ez8vrFgaw==} + dependencies: + '@react-spring/core': 9.4.4_react@18.0.0 + '@react-spring/konva': 9.4.4_react@18.0.0 + '@react-spring/native': 9.4.4_react@18.0.0 + '@react-spring/three': 9.4.4_react@18.0.0 + '@react-spring/web': 9.4.4_react-dom@18.0.0+react@18.0.0 + '@react-spring/zdog': 9.4.4_react-dom@18.0.0+react@18.0.0 + transitivePeerDependencies: + - '@react-three/fiber' + - konva + - react + - react-dom + - react-konva + - react-native + - react-zdog + - three + - zdog + dev: true + /react-ssr-prepass/1.5.0_react@18.0.0: resolution: {integrity: sha512-yFNHrlVEReVYKsLI5lF05tZoHveA5pGzjFbFJY/3pOqqjGOmMmqx83N4hIjN2n6E1AOa+eQEUxs3CgRnPmT0RQ==} peerDependencies: @@ -4137,6 +4298,14 @@ packages: react: 18.0.0 dev: false + /react-swipeable/6.2.1_react@18.0.0: + resolution: {integrity: sha512-JpTj+tjJTDcIWtoMkab6zfwWD1T1tBzUyEfXsXnohnNkwA2dTuNS0gtN7HoxU1Qa+e3GDnfNYk2z7vwzfO4SoQ==} + peerDependencies: + react: ^16.8.3 || ^17 + dependencies: + react: 18.0.0 + dev: true + /react/18.0.0: resolution: {integrity: sha512-x+VL6wbT4JRVPm7EGxXhZ8w8LTROaxPXOqhlGyVSrv0sB1jkyFGgXxJ8LVoPRLvPR6/CIZGFmfzqUa2NYeMr2A==} engines: {node: '>=0.10.0'} diff --git a/public/noflash.js b/public/noflash.js new file mode 100644 index 0000000..6c61fc5 --- /dev/null +++ b/public/noflash.js @@ -0,0 +1,42 @@ +// Insert this script in your index.html right after the tag. +// This will help to prevent a flash if dark mode is the default. + +// MIT License https://github.com/donavon/use-dark-mode + +(function() { + // Change these if you use something different in your hook. + var storageKey = 'darkMode'; + var classNameDark = 'dark-mode'; + var classNameLight = 'light-mode'; + + function setClassOnDocumentBody(darkMode) { + document.body.classList.add(darkMode ? classNameDark : classNameLight); + document.body.classList.remove(darkMode ? classNameLight : classNameDark); + } + + var preferDarkQuery = '(prefers-color-scheme: dark)'; + var mql = window.matchMedia(preferDarkQuery); + var supportsColorSchemeQuery = mql.media === preferDarkQuery; + var localStorageTheme = null; + try { + localStorageTheme = localStorage.getItem(storageKey); + } catch (err) {} + var localStorageExists = localStorageTheme !== null; + if (localStorageExists) { + localStorageTheme = JSON.parse(localStorageTheme); + } + + // Determine the source of truth + if (localStorageExists) { + // source of truth from localStorage + setClassOnDocumentBody(localStorageTheme); + } else if (supportsColorSchemeQuery) { + // source of truth from system + setClassOnDocumentBody(mql.matches); + localStorage.setItem(storageKey, mql.matches); + } else { + // source of truth from document.body + var isDarkMode = document.body.classList.contains(classNameDark); + localStorage.setItem(storageKey, JSON.stringify(isDarkMode)); + } + })(); diff --git a/public/sw.js b/public/sw.js index 2ef1277..608ba72 100644 --- a/public/sw.js +++ b/public/sw.js @@ -1 +1,114 @@ -if(!self.define){let e,s={};const n=(n,i)=>(n=new URL(n+".js",i).href,s[n]||new Promise((s=>{if("document"in self){const e=document.createElement("script");e.src=n,e.onload=s,document.head.appendChild(e)}else e=n,importScripts(n),s()})).then((()=>{let e=s[n];if(!e)throw new Error(`Module ${n} didn’t register its module`);return e})));self.define=(i,c)=>{const a=e||("document"in self?document.currentScript.src:"")||location.href;if(s[a])return;let t={};const o=e=>n(e,a),r={module:{uri:a},exports:t,require:o};s[a]=Promise.all(i.map((e=>r[e]||o(e)))).then((e=>(c(...e),t)))}}define(["./workbox-3d9e5b44"],(function(e){"use strict";importScripts(),self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"/_next/static/8Q6u4p3FOCcNqlkS0kKs6/_buildManifest.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/8Q6u4p3FOCcNqlkS0kKs6/_middlewareManifest.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/8Q6u4p3FOCcNqlkS0kKs6/_ssgManifest.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/framework-36c0234b5f4f6ad8.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/main-f4af3b467d02bcfd.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/pages/_app-87f6647db439f789.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/pages/_error-ea155eb97f8b1272.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/pages/index-2c4829aff0693e8a.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/polyfills-5cd94c89d3acac5f.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/chunks/webpack-69bfa6990bb9e155.js",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/_next/static/css/c13da96edaa829bc.css",revision:"8Q6u4p3FOCcNqlkS0kKs6"},{url:"/favicon.ico",revision:"4ff59fef4ad8bd2547e3db47bac48f20"},{url:"/icons/icon-128x128.png",revision:"d626cfe7c65e6e5403bcbb9d13aa5053"},{url:"/icons/icon-144x144.png",revision:"e53a506b62999dc7a4f8b7222f8c5add"},{url:"/icons/icon-152x152.png",revision:"18b3958440703a9ecd3c246a0f3f7c72"},{url:"/icons/icon-16x16.png",revision:"83703514f19796ee15151e450984416d"},{url:"/icons/icon-192x192.png",revision:"27dc12f66697a47b6a8b3ee25ba96257"},{url:"/icons/icon-32x32.png",revision:"25e2c6ee34840568012b32e4314278df"},{url:"/icons/icon-384x384.png",revision:"a40324a3fde2b0b26eeffd4f08bf8be8"},{url:"/icons/icon-512x512.png",revision:"93d6e8e15cfa78dfee55446f607d9a28"},{url:"/icons/icon-72x72.png",revision:"f2ffc41b3482888f3ae614e0dd2f6980"},{url:"/icons/icon-96x96.png",revision:"fba02a40f7ba6fc65be8a2f245480f6d"},{url:"/manifest.json",revision:"6985d83ff7945b11369e7b33e73f948f"},{url:"/vercel.svg",revision:"4b4f1876502eb6721764637fe5c41702"}],{ignoreURLParametersMatching:[]}),e.cleanupOutdatedCaches(),e.registerRoute("/",new e.NetworkFirst({cacheName:"start-url",plugins:[{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}]}),"GET"),e.registerRoute(/^https:\/\/fonts\.(?:gstatic)\.com\/.*/i,new e.CacheFirst({cacheName:"google-fonts-webfonts",plugins:[new e.ExpirationPlugin({maxEntries:4,maxAgeSeconds:31536e3})]}),"GET"),e.registerRoute(/^https:\/\/fonts\.(?:googleapis)\.com\/.*/i,new e.StaleWhileRevalidate({cacheName:"google-fonts-stylesheets",plugins:[new e.ExpirationPlugin({maxEntries:4,maxAgeSeconds:604800})]}),"GET"),e.registerRoute(/\.(?:eot|otf|ttc|ttf|woff|woff2|font.css)$/i,new e.StaleWhileRevalidate({cacheName:"static-font-assets",plugins:[new e.ExpirationPlugin({maxEntries:4,maxAgeSeconds:604800})]}),"GET"),e.registerRoute(/\.(?:jpg|jpeg|gif|png|svg|ico|webp)$/i,new e.StaleWhileRevalidate({cacheName:"static-image-assets",plugins:[new e.ExpirationPlugin({maxEntries:64,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\/_next\/image\?url=.+$/i,new e.StaleWhileRevalidate({cacheName:"next-image",plugins:[new e.ExpirationPlugin({maxEntries:64,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\.(?:mp3|wav|ogg)$/i,new e.CacheFirst({cacheName:"static-audio-assets",plugins:[new e.RangeRequestsPlugin,new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\.(?:mp4)$/i,new e.CacheFirst({cacheName:"static-video-assets",plugins:[new e.RangeRequestsPlugin,new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\.(?:js)$/i,new e.StaleWhileRevalidate({cacheName:"static-js-assets",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\.(?:css|less)$/i,new e.StaleWhileRevalidate({cacheName:"static-style-assets",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\/_next\/data\/.+\/.+\.json$/i,new e.StaleWhileRevalidate({cacheName:"next-data",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute(/\.(?:json|xml|csv)$/i,new e.NetworkFirst({cacheName:"static-data-assets",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute((({url:e})=>{if(!(self.origin===e.origin))return!1;const s=e.pathname;return!s.startsWith("/api/auth/")&&!!s.startsWith("/api/")}),new e.NetworkFirst({cacheName:"apis",networkTimeoutSeconds:10,plugins:[new e.ExpirationPlugin({maxEntries:16,maxAgeSeconds:86400})]}),"GET"),e.registerRoute((({url:e})=>{if(!(self.origin===e.origin))return!1;return!e.pathname.startsWith("/api/")}),new e.NetworkFirst({cacheName:"others",networkTimeoutSeconds:10,plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400})]}),"GET"),e.registerRoute((({url:e})=>!(self.origin===e.origin)),new e.NetworkFirst({cacheName:"cross-origin",networkTimeoutSeconds:10,plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:3600})]}),"GET")})); +/** + * Copyright 2018 Google Inc. All Rights Reserved. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * http://www.apache.org/licenses/LICENSE-2.0 + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +// If the loader is already loaded, just stop. +if (!self.define) { + let registry = {}; + + // Used for `eval` and `importScripts` where we can't get script URL by other means. + // In both cases, it's safe to use a global var because those functions are synchronous. + let nextDefineUri; + + const singleRequire = (uri, parentUri) => { + uri = new URL(uri + ".js", parentUri).href; + return registry[uri] || ( + + new Promise(resolve => { + if ("document" in self) { + const script = document.createElement("script"); + script.src = uri; + script.onload = resolve; + document.head.appendChild(script); + } else { + nextDefineUri = uri; + importScripts(uri); + resolve(); + } + }) + + .then(() => { + let promise = registry[uri]; + if (!promise) { + throw new Error(`Module ${uri} didn’t register its module`); + } + return promise; + }) + ); + }; + + self.define = (depsNames, factory) => { + const uri = nextDefineUri || ("document" in self ? document.currentScript.src : "") || location.href; + if (registry[uri]) { + // Module is already loading or loaded. + return; + } + let exports = {}; + const require = depUri => singleRequire(depUri, uri); + const specialDeps = { + module: { uri }, + exports, + require + }; + registry[uri] = Promise.all(depsNames.map( + depName => specialDeps[depName] || require(depName) + )).then(deps => { + factory(...deps); + return exports; + }); + }; +} +define(['./workbox-56d5d59b'], (function (workbox) { 'use strict'; + + /** + * Welcome to your Workbox-powered service worker! + * + * You'll need to register this file in your web app. + * See https://goo.gl/nhQhGp + * + * The rest of the code is auto-generated. Please don't update this file + * directly; instead, make changes to your Workbox build configuration + * and re-run your build process. + * See https://goo.gl/2aRDsh + */ + + importScripts(); + self.skipWaiting(); + workbox.clientsClaim(); + workbox.registerRoute("/", new workbox.NetworkFirst({ + "cacheName": "start-url", + plugins: [{ + cacheWillUpdate: async ({ + request, + response, + event, + state + }) => { + if (response && response.type === 'opaqueredirect') { + return new Response(response.body, { + status: 200, + statusText: 'OK', + headers: response.headers + }); + } + + return response; + } + }] + }), 'GET'); + workbox.registerRoute(/.*/i, new workbox.NetworkOnly({ + "cacheName": "dev", + plugins: [] + }), 'GET'); + +})); +//# sourceMappingURL=sw.js.map diff --git a/public/sw.js.map b/public/sw.js.map new file mode 100644 index 0000000..3362a99 --- /dev/null +++ b/public/sw.js.map @@ -0,0 +1 @@ +{"version":3,"file":"sw.js","sources":["../../../../AppData/Local/Temp/e438dd07dffba05d92963a3d63f5782a/sw.js"],"sourcesContent":["import {registerRoute as workbox_routing_registerRoute} from 'C:/Users/Guz/Documents/GitHub/Guz/homework.app/node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/registerRoute.mjs';\nimport {NetworkFirst as workbox_strategies_NetworkFirst} from 'C:/Users/Guz/Documents/GitHub/Guz/homework.app/node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/NetworkFirst.mjs';\nimport {NetworkOnly as workbox_strategies_NetworkOnly} from 'C:/Users/Guz/Documents/GitHub/Guz/homework.app/node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/NetworkOnly.mjs';\nimport {clientsClaim as workbox_core_clientsClaim} from 'C:/Users/Guz/Documents/GitHub/Guz/homework.app/node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/clientsClaim.mjs';/**\n * Welcome to your Workbox-powered service worker!\n *\n * You'll need to register this file in your web app.\n * See https://goo.gl/nhQhGp\n *\n * The rest of the code is auto-generated. Please don't update this file\n * directly; instead, make changes to your Workbox build configuration\n * and re-run your build process.\n * See https://goo.gl/2aRDsh\n */\n\n\nimportScripts(\n \n);\n\n\n\n\n\n\n\nself.skipWaiting();\n\nworkbox_core_clientsClaim();\n\n\n\nworkbox_routing_registerRoute(\"/\", new workbox_strategies_NetworkFirst({ \"cacheName\":\"start-url\", plugins: [{ cacheWillUpdate: async ({request, response, event, state}) => { if (response && response.type === 'opaqueredirect') { return new Response(response.body, {status: 200, statusText: 'OK', headers: response.headers}); } return response; } }] }), 'GET');\nworkbox_routing_registerRoute(/.*/i, new workbox_strategies_NetworkOnly({ \"cacheName\":\"dev\", plugins: [] }), 'GET');\n\n\n\n\n"],"names":["importScripts","self","skipWaiting","workbox_core_clientsClaim","workbox_routing_registerRoute","workbox_strategies_NetworkFirst","plugins","cacheWillUpdate","request","response","event","state","type","Response","body","status","statusText","headers","workbox_strategies_NetworkOnly"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAG0L,CAAA,CAAA,CAAA,CAAA,CAAA;AAC1L,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AA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"} \ No newline at end of file diff --git a/public/workbox-3d9e5b44.js b/public/workbox-3d9e5b44.js deleted file mode 100644 index 35437c1..0000000 --- a/public/workbox-3d9e5b44.js +++ /dev/null @@ -1 +0,0 @@ -define(["exports"],(function(t){"use strict";try{self["workbox:core:6.5.1"]&&_()}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.5.1"]&&_()}catch(t){}const n=t=>t&&"object"==typeof t?t:{handle:t};class r{constructor(t,e,s="GET"){this.handler=n(e),this.match=t,this.method=s}setCatchHandler(t){this.catchHandler=n(t)}}class i extends r{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:r,route:i}=this.findMatchingRoute({event:e,request:t,sameOrigin:n,url:s});let a=i&&i.handler;const o=t.method;if(!a&&this.i.has(o)&&(a=this.i.get(o)),!a)return;let c;try{c=a.handle({url:s,request:t,event:e,params:r})}catch(t){c=Promise.reject(t)}const h=i&&i.catchHandler;return c instanceof Promise&&(this.o||h)&&(c=c.catch((async n=>{if(h)try{return await h.handle({url:s,request:t,event:e,params:r})}catch(t){t instanceof Error&&(n=t)}if(this.o)return this.o.handle({url:s,request:t,event:e});throw n}))),c}findMatchingRoute({url:t,sameOrigin:e,request:s,event:n}){const r=this.t.get(s.method)||[];for(const i of r){let r;const a=i.match({url:t,sameOrigin:e,request:s,event:n});if(a)return r=a,(Array.isArray(r)&&0===r.length||a.constructor===Object&&0===Object.keys(a).length||"boolean"==typeof a)&&(r=void 0),{route:i,params:r}}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 o;const c=()=>(o||(o=new a,o.addFetchListener(),o.addCacheListener()),o);function h(t,e,n){let a;if("string"==typeof t){const s=new URL(t,location.href);a=new r((({url:t})=>t.href===s.href),e,n)}else if(t instanceof RegExp)a=new i(t,e,n);else if("function"==typeof t)a=new r(t,e,n);else{if(!(t instanceof r))throw new s("unsupported-route-type",{moduleName:"workbox-routing",funcName:"registerRoute",paramName:"capture"});a=t}return c().registerRoute(a),a}try{self["workbox:strategies:6.5.1"]&&_()}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(t,e){const s=new URL(t);for(const t of e)s.searchParams.delete(t);return s.href}class y{constructor(){this.promise=new Promise(((t,e)=>{this.resolve=t,this.reject=e}))}}const g=new Set;function m(t){return"string"==typeof t?new Request(t):t}class R{constructor(t,e){this.h={},Object.assign(this,e),this.event=e.event,this.u=t,this.l=new y,this.p=[],this.g=[...t.plugins],this.m=new Map;for(const t of this.g)this.m.set(t,{});this.event.waitUntil(this.l.promise)}async fetch(t){const{event:e}=this;let n=m(t);if("navigate"===n.mode&&e instanceof FetchEvent&&e.preloadResponse){const t=await e.preloadResponse;if(t)return t}const r=this.hasCallback("fetchDidFail")?n.clone():null;try{for(const t of this.iterateCallbacks("requestWillFetch"))n=await t({request:n.clone(),event:e})}catch(t){if(t instanceof Error)throw new s("plugin-error-request-will-fetch",{thrownErrorMessage:t.message})}const i=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:i,response:t});return t}catch(t){throw r&&await this.runCallbacks("fetchDidFail",{error:t,event:e,originalRequest:r.clone(),request:i.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=m(t);let s;const{cacheName:n,matchOptions:r}=this.u,i=await this.getCacheKey(e,"read"),a=Object.assign(Object.assign({},r),{cacheName:n});s=await caches.match(i,a);for(const t of this.iterateCallbacks("cachedResponseWillBeUsed"))s=await t({cacheName:n,matchOptions:r,cachedResponse:s,request:i,event:this.event})||void 0;return s}async cachePut(t,e){const n=m(t);var r;await(r=0,new Promise((t=>setTimeout(t,r))));const i=await this.getCacheKey(n,"write");if(!e)throw new s("cache-put-with-no-response",{url:(a=i.url,new URL(String(a),location.href).href.replace(new RegExp(`^${location.origin}`),""))});var a;const o=await this.R(e);if(!o)return!1;const{cacheName:c,matchOptions:h}=this.u,u=await self.caches.open(c),l=this.hasCallback("cacheDidUpdate"),f=l?await async function(t,e,s,n){const r=p(e.url,s);if(e.url===r)return t.match(e,n);const i=Object.assign(Object.assign({},n),{ignoreSearch:!0}),a=await t.keys(e,i);for(const e of a)if(r===p(e.url,s))return t.match(e,n)}(u,i.clone(),["__WB_REVISION__"],h):null;try{await u.put(i,l?o.clone():o)}catch(t){if(t instanceof Error)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:c,oldResponse:f,newResponse:o.clone(),request:i,event:this.event});return!0}async getCacheKey(t,e){const s=`${t.url} | ${e}`;if(!this.h[s]){let n=t;for(const t of this.iterateCallbacks("cacheKeyWillBeUsed"))n=m(await t({mode:e,request:n,event:this.event,params:this.params}));this.h[s]=n}return this.h[s]}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.m.get(e),n=n=>{const r=Object.assign(Object.assign({},n),{state:s});return e[t](r)};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(null)}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 v{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,r=new R(this,{event:e,request:s,params:n}),i=this.v(r,s,e);return[i,this.q(i,r,s,e)]}async v(t,e,n){let r;await t.runCallbacks("handlerWillStart",{event:n,request:e});try{if(r=await this.D(e,t),!r||"error"===r.type)throw new s("no-response",{url:e.url})}catch(s){if(s instanceof Error)for(const i of t.iterateCallbacks("handlerDidError"))if(r=await i({error:s,event:n,request:e}),r)break;if(!r)throw s}for(const s of t.iterateCallbacks("handlerWillRespond"))r=await s({event:n,request:e,response:r});return r}async q(t,e,s,n){let r,i;try{r=await t}catch(i){}try{await e.runCallbacks("handlerDidRespond",{event:n,request:s,response:r}),await e.doneWaiting()}catch(t){t instanceof Error&&(i=t)}if(await e.runCallbacks("handlerDidComplete",{event:n,request:s,response:r,error:i}),e.destroy(),i)throw i}}function b(t){t.then((()=>{}))}function q(){return q=Object.assign||function(t){for(var e=1;e(t[e]=s,!0),has:(t,e)=>t instanceof IDBTransaction&&("done"===e||"store"===e)||e in t};function O(t){return t!==IDBDatabase.prototype.transaction||"objectStoreNames"in IDBTransaction.prototype?(U||(U=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])).includes(t)?function(...e){return t.apply(B(this),e),k(x.get(this))}:function(...e){return k(t.apply(B(this),e))}:function(e,...s){const n=t.call(B(this),e,...s);return I.set(n,e.sort?e.sort():[e]),k(n)}}function T(t){return"function"==typeof t?O(t):(t instanceof IDBTransaction&&function(t){if(L.has(t))return;const e=new Promise(((e,s)=>{const n=()=>{t.removeEventListener("complete",r),t.removeEventListener("error",i),t.removeEventListener("abort",i)},r=()=>{e(),n()},i=()=>{s(t.error||new DOMException("AbortError","AbortError")),n()};t.addEventListener("complete",r),t.addEventListener("error",i),t.addEventListener("abort",i)}));L.set(t,e)}(t),e=t,(D||(D=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction])).some((t=>e instanceof t))?new Proxy(t,N):t);var e}function k(t){if(t instanceof IDBRequest)return function(t){const e=new Promise(((e,s)=>{const n=()=>{t.removeEventListener("success",r),t.removeEventListener("error",i)},r=()=>{e(k(t.result)),n()},i=()=>{s(t.error),n()};t.addEventListener("success",r),t.addEventListener("error",i)}));return e.then((e=>{e instanceof IDBCursor&&x.set(e,t)})).catch((()=>{})),E.set(e,t),e}(t);if(C.has(t))return C.get(t);const e=T(t);return e!==t&&(C.set(t,e),E.set(e,t)),e}const B=t=>E.get(t);const P=["get","getKey","getAll","getAllKeys","count"],M=["put","add","delete","clear"],W=new Map;function j(t,e){if(!(t instanceof IDBDatabase)||e in t||"string"!=typeof e)return;if(W.get(e))return W.get(e);const s=e.replace(/FromIndex$/,""),n=e!==s,r=M.includes(s);if(!(s in(n?IDBIndex:IDBObjectStore).prototype)||!r&&!P.includes(s))return;const i=async function(t,...e){const i=this.transaction(t,r?"readwrite":"readonly");let a=i.store;return n&&(a=a.index(e.shift())),(await Promise.all([a[s](...e),r&&i.done]))[0]};return W.set(e,i),i}N=(t=>q({},t,{get:(e,s,n)=>j(e,s)||t.get(e,s,n),has:(e,s)=>!!j(e,s)||t.has(e,s)}))(N);try{self["workbox:expiration:6.5.1"]&&_()}catch(t){}const S="cache-entries",K=t=>{const e=new URL(t,location.href);return e.hash="",e.href};class A{constructor(t){this.U=null,this._=t}L(t){const e=t.createObjectStore(S,{keyPath:"id"});e.createIndex("cacheName","cacheName",{unique:!1}),e.createIndex("timestamp","timestamp",{unique:!1})}I(t){this.L(t),this._&&function(t,{blocked:e}={}){const s=indexedDB.deleteDatabase(t);e&&s.addEventListener("blocked",(()=>e())),k(s).then((()=>{}))}(this._)}async setTimestamp(t,e){const s={url:t=K(t),timestamp:e,cacheName:this._,id:this.C(t)},n=(await this.getDb()).transaction(S,"readwrite",{durability:"relaxed"});await n.store.put(s),await n.done}async getTimestamp(t){const e=await this.getDb(),s=await e.get(S,this.C(t));return null==s?void 0:s.timestamp}async expireEntries(t,e){const s=await this.getDb();let n=await s.transaction(S).store.index("timestamp").openCursor(null,"prev");const r=[];let i=0;for(;n;){const s=n.value;s.cacheName===this._&&(t&&s.timestamp=e?r.push(n.value):i++),n=await n.continue()}const a=[];for(const t of r)await s.delete(S,t.id),a.push(t.url);return a}C(t){return this._+"|"+K(t)}async getDb(){return this.U||(this.U=await function(t,e,{blocked:s,upgrade:n,blocking:r,terminated:i}={}){const a=indexedDB.open(t,e),o=k(a);return n&&a.addEventListener("upgradeneeded",(t=>{n(k(a.result),t.oldVersion,t.newVersion,k(a.transaction))})),s&&a.addEventListener("blocked",(()=>s())),o.then((t=>{i&&t.addEventListener("close",(()=>i())),r&&t.addEventListener("versionchange",(()=>r()))})).catch((()=>{})),o}("workbox-expiration",1,{upgrade:this.I.bind(this)})),this.U}}class F{constructor(t,e={}){this.N=!1,this.O=!1,this.T=e.maxEntries,this.k=e.maxAgeSeconds,this.B=e.matchOptions,this._=t,this.P=new A(t)}async expireEntries(){if(this.N)return void(this.O=!0);this.N=!0;const t=this.k?Date.now()-1e3*this.k:0,e=await this.P.expireEntries(t,this.T),s=await self.caches.open(this._);for(const t of e)await s.delete(t,this.B);this.N=!1,this.O&&(this.O=!1,b(this.expireEntries()))}async updateTimestamp(t){await this.P.setTimestamp(t,Date.now())}async isURLExpired(t){if(this.k){const e=await this.P.getTimestamp(t),s=Date.now()-1e3*this.k;return void 0===e||er||e&&e<0)throw new s("range-not-satisfiable",{size:r,end:n,start:e});let i,a;return void 0!==e&&void 0!==n?(i=e,a=n+1):void 0!==e&&void 0===n?(i=e,a=r):void 0!==n&&void 0===e&&(i=r-n,a=r),{start:i,end:a}}(i,r.start,r.end),o=i.slice(a.start,a.end),c=o.size,h=new Response(o,{status:206,statusText:"Partial Content",headers:e.headers});return h.headers.set("Content-Length",String(c)),h.headers.set("Content-Range",`bytes ${a.start}-${a.end-1}/${i.size}`),h}catch(t){return new Response("",{status:416,statusText:"Range Not Satisfiable"})}}function $(t,e){const s=e();return t.waitUntil(s),s}try{self["workbox:precaching:6.5.1"]&&_()}catch(t){}function z(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 r=new URL(n,location.href),i=new URL(n,location.href);return r.searchParams.set("__WB_REVISION__",e),{cacheKey:r.href,url:i.href}}class G{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&&e&&e.originalRequest&&e.originalRequest instanceof Request){const t=e.originalRequest.url;s?this.notUpdatedURLs.push(t):this.updatedURLs.push(t)}return s}}}class V{constructor({precacheController:t}){this.cacheKeyWillBeUsed=async({request:t,params:e})=>{const s=(null==e?void 0:e.cacheKey)||this.M.getCacheKeyForURL(t.url);return s?new Request(s,{headers:t.headers}):t},this.M=t}}let J,Q;async function X(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 r=t.clone(),i={headers:new Headers(r.headers),status:r.status,statusText:r.statusText},a=e?e(i):i,o=function(){if(void 0===J){const t=new Response("");if("body"in t)try{new Response(t.body),J=!0}catch(t){J=!1}J=!1}return J}()?r.body:await r.blob();return new Response(o,a)}class Y extends v{constructor(t={}){t.cacheName=w(t.cacheName),super(t),this.W=!1!==t.fallbackToNetwork,this.plugins.push(Y.copyRedirectedCacheableResponsesPlugin)}async D(t,e){const s=await e.cacheMatch(t);return s||(e.event&&"install"===e.event.type?await this.j(t,e):await this.S(t,e))}async S(t,e){let n;const r=e.params||{};if(!this.W)throw new s("missing-precache-entry",{cacheName:this.cacheName,url:t.url});{const s=r.integrity,i=t.integrity,a=!i||i===s;n=await e.fetch(new Request(t,{integrity:i||s})),s&&a&&(this.K(),await e.cachePut(t,n.clone()))}return n}async j(t,e){this.K();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}K(){let t=null,e=0;for(const[s,n]of this.plugins.entries())n!==Y.copyRedirectedCacheableResponsesPlugin&&(n===Y.defaultPrecacheCacheabilityPlugin&&(t=s),n.cacheWillUpdate&&e++);0===e?this.plugins.push(Y.defaultPrecacheCacheabilityPlugin):e>1&&null!==t&&this.plugins.splice(t,1)}}Y.defaultPrecacheCacheabilityPlugin={cacheWillUpdate:async({response:t})=>!t||t.status>=400?null:t},Y.copyRedirectedCacheableResponsesPlugin={cacheWillUpdate:async({response:t})=>t.redirected?await X(t):t};class Z{constructor({cacheName:t,plugins:e=[],fallbackToNetwork:s=!0}={}){this.A=new Map,this.F=new Map,this.H=new Map,this.u=new Y({cacheName:w(t),plugins:[...e,new V({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.$||(self.addEventListener("install",this.install),self.addEventListener("activate",this.activate),this.$=!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:r}=z(n),i="string"!=typeof n&&n.revision?"reload":"default";if(this.A.has(r)&&this.A.get(r)!==t)throw new s("add-to-cache-list-conflicting-entries",{firstEntry:this.A.get(r),secondEntry:t});if("string"!=typeof n&&n.integrity){if(this.H.has(t)&&this.H.get(t)!==n.integrity)throw new s("add-to-cache-list-conflicting-integrities",{url:r});this.H.set(t,n.integrity)}if(this.A.set(r,t),this.F.set(r,i),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 $(t,(async()=>{const e=new G;this.strategy.plugins.push(e);for(const[e,s]of this.A){const n=this.H.get(s),r=this.F.get(e),i=new Request(e,{integrity:n,cache:r,credentials:"same-origin"});await Promise.all(this.strategy.handleAll({params:{cacheKey:s},request:i,event:t}))}const{updatedURLs:s,notUpdatedURLs:n}=e;return{updatedURLs:s,notUpdatedURLs:n}}))}activate(t){return $(t,(async()=>{const t=await self.caches.open(this.strategy.cacheName),e=await t.keys(),s=new Set(this.A.values()),n=[];for(const r of e)s.has(r.url)||(await t.delete(r),n.push(r.url));return{deletedURLs:n}}))}getURLsToCacheKeys(){return this.A}getCachedURLs(){return[...this.A.keys()]}getCacheKeyForURL(t){const e=new URL(t,location.href);return this.A.get(e.href)}getIntegrityForCacheKey(t){return this.H.get(t)}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=Object.assign({cacheKey:e},s.params),this.strategy.handle(s))}}const tt=()=>(Q||(Q=new Z),Q);class et extends r{constructor(t,e){super((({request:s})=>{const n=t.getURLsToCacheKeys();for(const r of function*(t,{ignoreURLParametersMatching:e=[/^utm_/,/^fbclid$/],directoryIndex:s="index.html",cleanURLs:n=!0,urlManipulation:r}={}){const i=new URL(t,location.href);i.hash="",yield i.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}(i,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(r){const t=r({url:i});for(const e of t)yield e.href}}(s.url,e)){const e=n.get(r);if(e){return{cacheKey:e,integrity:t.getIntegrityForCacheKey(e)}}}}),t.strategy)}}t.CacheFirst=class extends v{async D(t,e){let n,r=await e.cacheMatch(t);if(!r)try{r=await e.fetchAndCachePut(t)}catch(t){t instanceof Error&&(n=t)}if(!r)throw new s("no-response",{url:t.url,error:n});return r}},t.ExpirationPlugin=class{constructor(t={}){this.cachedResponseWillBeUsed=async({event:t,request:e,cacheName:s,cachedResponse:n})=>{if(!n)return null;const r=this.G(n),i=this.V(s);b(i.expireEntries());const a=i.updateTimestamp(e.url);if(t)try{t.waitUntil(a)}catch(t){}return r?n:null},this.cacheDidUpdate=async({cacheName:t,request:e})=>{const s=this.V(t);await s.updateTimestamp(e.url),await s.expireEntries()},this.J=t,this.k=t.maxAgeSeconds,this.X=new Map,t.purgeOnQuotaError&&function(t){g.add(t)}((()=>this.deleteCacheAndMetadata()))}V(t){if(t===d())throw new s("expire-custom-caches-only");let e=this.X.get(t);return e||(e=new F(t,this.J),this.X.set(t,e)),e}G(t){if(!this.k)return!0;const e=this.Y(t);if(null===e)return!0;return e>=Date.now()-1e3*this.k}Y(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.X)await self.caches.delete(t),await e.delete();this.X=new Map}},t.NetworkFirst=class extends v{constructor(t={}){super(t),this.plugins.some((t=>"cacheWillUpdate"in t))||this.plugins.unshift(u),this.Z=t.networkTimeoutSeconds||0}async D(t,e){const n=[],r=[];let i;if(this.Z){const{id:s,promise:a}=this.tt({request:t,logs:n,handler:e});i=s,r.push(a)}const a=this.et({timeoutId:i,request:t,logs:n,handler:e});r.push(a);const o=await e.waitUntil((async()=>await e.waitUntil(Promise.race(r))||await a)());if(!o)throw new s("no-response",{url:t.url});return o}tt({request:t,logs:e,handler:s}){let n;return{promise:new Promise((e=>{n=setTimeout((async()=>{e(await s.cacheMatch(t))}),1e3*this.Z)})),id:n}}async et({timeoutId:t,request:e,logs:s,handler:n}){let r,i;try{i=await n.fetchAndCachePut(e)}catch(t){t instanceof Error&&(r=t)}return t&&clearTimeout(t),!r&&i||(i=await n.cacheMatch(e)),i}},t.RangeRequestsPlugin=class{constructor(){this.cachedResponseWillBeUsed=async({request:t,cachedResponse:e})=>e&&t.headers.has("range")?await H(t,e):e}},t.StaleWhileRevalidate=class extends v{constructor(t={}){super(t),this.plugins.some((t=>"cacheWillUpdate"in t))||this.plugins.unshift(u)}async D(t,e){const n=e.fetchAndCachePut(t).catch((()=>{}));e.waitUntil(n);let r,i=await e.cacheMatch(t);if(i);else try{i=await n}catch(t){t instanceof Error&&(r=t)}if(!i)throw new s("no-response",{url:t.url,error:r});return i}},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){tt().precache(t)}(t),function(t){const e=tt();h(new et(e,t))}(e)},t.registerRoute=h})); diff --git a/public/workbox-56d5d59b.js b/public/workbox-56d5d59b.js new file mode 100644 index 0000000..0df6fa7 --- /dev/null +++ b/public/workbox-56d5d59b.js @@ -0,0 +1,2744 @@ +define(['exports'], (function (exports) { 'use strict'; + + try { + self['workbox:core:6.5.1'] && _(); + } catch (e) {} + + /* + Copyright 2019 Google LLC + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + const logger = (() => { + // Don't overwrite this value if it's already set. + // See https://github.com/GoogleChrome/workbox/pull/2284#issuecomment-560470923 + if (!('__WB_DISABLE_DEV_LOGS' in self)) { + self.__WB_DISABLE_DEV_LOGS = false; + } + + let inGroup = false; + const methodToColorMap = { + debug: `#7f8c8d`, + log: `#2ecc71`, + warn: `#f39c12`, + error: `#c0392b`, + groupCollapsed: `#3498db`, + groupEnd: null // No colored prefix on groupEnd + + }; + + const print = function (method, args) { + if (self.__WB_DISABLE_DEV_LOGS) { + return; + } + + if (method === 'groupCollapsed') { + // Safari doesn't print all console.groupCollapsed() arguments: + // https://bugs.webkit.org/show_bug.cgi?id=182754 + if (/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) { + console[method](...args); + return; + } + } + + const styles = [`background: ${methodToColorMap[method]}`, `border-radius: 0.5em`, `color: white`, `font-weight: bold`, `padding: 2px 0.5em`]; // When in a group, the workbox prefix is not displayed. + + const logPrefix = inGroup ? [] : ['%cworkbox', styles.join(';')]; + console[method](...logPrefix, ...args); + + if (method === 'groupCollapsed') { + inGroup = true; + } + + if (method === 'groupEnd') { + inGroup = false; + } + }; // eslint-disable-next-line @typescript-eslint/ban-types + + + const api = {}; + const loggerMethods = Object.keys(methodToColorMap); + + for (const key of loggerMethods) { + const method = key; + + api[method] = (...args) => { + print(method, args); + }; + } + + return api; + })(); + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + const messages$1 = { + 'invalid-value': ({ + paramName, + validValueDescription, + value + }) => { + if (!paramName || !validValueDescription) { + throw new Error(`Unexpected input to 'invalid-value' error.`); + } + + return `The '${paramName}' parameter was given a value with an ` + `unexpected value. ${validValueDescription} Received a value of ` + `${JSON.stringify(value)}.`; + }, + 'not-an-array': ({ + moduleName, + className, + funcName, + paramName + }) => { + if (!moduleName || !className || !funcName || !paramName) { + throw new Error(`Unexpected input to 'not-an-array' error.`); + } + + return `The parameter '${paramName}' passed into ` + `'${moduleName}.${className}.${funcName}()' must be an array.`; + }, + 'incorrect-type': ({ + expectedType, + paramName, + moduleName, + className, + funcName + }) => { + if (!expectedType || !paramName || !moduleName || !funcName) { + throw new Error(`Unexpected input to 'incorrect-type' error.`); + } + + const classNameStr = className ? `${className}.` : ''; + return `The parameter '${paramName}' passed into ` + `'${moduleName}.${classNameStr}` + `${funcName}()' must be of type ${expectedType}.`; + }, + 'incorrect-class': ({ + expectedClassName, + paramName, + moduleName, + className, + funcName, + isReturnValueProblem + }) => { + if (!expectedClassName || !moduleName || !funcName) { + throw new Error(`Unexpected input to 'incorrect-class' error.`); + } + + const classNameStr = className ? `${className}.` : ''; + + if (isReturnValueProblem) { + return `The return value from ` + `'${moduleName}.${classNameStr}${funcName}()' ` + `must be an instance of class ${expectedClassName}.`; + } + + return `The parameter '${paramName}' passed into ` + `'${moduleName}.${classNameStr}${funcName}()' ` + `must be an instance of class ${expectedClassName}.`; + }, + 'missing-a-method': ({ + expectedMethod, + paramName, + moduleName, + className, + funcName + }) => { + if (!expectedMethod || !paramName || !moduleName || !className || !funcName) { + throw new Error(`Unexpected input to 'missing-a-method' error.`); + } + + return `${moduleName}.${className}.${funcName}() expected the ` + `'${paramName}' parameter to expose a '${expectedMethod}' method.`; + }, + 'add-to-cache-list-unexpected-type': ({ + entry + }) => { + return `An unexpected entry was passed to ` + `'workbox-precaching.PrecacheController.addToCacheList()' The entry ` + `'${JSON.stringify(entry)}' isn't supported. You must supply an array of ` + `strings with one or more characters, objects with a url property or ` + `Request objects.`; + }, + 'add-to-cache-list-conflicting-entries': ({ + firstEntry, + secondEntry + }) => { + if (!firstEntry || !secondEntry) { + throw new Error(`Unexpected input to ` + `'add-to-cache-list-duplicate-entries' error.`); + } + + return `Two of the entries passed to ` + `'workbox-precaching.PrecacheController.addToCacheList()' had the URL ` + `${firstEntry} but different revision details. Workbox is ` + `unable to cache and version the asset correctly. Please remove one ` + `of the entries.`; + }, + 'plugin-error-request-will-fetch': ({ + thrownErrorMessage + }) => { + if (!thrownErrorMessage) { + throw new Error(`Unexpected input to ` + `'plugin-error-request-will-fetch', error.`); + } + + return `An error was thrown by a plugins 'requestWillFetch()' method. ` + `The thrown error message was: '${thrownErrorMessage}'.`; + }, + 'invalid-cache-name': ({ + cacheNameId, + value + }) => { + if (!cacheNameId) { + throw new Error(`Expected a 'cacheNameId' for error 'invalid-cache-name'`); + } + + return `You must provide a name containing at least one character for ` + `setCacheDetails({${cacheNameId}: '...'}). Received a value of ` + `'${JSON.stringify(value)}'`; + }, + 'unregister-route-but-not-found-with-method': ({ + method + }) => { + if (!method) { + throw new Error(`Unexpected input to ` + `'unregister-route-but-not-found-with-method' error.`); + } + + return `The route you're trying to unregister was not previously ` + `registered for the method type '${method}'.`; + }, + 'unregister-route-route-not-registered': () => { + return `The route you're trying to unregister was not previously ` + `registered.`; + }, + 'queue-replay-failed': ({ + name + }) => { + return `Replaying the background sync queue '${name}' failed.`; + }, + 'duplicate-queue-name': ({ + name + }) => { + return `The Queue name '${name}' is already being used. ` + `All instances of backgroundSync.Queue must be given unique names.`; + }, + 'expired-test-without-max-age': ({ + methodName, + paramName + }) => { + return `The '${methodName}()' method can only be used when the ` + `'${paramName}' is used in the constructor.`; + }, + 'unsupported-route-type': ({ + moduleName, + className, + funcName, + paramName + }) => { + return `The supplied '${paramName}' parameter was an unsupported type. ` + `Please check the docs for ${moduleName}.${className}.${funcName} for ` + `valid input types.`; + }, + 'not-array-of-class': ({ + value, + expectedClass, + moduleName, + className, + funcName, + paramName + }) => { + return `The supplied '${paramName}' parameter must be an array of ` + `'${expectedClass}' objects. Received '${JSON.stringify(value)},'. ` + `Please check the call to ${moduleName}.${className}.${funcName}() ` + `to fix the issue.`; + }, + 'max-entries-or-age-required': ({ + moduleName, + className, + funcName + }) => { + return `You must define either config.maxEntries or config.maxAgeSeconds` + `in ${moduleName}.${className}.${funcName}`; + }, + 'statuses-or-headers-required': ({ + moduleName, + className, + funcName + }) => { + return `You must define either config.statuses or config.headers` + `in ${moduleName}.${className}.${funcName}`; + }, + 'invalid-string': ({ + moduleName, + funcName, + paramName + }) => { + if (!paramName || !moduleName || !funcName) { + throw new Error(`Unexpected input to 'invalid-string' error.`); + } + + return `When using strings, the '${paramName}' parameter must start with ` + `'http' (for cross-origin matches) or '/' (for same-origin matches). ` + `Please see the docs for ${moduleName}.${funcName}() for ` + `more info.`; + }, + 'channel-name-required': () => { + return `You must provide a channelName to construct a ` + `BroadcastCacheUpdate instance.`; + }, + 'invalid-responses-are-same-args': () => { + return `The arguments passed into responsesAreSame() appear to be ` + `invalid. Please ensure valid Responses are used.`; + }, + 'expire-custom-caches-only': () => { + return `You must provide a 'cacheName' property when using the ` + `expiration plugin with a runtime caching strategy.`; + }, + 'unit-must-be-bytes': ({ + normalizedRangeHeader + }) => { + if (!normalizedRangeHeader) { + throw new Error(`Unexpected input to 'unit-must-be-bytes' error.`); + } + + return `The 'unit' portion of the Range header must be set to 'bytes'. ` + `The Range header provided was "${normalizedRangeHeader}"`; + }, + 'single-range-only': ({ + normalizedRangeHeader + }) => { + if (!normalizedRangeHeader) { + throw new Error(`Unexpected input to 'single-range-only' error.`); + } + + return `Multiple ranges are not supported. Please use a single start ` + `value, and optional end value. The Range header provided was ` + `"${normalizedRangeHeader}"`; + }, + 'invalid-range-values': ({ + normalizedRangeHeader + }) => { + if (!normalizedRangeHeader) { + throw new Error(`Unexpected input to 'invalid-range-values' error.`); + } + + return `The Range header is missing both start and end values. At least ` + `one of those values is needed. The Range header provided was ` + `"${normalizedRangeHeader}"`; + }, + 'no-range-header': () => { + return `No Range header was found in the Request provided.`; + }, + 'range-not-satisfiable': ({ + size, + start, + end + }) => { + return `The start (${start}) and end (${end}) values in the Range are ` + `not satisfiable by the cached response, which is ${size} bytes.`; + }, + 'attempt-to-cache-non-get-request': ({ + url, + method + }) => { + return `Unable to cache '${url}' because it is a '${method}' request and ` + `only 'GET' requests can be cached.`; + }, + 'cache-put-with-no-response': ({ + url + }) => { + return `There was an attempt to cache '${url}' but the response was not ` + `defined.`; + }, + 'no-response': ({ + url, + error + }) => { + let message = `The strategy could not generate a response for '${url}'.`; + + if (error) { + message += ` The underlying error is ${error}.`; + } + + return message; + }, + 'bad-precaching-response': ({ + url, + status + }) => { + return `The precaching request for '${url}' failed` + (status ? ` with an HTTP status of ${status}.` : `.`); + }, + 'non-precached-url': ({ + url + }) => { + return `createHandlerBoundToURL('${url}') was called, but that URL is ` + `not precached. Please pass in a URL that is precached instead.`; + }, + 'add-to-cache-list-conflicting-integrities': ({ + url + }) => { + return `Two of the entries passed to ` + `'workbox-precaching.PrecacheController.addToCacheList()' had the URL ` + `${url} with different integrity values. Please remove one of them.`; + }, + 'missing-precache-entry': ({ + cacheName, + url + }) => { + return `Unable to find a precached response in ${cacheName} for ${url}.`; + }, + 'cross-origin-copy-response': ({ + origin + }) => { + return `workbox-core.copyResponse() can only be used with same-origin ` + `responses. It was passed a response with origin ${origin}.`; + }, + 'opaque-streams-source': ({ + type + }) => { + const message = `One of the workbox-streams sources resulted in an ` + `'${type}' response.`; + + if (type === 'opaqueredirect') { + return `${message} Please do not use a navigation request that results ` + `in a redirect as a source.`; + } + + return `${message} Please ensure your sources are CORS-enabled.`; + } + }; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + + const generatorFunction = (code, details = {}) => { + const message = messages$1[code]; + + if (!message) { + throw new Error(`Unable to find message for code '${code}'.`); + } + + return message(details); + }; + + const messageGenerator = generatorFunction; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * Workbox errors should be thrown with this class. + * This allows use to ensure the type easily in tests, + * helps developers identify errors from workbox + * easily and allows use to optimise error + * messages correctly. + * + * @private + */ + + class WorkboxError extends Error { + /** + * + * @param {string} errorCode The error code that + * identifies this particular error. + * @param {Object=} details Any relevant arguments + * that will help developers identify issues should + * be added as a key on the context object. + */ + constructor(errorCode, details) { + const message = messageGenerator(errorCode, details); + super(message); + this.name = errorCode; + this.details = details; + } + + } + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /* + * This method throws if the supplied value is not an array. + * The destructed values are required to produce a meaningful error for users. + * The destructed and restructured object is so it's clear what is + * needed. + */ + + const isArray = (value, details) => { + if (!Array.isArray(value)) { + throw new WorkboxError('not-an-array', details); + } + }; + + const hasMethod = (object, expectedMethod, details) => { + const type = typeof object[expectedMethod]; + + if (type !== 'function') { + details['expectedMethod'] = expectedMethod; + throw new WorkboxError('missing-a-method', details); + } + }; + + const isType = (object, expectedType, details) => { + if (typeof object !== expectedType) { + details['expectedType'] = expectedType; + throw new WorkboxError('incorrect-type', details); + } + }; + + const isInstance = (object, // Need the general type to do the check later. + // eslint-disable-next-line @typescript-eslint/ban-types + expectedClass, details) => { + if (!(object instanceof expectedClass)) { + details['expectedClassName'] = expectedClass.name; + throw new WorkboxError('incorrect-class', details); + } + }; + + const isOneOf = (value, validValues, details) => { + if (!validValues.includes(value)) { + details['validValueDescription'] = `Valid values are ${JSON.stringify(validValues)}.`; + throw new WorkboxError('invalid-value', details); + } + }; + + const isArrayOfClass = (value, // Need general type to do check later. + expectedClass, // eslint-disable-line + details) => { + const error = new WorkboxError('not-array-of-class', details); + + if (!Array.isArray(value)) { + throw error; + } + + for (const item of value) { + if (!(item instanceof expectedClass)) { + throw error; + } + } + }; + + const finalAssertExports = { + hasMethod, + isArray, + isInstance, + isOneOf, + isType, + isArrayOfClass + }; + + try { + self['workbox:routing:6.5.1'] && _(); + } catch (e) {} + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * The default HTTP method, 'GET', used when there's no specific method + * configured for a route. + * + * @type {string} + * + * @private + */ + + const defaultMethod = 'GET'; + /** + * The list of valid HTTP methods associated with requests that could be routed. + * + * @type {Array} + * + * @private + */ + + const validMethods = ['DELETE', 'GET', 'HEAD', 'PATCH', 'POST', 'PUT']; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * @param {function()|Object} handler Either a function, or an object with a + * 'handle' method. + * @return {Object} An object with a handle method. + * + * @private + */ + + const normalizeHandler = handler => { + if (handler && typeof handler === 'object') { + { + finalAssertExports.hasMethod(handler, 'handle', { + moduleName: 'workbox-routing', + className: 'Route', + funcName: 'constructor', + paramName: 'handler' + }); + } + + return handler; + } else { + { + finalAssertExports.isType(handler, 'function', { + moduleName: 'workbox-routing', + className: 'Route', + funcName: 'constructor', + paramName: 'handler' + }); + } + + return { + handle: handler + }; + } + }; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * A `Route` consists of a pair of callback functions, "match" and "handler". + * The "match" callback determine if a route should be used to "handle" a + * request by returning a non-falsy value if it can. The "handler" callback + * is called when there is a match and should return a Promise that resolves + * to a `Response`. + * + * @memberof workbox-routing + */ + + class Route { + /** + * Constructor for Route class. + * + * @param {workbox-routing~matchCallback} match + * A callback function that determines whether the route matches a given + * `fetch` event by returning a non-falsy value. + * @param {workbox-routing~handlerCallback} handler A callback + * function that returns a Promise resolving to a Response. + * @param {string} [method='GET'] The HTTP method to match the Route + * against. + */ + constructor(match, handler, method = defaultMethod) { + { + finalAssertExports.isType(match, 'function', { + moduleName: 'workbox-routing', + className: 'Route', + funcName: 'constructor', + paramName: 'match' + }); + + if (method) { + finalAssertExports.isOneOf(method, validMethods, { + paramName: 'method' + }); + } + } // These values are referenced directly by Router so cannot be + // altered by minificaton. + + + this.handler = normalizeHandler(handler); + this.match = match; + this.method = method; + } + /** + * + * @param {workbox-routing-handlerCallback} handler A callback + * function that returns a Promise resolving to a Response + */ + + + setCatchHandler(handler) { + this.catchHandler = normalizeHandler(handler); + } + + } + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * RegExpRoute makes it easy to create a regular expression based + * {@link workbox-routing.Route}. + * + * For same-origin requests the RegExp only needs to match part of the URL. For + * requests against third-party servers, you must define a RegExp that matches + * the start of the URL. + * + * @memberof workbox-routing + * @extends workbox-routing.Route + */ + + class RegExpRoute extends Route { + /** + * If the regular expression contains + * [capture groups]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp#grouping-back-references}, + * the captured values will be passed to the + * {@link workbox-routing~handlerCallback} `params` + * argument. + * + * @param {RegExp} regExp The regular expression to match against URLs. + * @param {workbox-routing~handlerCallback} handler A callback + * function that returns a Promise resulting in a Response. + * @param {string} [method='GET'] The HTTP method to match the Route + * against. + */ + constructor(regExp, handler, method) { + { + finalAssertExports.isInstance(regExp, RegExp, { + moduleName: 'workbox-routing', + className: 'RegExpRoute', + funcName: 'constructor', + paramName: 'pattern' + }); + } + + const match = ({ + url + }) => { + const result = regExp.exec(url.href); // Return immediately if there's no match. + + if (!result) { + return; + } // Require that the match start at the first character in the URL string + // if it's a cross-origin request. + // See https://github.com/GoogleChrome/workbox/issues/281 for the context + // behind this behavior. + + + if (url.origin !== location.origin && result.index !== 0) { + { + logger.debug(`The regular expression '${regExp.toString()}' only partially matched ` + `against the cross-origin URL '${url.toString()}'. RegExpRoute's will only ` + `handle cross-origin requests if they match the entire URL.`); + } + + return; + } // If the route matches, but there aren't any capture groups defined, then + // this will return [], which is truthy and therefore sufficient to + // indicate a match. + // If there are capture groups, then it will return their values. + + + return result.slice(1); + }; + + super(match, handler, method); + } + + } + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + + const getFriendlyURL = url => { + const urlObj = new URL(String(url), location.href); // See https://github.com/GoogleChrome/workbox/issues/2323 + // We want to include everything, except for the origin if it's same-origin. + + return urlObj.href.replace(new RegExp(`^${location.origin}`), ''); + }; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * The Router can be used to process a `FetchEvent` using one or more + * {@link workbox-routing.Route}, responding with a `Response` if + * a matching route exists. + * + * If no route matches a given a request, the Router will use a "default" + * handler if one is defined. + * + * Should the matching Route throw an error, the Router will use a "catch" + * handler if one is defined to gracefully deal with issues and respond with a + * Request. + * + * If a request matches multiple routes, the **earliest** registered route will + * be used to respond to the request. + * + * @memberof workbox-routing + */ + + class Router { + /** + * Initializes a new Router. + */ + constructor() { + this._routes = new Map(); + this._defaultHandlerMap = new Map(); + } + /** + * @return {Map>} routes A `Map` of HTTP + * method name ('GET', etc.) to an array of all the corresponding `Route` + * instances that are registered. + */ + + + get routes() { + return this._routes; + } + /** + * Adds a fetch event listener to respond to events when a route matches + * the event's request. + */ + + + addFetchListener() { + // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705 + self.addEventListener('fetch', event => { + const { + request + } = event; + const responsePromise = this.handleRequest({ + request, + event + }); + + if (responsePromise) { + event.respondWith(responsePromise); + } + }); + } + /** + * Adds a message event listener for URLs to cache from the window. + * This is useful to cache resources loaded on the page prior to when the + * service worker started controlling it. + * + * The format of the message data sent from the window should be as follows. + * Where the `urlsToCache` array may consist of URL strings or an array of + * URL string + `requestInit` object (the same as you'd pass to `fetch()`). + * + * ``` + * { + * type: 'CACHE_URLS', + * payload: { + * urlsToCache: [ + * './script1.js', + * './script2.js', + * ['./script3.js', {mode: 'no-cors'}], + * ], + * }, + * } + * ``` + */ + + + addCacheListener() { + // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705 + self.addEventListener('message', event => { + // event.data is type 'any' + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access + if (event.data && event.data.type === 'CACHE_URLS') { + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + const { + payload + } = event.data; + + { + logger.debug(`Caching URLs from the window`, payload.urlsToCache); + } + + const requestPromises = Promise.all(payload.urlsToCache.map(entry => { + if (typeof entry === 'string') { + entry = [entry]; + } + + const request = new Request(...entry); + return this.handleRequest({ + request, + event + }); // TODO(philipwalton): TypeScript errors without this typecast for + // some reason (probably a bug). The real type here should work but + // doesn't: `Array | undefined>`. + })); // TypeScript + + event.waitUntil(requestPromises); // If a MessageChannel was used, reply to the message on success. + + if (event.ports && event.ports[0]) { + void requestPromises.then(() => event.ports[0].postMessage(true)); + } + } + }); + } + /** + * Apply the routing rules to a FetchEvent object to get a Response from an + * appropriate Route's handler. + * + * @param {Object} options + * @param {Request} options.request The request to handle. + * @param {ExtendableEvent} options.event The event that triggered the + * request. + * @return {Promise|undefined} A promise is returned if a + * registered route can handle the request. If there is no matching + * route and there's no `defaultHandler`, `undefined` is returned. + */ + + + handleRequest({ + request, + event + }) { + { + finalAssertExports.isInstance(request, Request, { + moduleName: 'workbox-routing', + className: 'Router', + funcName: 'handleRequest', + paramName: 'options.request' + }); + } + + const url = new URL(request.url, location.href); + + if (!url.protocol.startsWith('http')) { + { + logger.debug(`Workbox Router only supports URLs that start with 'http'.`); + } + + return; + } + + const sameOrigin = url.origin === location.origin; + const { + params, + route + } = this.findMatchingRoute({ + event, + request, + sameOrigin, + url + }); + let handler = route && route.handler; + const debugMessages = []; + + { + if (handler) { + debugMessages.push([`Found a route to handle this request:`, route]); + + if (params) { + debugMessages.push([`Passing the following params to the route's handler:`, params]); + } + } + } // If we don't have a handler because there was no matching route, then + // fall back to defaultHandler if that's defined. + + + const method = request.method; + + if (!handler && this._defaultHandlerMap.has(method)) { + { + debugMessages.push(`Failed to find a matching route. Falling ` + `back to the default handler for ${method}.`); + } + + handler = this._defaultHandlerMap.get(method); + } + + if (!handler) { + { + // No handler so Workbox will do nothing. If logs is set of debug + // i.e. verbose, we should print out this information. + logger.debug(`No route found for: ${getFriendlyURL(url)}`); + } + + return; + } + + { + // We have a handler, meaning Workbox is going to handle the route. + // print the routing details to the console. + logger.groupCollapsed(`Router is responding to: ${getFriendlyURL(url)}`); + debugMessages.forEach(msg => { + if (Array.isArray(msg)) { + logger.log(...msg); + } else { + logger.log(msg); + } + }); + logger.groupEnd(); + } // Wrap in try and catch in case the handle method throws a synchronous + // error. It should still callback to the catch handler. + + + let responsePromise; + + try { + responsePromise = handler.handle({ + url, + request, + event, + params + }); + } catch (err) { + responsePromise = Promise.reject(err); + } // Get route's catch handler, if it exists + + + const catchHandler = route && route.catchHandler; + + if (responsePromise instanceof Promise && (this._catchHandler || catchHandler)) { + responsePromise = responsePromise.catch(async err => { + // If there's a route catch handler, process that first + if (catchHandler) { + { + // Still include URL here as it will be async from the console group + // and may not make sense without the URL + logger.groupCollapsed(`Error thrown when responding to: ` + ` ${getFriendlyURL(url)}. Falling back to route's Catch Handler.`); + logger.error(`Error thrown by:`, route); + logger.error(err); + logger.groupEnd(); + } + + try { + return await catchHandler.handle({ + url, + request, + event, + params + }); + } catch (catchErr) { + if (catchErr instanceof Error) { + err = catchErr; + } + } + } + + if (this._catchHandler) { + { + // Still include URL here as it will be async from the console group + // and may not make sense without the URL + logger.groupCollapsed(`Error thrown when responding to: ` + ` ${getFriendlyURL(url)}. Falling back to global Catch Handler.`); + logger.error(`Error thrown by:`, route); + logger.error(err); + logger.groupEnd(); + } + + return this._catchHandler.handle({ + url, + request, + event + }); + } + + throw err; + }); + } + + return responsePromise; + } + /** + * Checks a request and URL (and optionally an event) against the list of + * registered routes, and if there's a match, returns the corresponding + * route along with any params generated by the match. + * + * @param {Object} options + * @param {URL} options.url + * @param {boolean} options.sameOrigin The result of comparing `url.origin` + * against the current origin. + * @param {Request} options.request The request to match. + * @param {Event} options.event The corresponding event. + * @return {Object} An object with `route` and `params` properties. + * They are populated if a matching route was found or `undefined` + * otherwise. + */ + + + findMatchingRoute({ + url, + sameOrigin, + request, + event + }) { + const routes = this._routes.get(request.method) || []; + + for (const route of routes) { + let params; // route.match returns type any, not possible to change right now. + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + + const matchResult = route.match({ + url, + sameOrigin, + request, + event + }); + + if (matchResult) { + { + // Warn developers that using an async matchCallback is almost always + // not the right thing to do. + if (matchResult instanceof Promise) { + logger.warn(`While routing ${getFriendlyURL(url)}, an async ` + `matchCallback function was used. Please convert the ` + `following route to use a synchronous matchCallback function:`, route); + } + } // See https://github.com/GoogleChrome/workbox/issues/2079 + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + + + params = matchResult; + + if (Array.isArray(params) && params.length === 0) { + // Instead of passing an empty array in as params, use undefined. + params = undefined; + } else if (matchResult.constructor === Object && // eslint-disable-line + Object.keys(matchResult).length === 0) { + // Instead of passing an empty object in as params, use undefined. + params = undefined; + } else if (typeof matchResult === 'boolean') { + // For the boolean value true (rather than just something truth-y), + // don't set params. + // See https://github.com/GoogleChrome/workbox/pull/2134#issuecomment-513924353 + params = undefined; + } // Return early if have a match. + + + return { + route, + params + }; + } + } // If no match was found above, return and empty object. + + + return {}; + } + /** + * Define a default `handler` that's called when no routes explicitly + * match the incoming request. + * + * Each HTTP method ('GET', 'POST', etc.) gets its own default handler. + * + * Without a default handler, unmatched requests will go against the + * network as if there were no service worker present. + * + * @param {workbox-routing~handlerCallback} handler A callback + * function that returns a Promise resulting in a Response. + * @param {string} [method='GET'] The HTTP method to associate with this + * default handler. Each method has its own default. + */ + + + setDefaultHandler(handler, method = defaultMethod) { + this._defaultHandlerMap.set(method, normalizeHandler(handler)); + } + /** + * If a Route throws an error while handling a request, this `handler` + * will be called and given a chance to provide a response. + * + * @param {workbox-routing~handlerCallback} handler A callback + * function that returns a Promise resulting in a Response. + */ + + + setCatchHandler(handler) { + this._catchHandler = normalizeHandler(handler); + } + /** + * Registers a route with the router. + * + * @param {workbox-routing.Route} route The route to register. + */ + + + registerRoute(route) { + { + finalAssertExports.isType(route, 'object', { + moduleName: 'workbox-routing', + className: 'Router', + funcName: 'registerRoute', + paramName: 'route' + }); + finalAssertExports.hasMethod(route, 'match', { + moduleName: 'workbox-routing', + className: 'Router', + funcName: 'registerRoute', + paramName: 'route' + }); + finalAssertExports.isType(route.handler, 'object', { + moduleName: 'workbox-routing', + className: 'Router', + funcName: 'registerRoute', + paramName: 'route' + }); + finalAssertExports.hasMethod(route.handler, 'handle', { + moduleName: 'workbox-routing', + className: 'Router', + funcName: 'registerRoute', + paramName: 'route.handler' + }); + finalAssertExports.isType(route.method, 'string', { + moduleName: 'workbox-routing', + className: 'Router', + funcName: 'registerRoute', + paramName: 'route.method' + }); + } + + if (!this._routes.has(route.method)) { + this._routes.set(route.method, []); + } // Give precedence to all of the earlier routes by adding this additional + // route to the end of the array. + + + this._routes.get(route.method).push(route); + } + /** + * Unregisters a route with the router. + * + * @param {workbox-routing.Route} route The route to unregister. + */ + + + unregisterRoute(route) { + if (!this._routes.has(route.method)) { + throw new WorkboxError('unregister-route-but-not-found-with-method', { + method: route.method + }); + } + + const routeIndex = this._routes.get(route.method).indexOf(route); + + if (routeIndex > -1) { + this._routes.get(route.method).splice(routeIndex, 1); + } else { + throw new WorkboxError('unregister-route-route-not-registered'); + } + } + + } + + /* + Copyright 2019 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + let defaultRouter; + /** + * Creates a new, singleton Router instance if one does not exist. If one + * does already exist, that instance is returned. + * + * @private + * @return {Router} + */ + + const getOrCreateDefaultRouter = () => { + if (!defaultRouter) { + defaultRouter = new Router(); // The helpers that use the default Router assume these listeners exist. + + defaultRouter.addFetchListener(); + defaultRouter.addCacheListener(); + } + + return defaultRouter; + }; + + /* + Copyright 2019 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * Easily register a RegExp, string, or function with a caching + * strategy to a singleton Router instance. + * + * This method will generate a Route for you if needed and + * call {@link workbox-routing.Router#registerRoute}. + * + * @param {RegExp|string|workbox-routing.Route~matchCallback|workbox-routing.Route} capture + * If the capture param is a `Route`, all other arguments will be ignored. + * @param {workbox-routing~handlerCallback} [handler] A callback + * function that returns a Promise resulting in a Response. This parameter + * is required if `capture` is not a `Route` object. + * @param {string} [method='GET'] The HTTP method to match the Route + * against. + * @return {workbox-routing.Route} The generated `Route`. + * + * @memberof workbox-routing + */ + + function registerRoute(capture, handler, method) { + let route; + + if (typeof capture === 'string') { + const captureUrl = new URL(capture, location.href); + + { + if (!(capture.startsWith('/') || capture.startsWith('http'))) { + throw new WorkboxError('invalid-string', { + moduleName: 'workbox-routing', + funcName: 'registerRoute', + paramName: 'capture' + }); + } // We want to check if Express-style wildcards are in the pathname only. + // TODO: Remove this log message in v4. + + + const valueToCheck = capture.startsWith('http') ? captureUrl.pathname : capture; // See https://github.com/pillarjs/path-to-regexp#parameters + + const wildcards = '[*:?+]'; + + if (new RegExp(`${wildcards}`).exec(valueToCheck)) { + logger.debug(`The '$capture' parameter contains an Express-style wildcard ` + `character (${wildcards}). Strings are now always interpreted as ` + `exact matches; use a RegExp for partial or wildcard matches.`); + } + } + + const matchCallback = ({ + url + }) => { + { + if (url.pathname === captureUrl.pathname && url.origin !== captureUrl.origin) { + logger.debug(`${capture} only partially matches the cross-origin URL ` + `${url.toString()}. This route will only handle cross-origin requests ` + `if they match the entire URL.`); + } + } + + return url.href === captureUrl.href; + }; // If `capture` is a string then `handler` and `method` must be present. + + + route = new Route(matchCallback, handler, method); + } else if (capture instanceof RegExp) { + // If `capture` is a `RegExp` then `handler` and `method` must be present. + route = new RegExpRoute(capture, handler, method); + } else if (typeof capture === 'function') { + // If `capture` is a function then `handler` and `method` must be present. + route = new Route(capture, handler, method); + } else if (capture instanceof Route) { + route = capture; + } else { + throw new WorkboxError('unsupported-route-type', { + moduleName: 'workbox-routing', + funcName: 'registerRoute', + paramName: 'capture' + }); + } + + const defaultRouter = getOrCreateDefaultRouter(); + defaultRouter.registerRoute(route); + return route; + } + + try { + self['workbox:strategies:6.5.1'] && _(); + } catch (e) {} + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + const cacheOkAndOpaquePlugin = { + /** + * Returns a valid response (to allow caching) if the status is 200 (OK) or + * 0 (opaque). + * + * @param {Object} options + * @param {Response} options.response + * @return {Response|null} + * + * @private + */ + cacheWillUpdate: async ({ + response + }) => { + if (response.status === 200 || response.status === 0) { + return response; + } + + return null; + } + }; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + const _cacheNameDetails = { + googleAnalytics: 'googleAnalytics', + precache: 'precache-v2', + prefix: 'workbox', + runtime: 'runtime', + suffix: typeof registration !== 'undefined' ? registration.scope : '' + }; + + const _createCacheName = cacheName => { + return [_cacheNameDetails.prefix, cacheName, _cacheNameDetails.suffix].filter(value => value && value.length > 0).join('-'); + }; + + const eachCacheNameDetail = fn => { + for (const key of Object.keys(_cacheNameDetails)) { + fn(key); + } + }; + + const cacheNames = { + updateDetails: details => { + eachCacheNameDetail(key => { + if (typeof details[key] === 'string') { + _cacheNameDetails[key] = details[key]; + } + }); + }, + getGoogleAnalyticsName: userCacheName => { + return userCacheName || _createCacheName(_cacheNameDetails.googleAnalytics); + }, + getPrecacheName: userCacheName => { + return userCacheName || _createCacheName(_cacheNameDetails.precache); + }, + getPrefix: () => { + return _cacheNameDetails.prefix; + }, + getRuntimeName: userCacheName => { + return userCacheName || _createCacheName(_cacheNameDetails.runtime); + }, + getSuffix: () => { + return _cacheNameDetails.suffix; + } + }; + + /* + Copyright 2020 Google LLC + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + + function stripParams(fullURL, ignoreParams) { + const strippedURL = new URL(fullURL); + + for (const param of ignoreParams) { + strippedURL.searchParams.delete(param); + } + + return strippedURL.href; + } + /** + * Matches an item in the cache, ignoring specific URL params. This is similar + * to the `ignoreSearch` option, but it allows you to ignore just specific + * params (while continuing to match on the others). + * + * @private + * @param {Cache} cache + * @param {Request} request + * @param {Object} matchOptions + * @param {Array} ignoreParams + * @return {Promise} + */ + + + async function cacheMatchIgnoreParams(cache, request, ignoreParams, matchOptions) { + const strippedRequestURL = stripParams(request.url, ignoreParams); // If the request doesn't include any ignored params, match as normal. + + if (request.url === strippedRequestURL) { + return cache.match(request, matchOptions); + } // Otherwise, match by comparing keys + + + const keysOptions = Object.assign(Object.assign({}, matchOptions), { + ignoreSearch: true + }); + const cacheKeys = await cache.keys(request, keysOptions); + + for (const cacheKey of cacheKeys) { + const strippedCacheKeyURL = stripParams(cacheKey.url, ignoreParams); + + if (strippedRequestURL === strippedCacheKeyURL) { + return cache.match(cacheKey, matchOptions); + } + } + + return; + } + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * The Deferred class composes Promises in a way that allows for them to be + * resolved or rejected from outside the constructor. In most cases promises + * should be used directly, but Deferreds can be necessary when the logic to + * resolve a promise must be separate. + * + * @private + */ + + class Deferred { + /** + * Creates a promise and exposes its resolve and reject functions as methods. + */ + constructor() { + this.promise = new Promise((resolve, reject) => { + this.resolve = resolve; + this.reject = reject; + }); + } + + } + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + // Can't change Function type right now. + // eslint-disable-next-line @typescript-eslint/ban-types + + const quotaErrorCallbacks = new Set(); + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * Runs all of the callback functions, one at a time sequentially, in the order + * in which they were registered. + * + * @memberof workbox-core + * @private + */ + + async function executeQuotaErrorCallbacks() { + { + logger.log(`About to run ${quotaErrorCallbacks.size} ` + `callbacks to clean up caches.`); + } + + for (const callback of quotaErrorCallbacks) { + await callback(); + + { + logger.log(callback, 'is complete.'); + } + } + + { + logger.log('Finished running callbacks.'); + } + } + + /* + Copyright 2019 Google LLC + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * Returns a promise that resolves and the passed number of milliseconds. + * This utility is an async/await-friendly version of `setTimeout`. + * + * @param {number} ms + * @return {Promise} + * @private + */ + + function timeout(ms) { + return new Promise(resolve => setTimeout(resolve, ms)); + } + + /* + Copyright 2020 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + + function toRequest(input) { + return typeof input === 'string' ? new Request(input) : input; + } + /** + * A class created every time a Strategy instance instance calls + * {@link workbox-strategies.Strategy~handle} or + * {@link workbox-strategies.Strategy~handleAll} that wraps all fetch and + * cache actions around plugin callbacks and keeps track of when the strategy + * is "done" (i.e. all added `event.waitUntil()` promises have resolved). + * + * @memberof workbox-strategies + */ + + + class StrategyHandler { + /** + * Creates a new instance associated with the passed strategy and event + * that's handling the request. + * + * The constructor also initializes the state that will be passed to each of + * the plugins handling this request. + * + * @param {workbox-strategies.Strategy} strategy + * @param {Object} options + * @param {Request|string} options.request A request to run this strategy for. + * @param {ExtendableEvent} options.event The event associated with the + * request. + * @param {URL} [options.url] + * @param {*} [options.params] The return value from the + * {@link workbox-routing~matchCallback} (if applicable). + */ + constructor(strategy, options) { + this._cacheKeys = {}; + /** + * The request the strategy is performing (passed to the strategy's + * `handle()` or `handleAll()` method). + * @name request + * @instance + * @type {Request} + * @memberof workbox-strategies.StrategyHandler + */ + + /** + * The event associated with this request. + * @name event + * @instance + * @type {ExtendableEvent} + * @memberof workbox-strategies.StrategyHandler + */ + + /** + * A `URL` instance of `request.url` (if passed to the strategy's + * `handle()` or `handleAll()` method). + * Note: the `url` param will be present if the strategy was invoked + * from a workbox `Route` object. + * @name url + * @instance + * @type {URL|undefined} + * @memberof workbox-strategies.StrategyHandler + */ + + /** + * A `param` value (if passed to the strategy's + * `handle()` or `handleAll()` method). + * Note: the `param` param will be present if the strategy was invoked + * from a workbox `Route` object and the + * {@link workbox-routing~matchCallback} returned + * a truthy value (it will be that value). + * @name params + * @instance + * @type {*|undefined} + * @memberof workbox-strategies.StrategyHandler + */ + + { + finalAssertExports.isInstance(options.event, ExtendableEvent, { + moduleName: 'workbox-strategies', + className: 'StrategyHandler', + funcName: 'constructor', + paramName: 'options.event' + }); + } + + Object.assign(this, options); + this.event = options.event; + this._strategy = strategy; + this._handlerDeferred = new Deferred(); + this._extendLifetimePromises = []; // Copy the plugins list (since it's mutable on the strategy), + // so any mutations don't affect this handler instance. + + this._plugins = [...strategy.plugins]; + this._pluginStateMap = new Map(); + + for (const plugin of this._plugins) { + this._pluginStateMap.set(plugin, {}); + } + + this.event.waitUntil(this._handlerDeferred.promise); + } + /** + * Fetches a given request (and invokes any applicable plugin callback + * methods) using the `fetchOptions` (for non-navigation requests) and + * `plugins` defined on the `Strategy` object. + * + * The following plugin lifecycle methods are invoked when using this method: + * - `requestWillFetch()` + * - `fetchDidSucceed()` + * - `fetchDidFail()` + * + * @param {Request|string} input The URL or request to fetch. + * @return {Promise} + */ + + + async fetch(input) { + const { + event + } = this; + let request = toRequest(input); + + if (request.mode === 'navigate' && event instanceof FetchEvent && event.preloadResponse) { + const possiblePreloadResponse = await event.preloadResponse; + + if (possiblePreloadResponse) { + { + logger.log(`Using a preloaded navigation response for ` + `'${getFriendlyURL(request.url)}'`); + } + + return possiblePreloadResponse; + } + } // If there is a fetchDidFail plugin, we need to save a clone of the + // original request before it's either modified by a requestWillFetch + // plugin or before the original request's body is consumed via fetch(). + + + const originalRequest = this.hasCallback('fetchDidFail') ? request.clone() : null; + + try { + for (const cb of this.iterateCallbacks('requestWillFetch')) { + request = await cb({ + request: request.clone(), + event + }); + } + } catch (err) { + if (err instanceof Error) { + throw new WorkboxError('plugin-error-request-will-fetch', { + thrownErrorMessage: err.message + }); + } + } // The request can be altered by plugins with `requestWillFetch` making + // the original request (most likely from a `fetch` event) different + // from the Request we make. Pass both to `fetchDidFail` to aid debugging. + + + const pluginFilteredRequest = request.clone(); + + try { + let fetchResponse; // See https://github.com/GoogleChrome/workbox/issues/1796 + + fetchResponse = await fetch(request, request.mode === 'navigate' ? undefined : this._strategy.fetchOptions); + + if ("development" !== 'production') { + logger.debug(`Network request for ` + `'${getFriendlyURL(request.url)}' returned a response with ` + `status '${fetchResponse.status}'.`); + } + + for (const callback of this.iterateCallbacks('fetchDidSucceed')) { + fetchResponse = await callback({ + event, + request: pluginFilteredRequest, + response: fetchResponse + }); + } + + return fetchResponse; + } catch (error) { + { + logger.log(`Network request for ` + `'${getFriendlyURL(request.url)}' threw an error.`, error); + } // `originalRequest` will only exist if a `fetchDidFail` callback + // is being used (see above). + + + if (originalRequest) { + await this.runCallbacks('fetchDidFail', { + error: error, + event, + originalRequest: originalRequest.clone(), + request: pluginFilteredRequest.clone() + }); + } + + throw error; + } + } + /** + * Calls `this.fetch()` and (in the background) runs `this.cachePut()` on + * the response generated by `this.fetch()`. + * + * The call to `this.cachePut()` automatically invokes `this.waitUntil()`, + * so you do not have to manually call `waitUntil()` on the event. + * + * @param {Request|string} input The request or URL to fetch and cache. + * @return {Promise} + */ + + + async fetchAndCachePut(input) { + const response = await this.fetch(input); + const responseClone = response.clone(); + void this.waitUntil(this.cachePut(input, responseClone)); + return response; + } + /** + * Matches a request from the cache (and invokes any applicable plugin + * callback methods) using the `cacheName`, `matchOptions`, and `plugins` + * defined on the strategy object. + * + * The following plugin lifecycle methods are invoked when using this method: + * - cacheKeyWillByUsed() + * - cachedResponseWillByUsed() + * + * @param {Request|string} key The Request or URL to use as the cache key. + * @return {Promise} A matching response, if found. + */ + + + async cacheMatch(key) { + const request = toRequest(key); + let cachedResponse; + const { + cacheName, + matchOptions + } = this._strategy; + const effectiveRequest = await this.getCacheKey(request, 'read'); + const multiMatchOptions = Object.assign(Object.assign({}, matchOptions), { + cacheName + }); + cachedResponse = await caches.match(effectiveRequest, multiMatchOptions); + + { + if (cachedResponse) { + logger.debug(`Found a cached response in '${cacheName}'.`); + } else { + logger.debug(`No cached response found in '${cacheName}'.`); + } + } + + for (const callback of this.iterateCallbacks('cachedResponseWillBeUsed')) { + cachedResponse = (await callback({ + cacheName, + matchOptions, + cachedResponse, + request: effectiveRequest, + event: this.event + })) || undefined; + } + + return cachedResponse; + } + /** + * Puts a request/response pair in the cache (and invokes any applicable + * plugin callback methods) using the `cacheName` and `plugins` defined on + * the strategy object. + * + * The following plugin lifecycle methods are invoked when using this method: + * - cacheKeyWillByUsed() + * - cacheWillUpdate() + * - cacheDidUpdate() + * + * @param {Request|string} key The request or URL to use as the cache key. + * @param {Response} response The response to cache. + * @return {Promise} `false` if a cacheWillUpdate caused the response + * not be cached, and `true` otherwise. + */ + + + async cachePut(key, response) { + const request = toRequest(key); // Run in the next task to avoid blocking other cache reads. + // https://github.com/w3c/ServiceWorker/issues/1397 + + await timeout(0); + const effectiveRequest = await this.getCacheKey(request, 'write'); + + { + if (effectiveRequest.method && effectiveRequest.method !== 'GET') { + throw new WorkboxError('attempt-to-cache-non-get-request', { + url: getFriendlyURL(effectiveRequest.url), + method: effectiveRequest.method + }); + } // See https://github.com/GoogleChrome/workbox/issues/2818 + + + const vary = response.headers.get('Vary'); + + if (vary) { + logger.debug(`The response for ${getFriendlyURL(effectiveRequest.url)} ` + `has a 'Vary: ${vary}' header. ` + `Consider setting the {ignoreVary: true} option on your strategy ` + `to ensure cache matching and deletion works as expected.`); + } + } + + if (!response) { + { + logger.error(`Cannot cache non-existent response for ` + `'${getFriendlyURL(effectiveRequest.url)}'.`); + } + + throw new WorkboxError('cache-put-with-no-response', { + url: getFriendlyURL(effectiveRequest.url) + }); + } + + const responseToCache = await this._ensureResponseSafeToCache(response); + + if (!responseToCache) { + { + logger.debug(`Response '${getFriendlyURL(effectiveRequest.url)}' ` + `will not be cached.`, responseToCache); + } + + return false; + } + + const { + cacheName, + matchOptions + } = this._strategy; + const cache = await self.caches.open(cacheName); + const hasCacheUpdateCallback = this.hasCallback('cacheDidUpdate'); + const oldResponse = hasCacheUpdateCallback ? await cacheMatchIgnoreParams( // TODO(philipwalton): the `__WB_REVISION__` param is a precaching + // feature. Consider into ways to only add this behavior if using + // precaching. + cache, effectiveRequest.clone(), ['__WB_REVISION__'], matchOptions) : null; + + { + logger.debug(`Updating the '${cacheName}' cache with a new Response ` + `for ${getFriendlyURL(effectiveRequest.url)}.`); + } + + try { + await cache.put(effectiveRequest, hasCacheUpdateCallback ? responseToCache.clone() : responseToCache); + } catch (error) { + if (error instanceof Error) { + // See https://developer.mozilla.org/en-US/docs/Web/API/DOMException#exception-QuotaExceededError + if (error.name === 'QuotaExceededError') { + await executeQuotaErrorCallbacks(); + } + + throw error; + } + } + + for (const callback of this.iterateCallbacks('cacheDidUpdate')) { + await callback({ + cacheName, + oldResponse, + newResponse: responseToCache.clone(), + request: effectiveRequest, + event: this.event + }); + } + + return true; + } + /** + * Checks the list of plugins for the `cacheKeyWillBeUsed` callback, and + * executes any of those callbacks found in sequence. The final `Request` + * object returned by the last plugin is treated as the cache key for cache + * reads and/or writes. If no `cacheKeyWillBeUsed` plugin callbacks have + * been registered, the passed request is returned unmodified + * + * @param {Request} request + * @param {string} mode + * @return {Promise} + */ + + + async getCacheKey(request, mode) { + const key = `${request.url} | ${mode}`; + + if (!this._cacheKeys[key]) { + let effectiveRequest = request; + + for (const callback of this.iterateCallbacks('cacheKeyWillBeUsed')) { + effectiveRequest = toRequest(await callback({ + mode, + request: effectiveRequest, + event: this.event, + // params has a type any can't change right now. + params: this.params // eslint-disable-line + + })); + } + + this._cacheKeys[key] = effectiveRequest; + } + + return this._cacheKeys[key]; + } + /** + * Returns true if the strategy has at least one plugin with the given + * callback. + * + * @param {string} name The name of the callback to check for. + * @return {boolean} + */ + + + hasCallback(name) { + for (const plugin of this._strategy.plugins) { + if (name in plugin) { + return true; + } + } + + return false; + } + /** + * Runs all plugin callbacks matching the given name, in order, passing the + * given param object (merged ith the current plugin state) as the only + * argument. + * + * Note: since this method runs all plugins, it's not suitable for cases + * where the return value of a callback needs to be applied prior to calling + * the next callback. See + * {@link workbox-strategies.StrategyHandler#iterateCallbacks} + * below for how to handle that case. + * + * @param {string} name The name of the callback to run within each plugin. + * @param {Object} param The object to pass as the first (and only) param + * when executing each callback. This object will be merged with the + * current plugin state prior to callback execution. + */ + + + async runCallbacks(name, param) { + for (const callback of this.iterateCallbacks(name)) { + // TODO(philipwalton): not sure why `any` is needed. It seems like + // this should work with `as WorkboxPluginCallbackParam[C]`. + await callback(param); + } + } + /** + * Accepts a callback and returns an iterable of matching plugin callbacks, + * where each callback is wrapped with the current handler state (i.e. when + * you call each callback, whatever object parameter you pass it will + * be merged with the plugin's current state). + * + * @param {string} name The name fo the callback to run + * @return {Array} + */ + + + *iterateCallbacks(name) { + for (const plugin of this._strategy.plugins) { + if (typeof plugin[name] === 'function') { + const state = this._pluginStateMap.get(plugin); + + const statefulCallback = param => { + const statefulParam = Object.assign(Object.assign({}, param), { + state + }); // TODO(philipwalton): not sure why `any` is needed. It seems like + // this should work with `as WorkboxPluginCallbackParam[C]`. + + return plugin[name](statefulParam); + }; + + yield statefulCallback; + } + } + } + /** + * Adds a promise to the + * [extend lifetime promises]{@link https://w3c.github.io/ServiceWorker/#extendableevent-extend-lifetime-promises} + * of the event event associated with the request being handled (usually a + * `FetchEvent`). + * + * Note: you can await + * {@link workbox-strategies.StrategyHandler~doneWaiting} + * to know when all added promises have settled. + * + * @param {Promise} promise A promise to add to the extend lifetime promises + * of the event that triggered the request. + */ + + + waitUntil(promise) { + this._extendLifetimePromises.push(promise); + + return promise; + } + /** + * Returns a promise that resolves once all promises passed to + * {@link workbox-strategies.StrategyHandler~waitUntil} + * have settled. + * + * Note: any work done after `doneWaiting()` settles should be manually + * passed to an event's `waitUntil()` method (not this handler's + * `waitUntil()` method), otherwise the service worker thread my be killed + * prior to your work completing. + */ + + + async doneWaiting() { + let promise; + + while (promise = this._extendLifetimePromises.shift()) { + await promise; + } + } + /** + * Stops running the strategy and immediately resolves any pending + * `waitUntil()` promises. + */ + + + destroy() { + this._handlerDeferred.resolve(null); + } + /** + * This method will call cacheWillUpdate on the available plugins (or use + * status === 200) to determine if the Response is safe and valid to cache. + * + * @param {Request} options.request + * @param {Response} options.response + * @return {Promise} + * + * @private + */ + + + async _ensureResponseSafeToCache(response) { + let responseToCache = response; + let pluginsUsed = false; + + for (const callback of this.iterateCallbacks('cacheWillUpdate')) { + responseToCache = (await callback({ + request: this.request, + response: responseToCache, + event: this.event + })) || undefined; + pluginsUsed = true; + + if (!responseToCache) { + break; + } + } + + if (!pluginsUsed) { + if (responseToCache && responseToCache.status !== 200) { + responseToCache = undefined; + } + + { + if (responseToCache) { + if (responseToCache.status !== 200) { + if (responseToCache.status === 0) { + logger.warn(`The response for '${this.request.url}' ` + `is an opaque response. The caching strategy that you're ` + `using will not cache opaque responses by default.`); + } else { + logger.debug(`The response for '${this.request.url}' ` + `returned a status code of '${response.status}' and won't ` + `be cached as a result.`); + } + } + } + } + } + + return responseToCache; + } + + } + + /* + Copyright 2020 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * An abstract base class that all other strategy classes must extend from: + * + * @memberof workbox-strategies + */ + + class Strategy { + /** + * Creates a new instance of the strategy and sets all documented option + * properties as public instance properties. + * + * Note: if a custom strategy class extends the base Strategy class and does + * not need more than these properties, it does not need to define its own + * constructor. + * + * @param {Object} [options] + * @param {string} [options.cacheName] Cache name to store and retrieve + * requests. Defaults to the cache names provided by + * {@link workbox-core.cacheNames}. + * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins} + * to use in conjunction with this caching strategy. + * @param {Object} [options.fetchOptions] Values passed along to the + * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters) + * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796) + * `fetch()` requests made by this strategy. + * @param {Object} [options.matchOptions] The + * [`CacheQueryOptions`]{@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions} + * for any `cache.match()` or `cache.put()` calls made by this strategy. + */ + constructor(options = {}) { + /** + * Cache name to store and retrieve + * requests. Defaults to the cache names provided by + * {@link workbox-core.cacheNames}. + * + * @type {string} + */ + this.cacheName = cacheNames.getRuntimeName(options.cacheName); + /** + * The list + * [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins} + * used by this strategy. + * + * @type {Array} + */ + + this.plugins = options.plugins || []; + /** + * Values passed along to the + * [`init`]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters} + * of all fetch() requests made by this strategy. + * + * @type {Object} + */ + + this.fetchOptions = options.fetchOptions; + /** + * The + * [`CacheQueryOptions`]{@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions} + * for any `cache.match()` or `cache.put()` calls made by this strategy. + * + * @type {Object} + */ + + this.matchOptions = options.matchOptions; + } + /** + * Perform a request strategy and returns a `Promise` that will resolve with + * a `Response`, invoking all relevant plugin callbacks. + * + * When a strategy instance is registered with a Workbox + * {@link workbox-routing.Route}, this method is automatically + * called when the route matches. + * + * Alternatively, this method can be used in a standalone `FetchEvent` + * listener by passing it to `event.respondWith()`. + * + * @param {FetchEvent|Object} options A `FetchEvent` or an object with the + * properties listed below. + * @param {Request|string} options.request A request to run this strategy for. + * @param {ExtendableEvent} options.event The event associated with the + * request. + * @param {URL} [options.url] + * @param {*} [options.params] + */ + + + handle(options) { + const [responseDone] = this.handleAll(options); + return responseDone; + } + /** + * Similar to {@link workbox-strategies.Strategy~handle}, but + * instead of just returning a `Promise` that resolves to a `Response` it + * it will return an tuple of `[response, done]` promises, where the former + * (`response`) is equivalent to what `handle()` returns, and the latter is a + * Promise that will resolve once any promises that were added to + * `event.waitUntil()` as part of performing the strategy have completed. + * + * You can await the `done` promise to ensure any extra work performed by + * the strategy (usually caching responses) completes successfully. + * + * @param {FetchEvent|Object} options A `FetchEvent` or an object with the + * properties listed below. + * @param {Request|string} options.request A request to run this strategy for. + * @param {ExtendableEvent} options.event The event associated with the + * request. + * @param {URL} [options.url] + * @param {*} [options.params] + * @return {Array} A tuple of [response, done] + * promises that can be used to determine when the response resolves as + * well as when the handler has completed all its work. + */ + + + handleAll(options) { + // Allow for flexible options to be passed. + if (options instanceof FetchEvent) { + options = { + event: options, + request: options.request + }; + } + + const event = options.event; + const request = typeof options.request === 'string' ? new Request(options.request) : options.request; + const params = 'params' in options ? options.params : undefined; + const handler = new StrategyHandler(this, { + event, + request, + params + }); + + const responseDone = this._getResponse(handler, request, event); + + const handlerDone = this._awaitComplete(responseDone, handler, request, event); // Return an array of promises, suitable for use with Promise.all(). + + + return [responseDone, handlerDone]; + } + + async _getResponse(handler, request, event) { + await handler.runCallbacks('handlerWillStart', { + event, + request + }); + let response = undefined; + + try { + response = await this._handle(request, handler); // The "official" Strategy subclasses all throw this error automatically, + // but in case a third-party Strategy doesn't, ensure that we have a + // consistent failure when there's no response or an error response. + + if (!response || response.type === 'error') { + throw new WorkboxError('no-response', { + url: request.url + }); + } + } catch (error) { + if (error instanceof Error) { + for (const callback of handler.iterateCallbacks('handlerDidError')) { + response = await callback({ + error, + event, + request + }); + + if (response) { + break; + } + } + } + + if (!response) { + throw error; + } else { + logger.log(`While responding to '${getFriendlyURL(request.url)}', ` + `an ${error instanceof Error ? error.toString() : ''} error occurred. Using a fallback response provided by ` + `a handlerDidError plugin.`); + } + } + + for (const callback of handler.iterateCallbacks('handlerWillRespond')) { + response = await callback({ + event, + request, + response + }); + } + + return response; + } + + async _awaitComplete(responseDone, handler, request, event) { + let response; + let error; + + try { + response = await responseDone; + } catch (error) {// Ignore errors, as response errors should be caught via the `response` + // promise above. The `done` promise will only throw for errors in + // promises passed to `handler.waitUntil()`. + } + + try { + await handler.runCallbacks('handlerDidRespond', { + event, + request, + response + }); + await handler.doneWaiting(); + } catch (waitUntilError) { + if (waitUntilError instanceof Error) { + error = waitUntilError; + } + } + + await handler.runCallbacks('handlerDidComplete', { + event, + request, + response, + error: error + }); + handler.destroy(); + + if (error) { + throw error; + } + } + + } + /** + * Classes extending the `Strategy` based class should implement this method, + * and leverage the {@link workbox-strategies.StrategyHandler} + * arg to perform all fetching and cache logic, which will ensure all relevant + * cache, cache options, fetch options and plugins are used (per the current + * strategy instance). + * + * @name _handle + * @instance + * @abstract + * @function + * @param {Request} request + * @param {workbox-strategies.StrategyHandler} handler + * @return {Promise} + * + * @memberof workbox-strategies.Strategy + */ + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + const messages = { + strategyStart: (strategyName, request) => `Using ${strategyName} to respond to '${getFriendlyURL(request.url)}'`, + printFinalResponse: response => { + if (response) { + logger.groupCollapsed(`View the final response here.`); + logger.log(response || '[No response returned]'); + logger.groupEnd(); + } + } + }; + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * An implementation of a + * [network first](https://developer.chrome.com/docs/workbox/caching-strategies-overview/#network-first-falling-back-to-cache) + * request strategy. + * + * By default, this strategy will cache responses with a 200 status code as + * well as [opaque responses](https://developer.chrome.com/docs/workbox/caching-resources-during-runtime/#opaque-responses). + * Opaque responses are are cross-origin requests where the response doesn't + * support [CORS](https://enable-cors.org/). + * + * If the network request fails, and there is no cache match, this will throw + * a `WorkboxError` exception. + * + * @extends workbox-strategies.Strategy + * @memberof workbox-strategies + */ + + class NetworkFirst extends Strategy { + /** + * @param {Object} [options] + * @param {string} [options.cacheName] Cache name to store and retrieve + * requests. Defaults to cache names provided by + * {@link workbox-core.cacheNames}. + * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins} + * to use in conjunction with this caching strategy. + * @param {Object} [options.fetchOptions] Values passed along to the + * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters) + * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796) + * `fetch()` requests made by this strategy. + * @param {Object} [options.matchOptions] [`CacheQueryOptions`](https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions) + * @param {number} [options.networkTimeoutSeconds] If set, any network requests + * that fail to respond within the timeout will fallback to the cache. + * + * This option can be used to combat + * "[lie-fi]{@link https://developers.google.com/web/fundamentals/performance/poor-connectivity/#lie-fi}" + * scenarios. + */ + constructor(options = {}) { + super(options); // If this instance contains no plugins with a 'cacheWillUpdate' callback, + // prepend the `cacheOkAndOpaquePlugin` plugin to the plugins list. + + if (!this.plugins.some(p => 'cacheWillUpdate' in p)) { + this.plugins.unshift(cacheOkAndOpaquePlugin); + } + + this._networkTimeoutSeconds = options.networkTimeoutSeconds || 0; + + { + if (this._networkTimeoutSeconds) { + finalAssertExports.isType(this._networkTimeoutSeconds, 'number', { + moduleName: 'workbox-strategies', + className: this.constructor.name, + funcName: 'constructor', + paramName: 'networkTimeoutSeconds' + }); + } + } + } + /** + * @private + * @param {Request|string} request A request to run this strategy for. + * @param {workbox-strategies.StrategyHandler} handler The event that + * triggered the request. + * @return {Promise} + */ + + + async _handle(request, handler) { + const logs = []; + + { + finalAssertExports.isInstance(request, Request, { + moduleName: 'workbox-strategies', + className: this.constructor.name, + funcName: 'handle', + paramName: 'makeRequest' + }); + } + + const promises = []; + let timeoutId; + + if (this._networkTimeoutSeconds) { + const { + id, + promise + } = this._getTimeoutPromise({ + request, + logs, + handler + }); + + timeoutId = id; + promises.push(promise); + } + + const networkPromise = this._getNetworkPromise({ + timeoutId, + request, + logs, + handler + }); + + promises.push(networkPromise); + const response = await handler.waitUntil((async () => { + // Promise.race() will resolve as soon as the first promise resolves. + return (await handler.waitUntil(Promise.race(promises))) || ( // If Promise.race() resolved with null, it might be due to a network + // timeout + a cache miss. If that were to happen, we'd rather wait until + // the networkPromise resolves instead of returning null. + // Note that it's fine to await an already-resolved promise, so we don't + // have to check to see if it's still "in flight". + await networkPromise); + })()); + + { + logger.groupCollapsed(messages.strategyStart(this.constructor.name, request)); + + for (const log of logs) { + logger.log(log); + } + + messages.printFinalResponse(response); + logger.groupEnd(); + } + + if (!response) { + throw new WorkboxError('no-response', { + url: request.url + }); + } + + return response; + } + /** + * @param {Object} options + * @param {Request} options.request + * @param {Array} options.logs A reference to the logs array + * @param {Event} options.event + * @return {Promise} + * + * @private + */ + + + _getTimeoutPromise({ + request, + logs, + handler + }) { + let timeoutId; + const timeoutPromise = new Promise(resolve => { + const onNetworkTimeout = async () => { + { + logs.push(`Timing out the network response at ` + `${this._networkTimeoutSeconds} seconds.`); + } + + resolve(await handler.cacheMatch(request)); + }; + + timeoutId = setTimeout(onNetworkTimeout, this._networkTimeoutSeconds * 1000); + }); + return { + promise: timeoutPromise, + id: timeoutId + }; + } + /** + * @param {Object} options + * @param {number|undefined} options.timeoutId + * @param {Request} options.request + * @param {Array} options.logs A reference to the logs Array. + * @param {Event} options.event + * @return {Promise} + * + * @private + */ + + + async _getNetworkPromise({ + timeoutId, + request, + logs, + handler + }) { + let error; + let response; + + try { + response = await handler.fetchAndCachePut(request); + } catch (fetchError) { + if (fetchError instanceof Error) { + error = fetchError; + } + } + + if (timeoutId) { + clearTimeout(timeoutId); + } + + { + if (response) { + logs.push(`Got response from network.`); + } else { + logs.push(`Unable to get a response from the network. Will respond ` + `with a cached response.`); + } + } + + if (error || !response) { + response = await handler.cacheMatch(request); + + { + if (response) { + logs.push(`Found a cached response in the '${this.cacheName}'` + ` cache.`); + } else { + logs.push(`No response found in the '${this.cacheName}' cache.`); + } + } + } + + return response; + } + + } + + /* + Copyright 2018 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * An implementation of a + * [network-only](https://developer.chrome.com/docs/workbox/caching-strategies-overview/#network-only) + * request strategy. + * + * This class is useful if you want to take advantage of any + * [Workbox plugins](https://developer.chrome.com/docs/workbox/using-plugins/). + * + * If the network request fails, this will throw a `WorkboxError` exception. + * + * @extends workbox-strategies.Strategy + * @memberof workbox-strategies + */ + + class NetworkOnly extends Strategy { + /** + * @param {Object} [options] + * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins} + * to use in conjunction with this caching strategy. + * @param {Object} [options.fetchOptions] Values passed along to the + * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters) + * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796) + * `fetch()` requests made by this strategy. + * @param {number} [options.networkTimeoutSeconds] If set, any network requests + * that fail to respond within the timeout will result in a network error. + */ + constructor(options = {}) { + super(options); + this._networkTimeoutSeconds = options.networkTimeoutSeconds || 0; + } + /** + * @private + * @param {Request|string} request A request to run this strategy for. + * @param {workbox-strategies.StrategyHandler} handler The event that + * triggered the request. + * @return {Promise} + */ + + + async _handle(request, handler) { + { + finalAssertExports.isInstance(request, Request, { + moduleName: 'workbox-strategies', + className: this.constructor.name, + funcName: '_handle', + paramName: 'request' + }); + } + + let error = undefined; + let response; + + try { + const promises = [handler.fetch(request)]; + + if (this._networkTimeoutSeconds) { + const timeoutPromise = timeout(this._networkTimeoutSeconds * 1000); + promises.push(timeoutPromise); + } + + response = await Promise.race(promises); + + if (!response) { + throw new Error(`Timed out the network response after ` + `${this._networkTimeoutSeconds} seconds.`); + } + } catch (err) { + if (err instanceof Error) { + error = err; + } + } + + { + logger.groupCollapsed(messages.strategyStart(this.constructor.name, request)); + + if (response) { + logger.log(`Got response from network.`); + } else { + logger.log(`Unable to get a response from the network.`); + } + + messages.printFinalResponse(response); + logger.groupEnd(); + } + + if (!response) { + throw new WorkboxError('no-response', { + url: request.url, + error + }); + } + + return response; + } + + } + + /* + Copyright 2019 Google LLC + + Use of this source code is governed by an MIT-style + license that can be found in the LICENSE file or at + https://opensource.org/licenses/MIT. + */ + /** + * Claim any currently available clients once the service worker + * becomes active. This is normally used in conjunction with `skipWaiting()`. + * + * @memberof workbox-core + */ + + function clientsClaim() { + self.addEventListener('activate', () => self.clients.claim()); + } + + exports.NetworkFirst = NetworkFirst; + exports.NetworkOnly = NetworkOnly; + exports.clientsClaim = clientsClaim; + exports.registerRoute = registerRoute; + +})); +//# sourceMappingURL=workbox-56d5d59b.js.map diff --git a/public/workbox-56d5d59b.js.map b/public/workbox-56d5d59b.js.map new file mode 100644 index 0000000..af4db69 --- /dev/null +++ b/public/workbox-56d5d59b.js.map @@ -0,0 +1 @@ +{"version":3,"file":"workbox-56d5d59b.js","sources":["node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_version.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/logger.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/models/messages/messages.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/models/messages/messageGenerator.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/WorkboxError.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/assert.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/_version.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/utils/constants.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/utils/normalizeHandler.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/Route.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/RegExpRoute.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/getFriendlyURL.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/Router.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/utils/getOrCreateDefaultRouter.js","node_modules/.pnpm/workbox-routing@6.5.2/node_modules/workbox-routing/registerRoute.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/_version.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/plugins/cacheOkAndOpaquePlugin.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/cacheNames.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/cacheMatchIgnoreParams.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/Deferred.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/models/quotaErrorCallbacks.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/executeQuotaErrorCallbacks.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/_private/timeout.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/StrategyHandler.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/Strategy.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/utils/messages.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/NetworkFirst.js","node_modules/.pnpm/workbox-strategies@6.5.2/node_modules/workbox-strategies/NetworkOnly.js","node_modules/.pnpm/workbox-core@6.5.2/node_modules/workbox-core/clientsClaim.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:6.5.1'] && _();\n}\ncatch (e) { }\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'\n ? null\n : (() => {\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, // No colored prefix on groupEnd\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 // eslint-disable-next-line @typescript-eslint/ban-types\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 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';\nexport const messages = {\n 'invalid-value': ({ paramName, validValueDescription, value }) => {\n if (!paramName || !validValueDescription) {\n throw new Error(`Unexpected input to 'invalid-value' error.`);\n }\n return (`The '${paramName}' parameter was given a value with an ` +\n `unexpected value. ${validValueDescription} Received a value of ` +\n `${JSON.stringify(value)}.`);\n },\n 'not-an-array': ({ moduleName, className, funcName, paramName }) => {\n if (!moduleName || !className || !funcName || !paramName) {\n throw new Error(`Unexpected input to 'not-an-array' error.`);\n }\n return (`The parameter '${paramName}' passed into ` +\n `'${moduleName}.${className}.${funcName}()' must be an array.`);\n },\n 'incorrect-type': ({ expectedType, paramName, moduleName, className, funcName, }) => {\n if (!expectedType || !paramName || !moduleName || !funcName) {\n throw new Error(`Unexpected input to 'incorrect-type' error.`);\n }\n const classNameStr = className ? `${className}.` : '';\n return (`The parameter '${paramName}' passed into ` +\n `'${moduleName}.${classNameStr}` +\n `${funcName}()' must be of type ${expectedType}.`);\n },\n 'incorrect-class': ({ expectedClassName, paramName, moduleName, className, funcName, isReturnValueProblem, }) => {\n if (!expectedClassName || !moduleName || !funcName) {\n throw new Error(`Unexpected input to 'incorrect-class' error.`);\n }\n const classNameStr = className ? `${className}.` : '';\n if (isReturnValueProblem) {\n return (`The return value from ` +\n `'${moduleName}.${classNameStr}${funcName}()' ` +\n `must be an instance of class ${expectedClassName}.`);\n }\n return (`The parameter '${paramName}' passed into ` +\n `'${moduleName}.${classNameStr}${funcName}()' ` +\n `must be an instance of class ${expectedClassName}.`);\n },\n 'missing-a-method': ({ expectedMethod, paramName, moduleName, className, funcName, }) => {\n if (!expectedMethod ||\n !paramName ||\n !moduleName ||\n !className ||\n !funcName) {\n throw new Error(`Unexpected input to 'missing-a-method' error.`);\n }\n return (`${moduleName}.${className}.${funcName}() expected the ` +\n `'${paramName}' parameter to expose a '${expectedMethod}' method.`);\n },\n 'add-to-cache-list-unexpected-type': ({ entry }) => {\n return (`An unexpected entry was passed to ` +\n `'workbox-precaching.PrecacheController.addToCacheList()' The entry ` +\n `'${JSON.stringify(entry)}' isn't supported. You must supply an array of ` +\n `strings with one or more characters, objects with a url property or ` +\n `Request objects.`);\n },\n 'add-to-cache-list-conflicting-entries': ({ firstEntry, secondEntry }) => {\n if (!firstEntry || !secondEntry) {\n throw new Error(`Unexpected input to ` + `'add-to-cache-list-duplicate-entries' error.`);\n }\n return (`Two of the entries passed to ` +\n `'workbox-precaching.PrecacheController.addToCacheList()' had the URL ` +\n `${firstEntry} but different revision details. Workbox is ` +\n `unable to cache and version the asset correctly. Please remove one ` +\n `of the entries.`);\n },\n 'plugin-error-request-will-fetch': ({ thrownErrorMessage }) => {\n if (!thrownErrorMessage) {\n throw new Error(`Unexpected input to ` + `'plugin-error-request-will-fetch', error.`);\n }\n return (`An error was thrown by a plugins 'requestWillFetch()' method. ` +\n `The thrown error message was: '${thrownErrorMessage}'.`);\n },\n 'invalid-cache-name': ({ cacheNameId, value }) => {\n if (!cacheNameId) {\n throw new Error(`Expected a 'cacheNameId' for error 'invalid-cache-name'`);\n }\n return (`You must provide a name containing at least one character for ` +\n `setCacheDetails({${cacheNameId}: '...'}). Received a value of ` +\n `'${JSON.stringify(value)}'`);\n },\n 'unregister-route-but-not-found-with-method': ({ method }) => {\n if (!method) {\n throw new Error(`Unexpected input to ` +\n `'unregister-route-but-not-found-with-method' error.`);\n }\n return (`The route you're trying to unregister was not previously ` +\n `registered for the method type '${method}'.`);\n },\n 'unregister-route-route-not-registered': () => {\n return (`The route you're trying to unregister was not previously ` +\n `registered.`);\n },\n 'queue-replay-failed': ({ name }) => {\n return `Replaying the background sync queue '${name}' failed.`;\n },\n 'duplicate-queue-name': ({ name }) => {\n return (`The Queue name '${name}' is already being used. ` +\n `All instances of backgroundSync.Queue must be given unique names.`);\n },\n 'expired-test-without-max-age': ({ methodName, paramName }) => {\n return (`The '${methodName}()' method can only be used when the ` +\n `'${paramName}' is used in the constructor.`);\n },\n 'unsupported-route-type': ({ moduleName, className, funcName, paramName }) => {\n return (`The supplied '${paramName}' parameter was an unsupported type. ` +\n `Please check the docs for ${moduleName}.${className}.${funcName} for ` +\n `valid input types.`);\n },\n 'not-array-of-class': ({ value, expectedClass, moduleName, className, funcName, paramName, }) => {\n return (`The supplied '${paramName}' parameter must be an array of ` +\n `'${expectedClass}' objects. Received '${JSON.stringify(value)},'. ` +\n `Please check the call to ${moduleName}.${className}.${funcName}() ` +\n `to fix the issue.`);\n },\n 'max-entries-or-age-required': ({ moduleName, className, funcName }) => {\n return (`You must define either config.maxEntries or config.maxAgeSeconds` +\n `in ${moduleName}.${className}.${funcName}`);\n },\n 'statuses-or-headers-required': ({ moduleName, className, funcName }) => {\n return (`You must define either config.statuses or config.headers` +\n `in ${moduleName}.${className}.${funcName}`);\n },\n 'invalid-string': ({ moduleName, funcName, paramName }) => {\n if (!paramName || !moduleName || !funcName) {\n throw new Error(`Unexpected input to 'invalid-string' error.`);\n }\n return (`When using strings, the '${paramName}' parameter must start with ` +\n `'http' (for cross-origin matches) or '/' (for same-origin matches). ` +\n `Please see the docs for ${moduleName}.${funcName}() for ` +\n `more info.`);\n },\n 'channel-name-required': () => {\n return (`You must provide a channelName to construct a ` +\n `BroadcastCacheUpdate instance.`);\n },\n 'invalid-responses-are-same-args': () => {\n return (`The arguments passed into responsesAreSame() appear to be ` +\n `invalid. Please ensure valid Responses are used.`);\n },\n 'expire-custom-caches-only': () => {\n return (`You must provide a 'cacheName' property when using the ` +\n `expiration plugin with a runtime caching strategy.`);\n },\n 'unit-must-be-bytes': ({ normalizedRangeHeader }) => {\n if (!normalizedRangeHeader) {\n throw new Error(`Unexpected input to 'unit-must-be-bytes' error.`);\n }\n return (`The 'unit' portion of the Range header must be set to 'bytes'. ` +\n `The Range header provided was \"${normalizedRangeHeader}\"`);\n },\n 'single-range-only': ({ normalizedRangeHeader }) => {\n if (!normalizedRangeHeader) {\n throw new Error(`Unexpected input to 'single-range-only' error.`);\n }\n return (`Multiple ranges are not supported. Please use a single start ` +\n `value, and optional end value. The Range header provided was ` +\n `\"${normalizedRangeHeader}\"`);\n },\n 'invalid-range-values': ({ normalizedRangeHeader }) => {\n if (!normalizedRangeHeader) {\n throw new Error(`Unexpected input to 'invalid-range-values' error.`);\n }\n return (`The Range header is missing both start and end values. At least ` +\n `one of those values is needed. The Range header provided was ` +\n `\"${normalizedRangeHeader}\"`);\n },\n 'no-range-header': () => {\n return `No Range header was found in the Request provided.`;\n },\n 'range-not-satisfiable': ({ size, start, end }) => {\n return (`The start (${start}) and end (${end}) values in the Range are ` +\n `not satisfiable by the cached response, which is ${size} bytes.`);\n },\n 'attempt-to-cache-non-get-request': ({ url, method }) => {\n return (`Unable to cache '${url}' because it is a '${method}' request and ` +\n `only 'GET' requests can be cached.`);\n },\n 'cache-put-with-no-response': ({ url }) => {\n return (`There was an attempt to cache '${url}' but the response was not ` +\n `defined.`);\n },\n 'no-response': ({ url, error }) => {\n let message = `The strategy could not generate a response for '${url}'.`;\n if (error) {\n message += ` The underlying error is ${error}.`;\n }\n return message;\n },\n 'bad-precaching-response': ({ url, status }) => {\n return (`The precaching request for '${url}' failed` +\n (status ? ` with an HTTP status of ${status}.` : `.`));\n },\n 'non-precached-url': ({ url }) => {\n return (`createHandlerBoundToURL('${url}') was called, but that URL is ` +\n `not precached. Please pass in a URL that is precached instead.`);\n },\n 'add-to-cache-list-conflicting-integrities': ({ url }) => {\n return (`Two of the entries passed to ` +\n `'workbox-precaching.PrecacheController.addToCacheList()' had the URL ` +\n `${url} with different integrity values. Please remove one of them.`);\n },\n 'missing-precache-entry': ({ cacheName, url }) => {\n return `Unable to find a precached response in ${cacheName} for ${url}.`;\n },\n 'cross-origin-copy-response': ({ origin }) => {\n return (`workbox-core.copyResponse() can only be used with same-origin ` +\n `responses. It was passed a response with origin ${origin}.`);\n },\n 'opaque-streams-source': ({ type }) => {\n const message = `One of the workbox-streams sources resulted in an ` +\n `'${type}' response.`;\n if (type === 'opaqueredirect') {\n return (`${message} Please do not use a navigation request that results ` +\n `in a redirect as a source.`);\n }\n return `${message} Please ensure your sources are CORS-enabled.`;\n },\n};\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 { messages } from './messages.js';\nimport '../../_version.js';\nconst fallback = (code, ...args) => {\n let msg = code;\n if (args.length > 0) {\n msg += ` :: ${JSON.stringify(args)}`;\n }\n return msg;\n};\nconst generatorFunction = (code, details = {}) => {\n const message = messages[code];\n if (!message) {\n throw new Error(`Unable to find message for code '${code}'.`);\n }\n return message(details);\n};\nexport const messageGenerator = process.env.NODE_ENV === 'production' ? fallback : generatorFunction;\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 { messageGenerator } from '../models/messages/messageGenerator.js';\nimport '../_version.js';\n/**\n * Workbox errors should be thrown with this class.\n * This allows use to ensure the type easily in tests,\n * helps developers identify errors from workbox\n * easily and allows use to optimise error\n * messages correctly.\n *\n * @private\n */\nclass WorkboxError extends Error {\n /**\n *\n * @param {string} errorCode The error code that\n * identifies this particular error.\n * @param {Object=} details Any relevant arguments\n * that will help developers identify issues should\n * be added as a key on the context object.\n */\n constructor(errorCode, details) {\n const message = messageGenerator(errorCode, details);\n super(message);\n this.name = errorCode;\n this.details = details;\n }\n}\nexport { WorkboxError };\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 { WorkboxError } from '../_private/WorkboxError.js';\nimport '../_version.js';\n/*\n * This method throws if the supplied value is not an array.\n * The destructed values are required to produce a meaningful error for users.\n * The destructed and restructured object is so it's clear what is\n * needed.\n */\nconst isArray = (value, details) => {\n if (!Array.isArray(value)) {\n throw new WorkboxError('not-an-array', details);\n }\n};\nconst hasMethod = (object, expectedMethod, details) => {\n const type = typeof object[expectedMethod];\n if (type !== 'function') {\n details['expectedMethod'] = expectedMethod;\n throw new WorkboxError('missing-a-method', details);\n }\n};\nconst isType = (object, expectedType, details) => {\n if (typeof object !== expectedType) {\n details['expectedType'] = expectedType;\n throw new WorkboxError('incorrect-type', details);\n }\n};\nconst isInstance = (object, \n// Need the general type to do the check later.\n// eslint-disable-next-line @typescript-eslint/ban-types\nexpectedClass, details) => {\n if (!(object instanceof expectedClass)) {\n details['expectedClassName'] = expectedClass.name;\n throw new WorkboxError('incorrect-class', details);\n }\n};\nconst isOneOf = (value, validValues, details) => {\n if (!validValues.includes(value)) {\n details['validValueDescription'] = `Valid values are ${JSON.stringify(validValues)}.`;\n throw new WorkboxError('invalid-value', details);\n }\n};\nconst isArrayOfClass = (value, \n// Need general type to do check later.\nexpectedClass, // eslint-disable-line\ndetails) => {\n const error = new WorkboxError('not-array-of-class', details);\n if (!Array.isArray(value)) {\n throw error;\n }\n for (const item of value) {\n if (!(item instanceof expectedClass)) {\n throw error;\n }\n }\n};\nconst finalAssertExports = process.env.NODE_ENV === 'production'\n ? null\n : {\n hasMethod,\n isArray,\n isInstance,\n isOneOf,\n isType,\n isArrayOfClass,\n };\nexport { finalAssertExports as assert };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:routing:6.5.1'] && _();\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 default HTTP method, 'GET', used when there's no specific method\n * configured for a route.\n *\n * @type {string}\n *\n * @private\n */\nexport const defaultMethod = 'GET';\n/**\n * The list of valid HTTP methods associated with requests that could be routed.\n *\n * @type {Array}\n *\n * @private\n */\nexport const validMethods = [\n 'DELETE',\n 'GET',\n 'HEAD',\n 'PATCH',\n 'POST',\n 'PUT',\n];\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 { assert } from 'workbox-core/_private/assert.js';\nimport '../_version.js';\n/**\n * @param {function()|Object} handler Either a function, or an object with a\n * 'handle' method.\n * @return {Object} An object with a handle method.\n *\n * @private\n */\nexport const normalizeHandler = (handler) => {\n if (handler && typeof handler === 'object') {\n if (process.env.NODE_ENV !== 'production') {\n assert.hasMethod(handler, 'handle', {\n moduleName: 'workbox-routing',\n className: 'Route',\n funcName: 'constructor',\n paramName: 'handler',\n });\n }\n return handler;\n }\n else {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(handler, 'function', {\n moduleName: 'workbox-routing',\n className: 'Route',\n funcName: 'constructor',\n paramName: 'handler',\n });\n }\n return { handle: handler };\n }\n};\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 { assert } from 'workbox-core/_private/assert.js';\nimport { defaultMethod, validMethods } from './utils/constants.js';\nimport { normalizeHandler } from './utils/normalizeHandler.js';\nimport './_version.js';\n/**\n * A `Route` consists of a pair of callback functions, \"match\" and \"handler\".\n * The \"match\" callback determine if a route should be used to \"handle\" a\n * request by returning a non-falsy value if it can. The \"handler\" callback\n * is called when there is a match and should return a Promise that resolves\n * to a `Response`.\n *\n * @memberof workbox-routing\n */\nclass Route {\n /**\n * Constructor for Route class.\n *\n * @param {workbox-routing~matchCallback} match\n * A callback function that determines whether the route matches a given\n * `fetch` event by returning a non-falsy value.\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resolving to a Response.\n * @param {string} [method='GET'] The HTTP method to match the Route\n * against.\n */\n constructor(match, handler, method = defaultMethod) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(match, 'function', {\n moduleName: 'workbox-routing',\n className: 'Route',\n funcName: 'constructor',\n paramName: 'match',\n });\n if (method) {\n assert.isOneOf(method, validMethods, { paramName: 'method' });\n }\n }\n // These values are referenced directly by Router so cannot be\n // altered by minificaton.\n this.handler = normalizeHandler(handler);\n this.match = match;\n this.method = method;\n }\n /**\n *\n * @param {workbox-routing-handlerCallback} handler A callback\n * function that returns a Promise resolving to a Response\n */\n setCatchHandler(handler) {\n this.catchHandler = normalizeHandler(handler);\n }\n}\nexport { Route };\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 { assert } from 'workbox-core/_private/assert.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { Route } from './Route.js';\nimport './_version.js';\n/**\n * RegExpRoute makes it easy to create a regular expression based\n * {@link workbox-routing.Route}.\n *\n * For same-origin requests the RegExp only needs to match part of the URL. For\n * requests against third-party servers, you must define a RegExp that matches\n * the start of the URL.\n *\n * @memberof workbox-routing\n * @extends workbox-routing.Route\n */\nclass RegExpRoute extends Route {\n /**\n * If the regular expression contains\n * [capture groups]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp#grouping-back-references},\n * the captured values will be passed to the\n * {@link workbox-routing~handlerCallback} `params`\n * argument.\n *\n * @param {RegExp} regExp The regular expression to match against URLs.\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resulting in a Response.\n * @param {string} [method='GET'] The HTTP method to match the Route\n * against.\n */\n constructor(regExp, handler, method) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(regExp, RegExp, {\n moduleName: 'workbox-routing',\n className: 'RegExpRoute',\n funcName: 'constructor',\n paramName: 'pattern',\n });\n }\n const match = ({ url }) => {\n const result = regExp.exec(url.href);\n // Return immediately if there's no match.\n if (!result) {\n return;\n }\n // Require that the match start at the first character in the URL string\n // if it's a cross-origin request.\n // See https://github.com/GoogleChrome/workbox/issues/281 for the context\n // behind this behavior.\n if (url.origin !== location.origin && result.index !== 0) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`The regular expression '${regExp.toString()}' only partially matched ` +\n `against the cross-origin URL '${url.toString()}'. RegExpRoute's will only ` +\n `handle cross-origin requests if they match the entire URL.`);\n }\n return;\n }\n // If the route matches, but there aren't any capture groups defined, then\n // this will return [], which is truthy and therefore sufficient to\n // indicate a match.\n // If there are capture groups, then it will return their values.\n return result.slice(1);\n };\n super(match, handler, method);\n }\n}\nexport { RegExpRoute };\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';\nconst getFriendlyURL = (url) => {\n const urlObj = new URL(String(url), location.href);\n // See https://github.com/GoogleChrome/workbox/issues/2323\n // We want to include everything, except for the origin if it's same-origin.\n return urlObj.href.replace(new RegExp(`^${location.origin}`), '');\n};\nexport { getFriendlyURL };\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 { assert } from 'workbox-core/_private/assert.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { defaultMethod } from './utils/constants.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { normalizeHandler } from './utils/normalizeHandler.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport './_version.js';\n/**\n * The Router can be used to process a `FetchEvent` using one or more\n * {@link workbox-routing.Route}, responding with a `Response` if\n * a matching route exists.\n *\n * If no route matches a given a request, the Router will use a \"default\"\n * handler if one is defined.\n *\n * Should the matching Route throw an error, the Router will use a \"catch\"\n * handler if one is defined to gracefully deal with issues and respond with a\n * Request.\n *\n * If a request matches multiple routes, the **earliest** registered route will\n * be used to respond to the request.\n *\n * @memberof workbox-routing\n */\nclass Router {\n /**\n * Initializes a new Router.\n */\n constructor() {\n this._routes = new Map();\n this._defaultHandlerMap = new Map();\n }\n /**\n * @return {Map>} routes A `Map` of HTTP\n * method name ('GET', etc.) to an array of all the corresponding `Route`\n * instances that are registered.\n */\n get routes() {\n return this._routes;\n }\n /**\n * Adds a fetch event listener to respond to events when a route matches\n * the event's request.\n */\n addFetchListener() {\n // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705\n self.addEventListener('fetch', ((event) => {\n const { request } = event;\n const responsePromise = this.handleRequest({ request, event });\n if (responsePromise) {\n event.respondWith(responsePromise);\n }\n }));\n }\n /**\n * Adds a message event listener for URLs to cache from the window.\n * This is useful to cache resources loaded on the page prior to when the\n * service worker started controlling it.\n *\n * The format of the message data sent from the window should be as follows.\n * Where the `urlsToCache` array may consist of URL strings or an array of\n * URL string + `requestInit` object (the same as you'd pass to `fetch()`).\n *\n * ```\n * {\n * type: 'CACHE_URLS',\n * payload: {\n * urlsToCache: [\n * './script1.js',\n * './script2.js',\n * ['./script3.js', {mode: 'no-cors'}],\n * ],\n * },\n * }\n * ```\n */\n addCacheListener() {\n // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705\n self.addEventListener('message', ((event) => {\n // event.data is type 'any'\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (event.data && event.data.type === 'CACHE_URLS') {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { payload } = event.data;\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Caching URLs from the window`, payload.urlsToCache);\n }\n const requestPromises = Promise.all(payload.urlsToCache.map((entry) => {\n if (typeof entry === 'string') {\n entry = [entry];\n }\n const request = new Request(...entry);\n return this.handleRequest({ request, event });\n // TODO(philipwalton): TypeScript errors without this typecast for\n // some reason (probably a bug). The real type here should work but\n // doesn't: `Array | undefined>`.\n })); // TypeScript\n event.waitUntil(requestPromises);\n // If a MessageChannel was used, reply to the message on success.\n if (event.ports && event.ports[0]) {\n void requestPromises.then(() => event.ports[0].postMessage(true));\n }\n }\n }));\n }\n /**\n * Apply the routing rules to a FetchEvent object to get a Response from an\n * appropriate Route's handler.\n *\n * @param {Object} options\n * @param {Request} options.request The request to handle.\n * @param {ExtendableEvent} options.event The event that triggered the\n * request.\n * @return {Promise|undefined} A promise is returned if a\n * registered route can handle the request. If there is no matching\n * route and there's no `defaultHandler`, `undefined` is returned.\n */\n handleRequest({ request, event, }) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(request, Request, {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'handleRequest',\n paramName: 'options.request',\n });\n }\n const url = new URL(request.url, location.href);\n if (!url.protocol.startsWith('http')) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Workbox Router only supports URLs that start with 'http'.`);\n }\n return;\n }\n const sameOrigin = url.origin === location.origin;\n const { params, route } = this.findMatchingRoute({\n event,\n request,\n sameOrigin,\n url,\n });\n let handler = route && route.handler;\n const debugMessages = [];\n if (process.env.NODE_ENV !== 'production') {\n if (handler) {\n debugMessages.push([`Found a route to handle this request:`, route]);\n if (params) {\n debugMessages.push([\n `Passing the following params to the route's handler:`,\n params,\n ]);\n }\n }\n }\n // If we don't have a handler because there was no matching route, then\n // fall back to defaultHandler if that's defined.\n const method = request.method;\n if (!handler && this._defaultHandlerMap.has(method)) {\n if (process.env.NODE_ENV !== 'production') {\n debugMessages.push(`Failed to find a matching route. Falling ` +\n `back to the default handler for ${method}.`);\n }\n handler = this._defaultHandlerMap.get(method);\n }\n if (!handler) {\n if (process.env.NODE_ENV !== 'production') {\n // No handler so Workbox will do nothing. If logs is set of debug\n // i.e. verbose, we should print out this information.\n logger.debug(`No route found for: ${getFriendlyURL(url)}`);\n }\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // We have a handler, meaning Workbox is going to handle the route.\n // print the routing details to the console.\n logger.groupCollapsed(`Router is responding to: ${getFriendlyURL(url)}`);\n debugMessages.forEach((msg) => {\n if (Array.isArray(msg)) {\n logger.log(...msg);\n }\n else {\n logger.log(msg);\n }\n });\n logger.groupEnd();\n }\n // Wrap in try and catch in case the handle method throws a synchronous\n // error. It should still callback to the catch handler.\n let responsePromise;\n try {\n responsePromise = handler.handle({ url, request, event, params });\n }\n catch (err) {\n responsePromise = Promise.reject(err);\n }\n // Get route's catch handler, if it exists\n const catchHandler = route && route.catchHandler;\n if (responsePromise instanceof Promise &&\n (this._catchHandler || catchHandler)) {\n responsePromise = responsePromise.catch(async (err) => {\n // If there's a route catch handler, process that first\n if (catchHandler) {\n if (process.env.NODE_ENV !== 'production') {\n // Still include URL here as it will be async from the console group\n // and may not make sense without the URL\n logger.groupCollapsed(`Error thrown when responding to: ` +\n ` ${getFriendlyURL(url)}. Falling back to route's Catch Handler.`);\n logger.error(`Error thrown by:`, route);\n logger.error(err);\n logger.groupEnd();\n }\n try {\n return await catchHandler.handle({ url, request, event, params });\n }\n catch (catchErr) {\n if (catchErr instanceof Error) {\n err = catchErr;\n }\n }\n }\n if (this._catchHandler) {\n if (process.env.NODE_ENV !== 'production') {\n // Still include URL here as it will be async from the console group\n // and may not make sense without the URL\n logger.groupCollapsed(`Error thrown when responding to: ` +\n ` ${getFriendlyURL(url)}. Falling back to global Catch Handler.`);\n logger.error(`Error thrown by:`, route);\n logger.error(err);\n logger.groupEnd();\n }\n return this._catchHandler.handle({ url, request, event });\n }\n throw err;\n });\n }\n return responsePromise;\n }\n /**\n * Checks a request and URL (and optionally an event) against the list of\n * registered routes, and if there's a match, returns the corresponding\n * route along with any params generated by the match.\n *\n * @param {Object} options\n * @param {URL} options.url\n * @param {boolean} options.sameOrigin The result of comparing `url.origin`\n * against the current origin.\n * @param {Request} options.request The request to match.\n * @param {Event} options.event The corresponding event.\n * @return {Object} An object with `route` and `params` properties.\n * They are populated if a matching route was found or `undefined`\n * otherwise.\n */\n findMatchingRoute({ url, sameOrigin, request, event, }) {\n const routes = this._routes.get(request.method) || [];\n for (const route of routes) {\n let params;\n // route.match returns type any, not possible to change right now.\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const matchResult = route.match({ url, sameOrigin, request, event });\n if (matchResult) {\n if (process.env.NODE_ENV !== 'production') {\n // Warn developers that using an async matchCallback is almost always\n // not the right thing to do.\n if (matchResult instanceof Promise) {\n logger.warn(`While routing ${getFriendlyURL(url)}, an async ` +\n `matchCallback function was used. Please convert the ` +\n `following route to use a synchronous matchCallback function:`, route);\n }\n }\n // See https://github.com/GoogleChrome/workbox/issues/2079\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n params = matchResult;\n if (Array.isArray(params) && params.length === 0) {\n // Instead of passing an empty array in as params, use undefined.\n params = undefined;\n }\n else if (matchResult.constructor === Object && // eslint-disable-line\n Object.keys(matchResult).length === 0) {\n // Instead of passing an empty object in as params, use undefined.\n params = undefined;\n }\n else if (typeof matchResult === 'boolean') {\n // For the boolean value true (rather than just something truth-y),\n // don't set params.\n // See https://github.com/GoogleChrome/workbox/pull/2134#issuecomment-513924353\n params = undefined;\n }\n // Return early if have a match.\n return { route, params };\n }\n }\n // If no match was found above, return and empty object.\n return {};\n }\n /**\n * Define a default `handler` that's called when no routes explicitly\n * match the incoming request.\n *\n * Each HTTP method ('GET', 'POST', etc.) gets its own default handler.\n *\n * Without a default handler, unmatched requests will go against the\n * network as if there were no service worker present.\n *\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resulting in a Response.\n * @param {string} [method='GET'] The HTTP method to associate with this\n * default handler. Each method has its own default.\n */\n setDefaultHandler(handler, method = defaultMethod) {\n this._defaultHandlerMap.set(method, normalizeHandler(handler));\n }\n /**\n * If a Route throws an error while handling a request, this `handler`\n * will be called and given a chance to provide a response.\n *\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resulting in a Response.\n */\n setCatchHandler(handler) {\n this._catchHandler = normalizeHandler(handler);\n }\n /**\n * Registers a route with the router.\n *\n * @param {workbox-routing.Route} route The route to register.\n */\n registerRoute(route) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(route, 'object', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route',\n });\n assert.hasMethod(route, 'match', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route',\n });\n assert.isType(route.handler, 'object', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route',\n });\n assert.hasMethod(route.handler, 'handle', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route.handler',\n });\n assert.isType(route.method, 'string', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route.method',\n });\n }\n if (!this._routes.has(route.method)) {\n this._routes.set(route.method, []);\n }\n // Give precedence to all of the earlier routes by adding this additional\n // route to the end of the array.\n this._routes.get(route.method).push(route);\n }\n /**\n * Unregisters a route with the router.\n *\n * @param {workbox-routing.Route} route The route to unregister.\n */\n unregisterRoute(route) {\n if (!this._routes.has(route.method)) {\n throw new WorkboxError('unregister-route-but-not-found-with-method', {\n method: route.method,\n });\n }\n const routeIndex = this._routes.get(route.method).indexOf(route);\n if (routeIndex > -1) {\n this._routes.get(route.method).splice(routeIndex, 1);\n }\n else {\n throw new WorkboxError('unregister-route-route-not-registered');\n }\n }\n}\nexport { Router };\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 { Router } from '../Router.js';\nimport '../_version.js';\nlet defaultRouter;\n/**\n * Creates a new, singleton Router instance if one does not exist. If one\n * does already exist, that instance is returned.\n *\n * @private\n * @return {Router}\n */\nexport const getOrCreateDefaultRouter = () => {\n if (!defaultRouter) {\n defaultRouter = new Router();\n // The helpers that use the default Router assume these listeners exist.\n defaultRouter.addFetchListener();\n defaultRouter.addCacheListener();\n }\n return defaultRouter;\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 { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { Route } from './Route.js';\nimport { RegExpRoute } from './RegExpRoute.js';\nimport { getOrCreateDefaultRouter } from './utils/getOrCreateDefaultRouter.js';\nimport './_version.js';\n/**\n * Easily register a RegExp, string, or function with a caching\n * strategy to a singleton Router instance.\n *\n * This method will generate a Route for you if needed and\n * call {@link workbox-routing.Router#registerRoute}.\n *\n * @param {RegExp|string|workbox-routing.Route~matchCallback|workbox-routing.Route} capture\n * If the capture param is a `Route`, all other arguments will be ignored.\n * @param {workbox-routing~handlerCallback} [handler] A callback\n * function that returns a Promise resulting in a Response. This parameter\n * is required if `capture` is not a `Route` object.\n * @param {string} [method='GET'] The HTTP method to match the Route\n * against.\n * @return {workbox-routing.Route} The generated `Route`.\n *\n * @memberof workbox-routing\n */\nfunction registerRoute(capture, handler, method) {\n let route;\n if (typeof capture === 'string') {\n const captureUrl = new URL(capture, location.href);\n if (process.env.NODE_ENV !== 'production') {\n if (!(capture.startsWith('/') || capture.startsWith('http'))) {\n throw new WorkboxError('invalid-string', {\n moduleName: 'workbox-routing',\n funcName: 'registerRoute',\n paramName: 'capture',\n });\n }\n // We want to check if Express-style wildcards are in the pathname only.\n // TODO: Remove this log message in v4.\n const valueToCheck = capture.startsWith('http')\n ? captureUrl.pathname\n : capture;\n // See https://github.com/pillarjs/path-to-regexp#parameters\n const wildcards = '[*:?+]';\n if (new RegExp(`${wildcards}`).exec(valueToCheck)) {\n logger.debug(`The '$capture' parameter contains an Express-style wildcard ` +\n `character (${wildcards}). Strings are now always interpreted as ` +\n `exact matches; use a RegExp for partial or wildcard matches.`);\n }\n }\n const matchCallback = ({ url }) => {\n if (process.env.NODE_ENV !== 'production') {\n if (url.pathname === captureUrl.pathname &&\n url.origin !== captureUrl.origin) {\n logger.debug(`${capture} only partially matches the cross-origin URL ` +\n `${url.toString()}. This route will only handle cross-origin requests ` +\n `if they match the entire URL.`);\n }\n }\n return url.href === captureUrl.href;\n };\n // If `capture` is a string then `handler` and `method` must be present.\n route = new Route(matchCallback, handler, method);\n }\n else if (capture instanceof RegExp) {\n // If `capture` is a `RegExp` then `handler` and `method` must be present.\n route = new RegExpRoute(capture, handler, method);\n }\n else if (typeof capture === 'function') {\n // If `capture` is a function then `handler` and `method` must be present.\n route = new Route(capture, handler, method);\n }\n else if (capture instanceof Route) {\n route = capture;\n }\n else {\n throw new WorkboxError('unsupported-route-type', {\n moduleName: 'workbox-routing',\n funcName: 'registerRoute',\n paramName: 'capture',\n });\n }\n const defaultRouter = getOrCreateDefaultRouter();\n defaultRouter.registerRoute(route);\n return route;\n}\nexport { registerRoute };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:strategies:6.5.1'] && _();\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';\nexport const cacheOkAndOpaquePlugin = {\n /**\n * Returns a valid response (to allow caching) if the status is 200 (OK) or\n * 0 (opaque).\n *\n * @param {Object} options\n * @param {Response} options.response\n * @return {Response|null}\n *\n * @private\n */\n cacheWillUpdate: async ({ response }) => {\n if (response.status === 200 || response.status === 0) {\n return response;\n }\n return null;\n },\n};\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';\nconst _cacheNameDetails = {\n googleAnalytics: 'googleAnalytics',\n precache: 'precache-v2',\n prefix: 'workbox',\n runtime: 'runtime',\n suffix: typeof registration !== 'undefined' ? registration.scope : '',\n};\nconst _createCacheName = (cacheName) => {\n return [_cacheNameDetails.prefix, cacheName, _cacheNameDetails.suffix]\n .filter((value) => value && value.length > 0)\n .join('-');\n};\nconst eachCacheNameDetail = (fn) => {\n for (const key of Object.keys(_cacheNameDetails)) {\n fn(key);\n }\n};\nexport const cacheNames = {\n updateDetails: (details) => {\n eachCacheNameDetail((key) => {\n if (typeof details[key] === 'string') {\n _cacheNameDetails[key] = details[key];\n }\n });\n },\n getGoogleAnalyticsName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.googleAnalytics);\n },\n getPrecacheName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.precache);\n },\n getPrefix: () => {\n return _cacheNameDetails.prefix;\n },\n getRuntimeName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.runtime);\n },\n getSuffix: () => {\n return _cacheNameDetails.suffix;\n },\n};\n","/*\n Copyright 2020 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';\nfunction stripParams(fullURL, ignoreParams) {\n const strippedURL = new URL(fullURL);\n for (const param of ignoreParams) {\n strippedURL.searchParams.delete(param);\n }\n return strippedURL.href;\n}\n/**\n * Matches an item in the cache, ignoring specific URL params. This is similar\n * to the `ignoreSearch` option, but it allows you to ignore just specific\n * params (while continuing to match on the others).\n *\n * @private\n * @param {Cache} cache\n * @param {Request} request\n * @param {Object} matchOptions\n * @param {Array} ignoreParams\n * @return {Promise}\n */\nasync function cacheMatchIgnoreParams(cache, request, ignoreParams, matchOptions) {\n const strippedRequestURL = stripParams(request.url, ignoreParams);\n // If the request doesn't include any ignored params, match as normal.\n if (request.url === strippedRequestURL) {\n return cache.match(request, matchOptions);\n }\n // Otherwise, match by comparing keys\n const keysOptions = Object.assign(Object.assign({}, matchOptions), { ignoreSearch: true });\n const cacheKeys = await cache.keys(request, keysOptions);\n for (const cacheKey of cacheKeys) {\n const strippedCacheKeyURL = stripParams(cacheKey.url, ignoreParams);\n if (strippedRequestURL === strippedCacheKeyURL) {\n return cache.match(cacheKey, matchOptions);\n }\n }\n return;\n}\nexport { cacheMatchIgnoreParams };\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 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// Callbacks to be executed whenever there's a quota error.\n// Can't change Function type right now.\n// eslint-disable-next-line @typescript-eslint/ban-types\nconst quotaErrorCallbacks = new Set();\nexport { quotaErrorCallbacks };\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 { logger } from '../_private/logger.js';\nimport { quotaErrorCallbacks } from '../models/quotaErrorCallbacks.js';\nimport '../_version.js';\n/**\n * Runs all of the callback functions, one at a time sequentially, in the order\n * in which they were registered.\n *\n * @memberof workbox-core\n * @private\n */\nasync function executeQuotaErrorCallbacks() {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`About to run ${quotaErrorCallbacks.size} ` +\n `callbacks to clean up caches.`);\n }\n for (const callback of quotaErrorCallbacks) {\n await callback();\n if (process.env.NODE_ENV !== 'production') {\n logger.log(callback, 'is complete.');\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Finished running callbacks.');\n }\n}\nexport { executeQuotaErrorCallbacks };\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 * Returns a promise that resolves and the passed number of milliseconds.\n * This utility is an async/await-friendly version of `setTimeout`.\n *\n * @param {number} ms\n * @return {Promise}\n * @private\n */\nexport function timeout(ms) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n","/*\n Copyright 2020 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 { assert } from 'workbox-core/_private/assert.js';\nimport { cacheMatchIgnoreParams } from 'workbox-core/_private/cacheMatchIgnoreParams.js';\nimport { Deferred } from 'workbox-core/_private/Deferred.js';\nimport { executeQuotaErrorCallbacks } from 'workbox-core/_private/executeQuotaErrorCallbacks.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { timeout } from 'workbox-core/_private/timeout.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport './_version.js';\nfunction toRequest(input) {\n return typeof input === 'string' ? new Request(input) : input;\n}\n/**\n * A class created every time a Strategy instance instance calls\n * {@link workbox-strategies.Strategy~handle} or\n * {@link workbox-strategies.Strategy~handleAll} that wraps all fetch and\n * cache actions around plugin callbacks and keeps track of when the strategy\n * is \"done\" (i.e. all added `event.waitUntil()` promises have resolved).\n *\n * @memberof workbox-strategies\n */\nclass StrategyHandler {\n /**\n * Creates a new instance associated with the passed strategy and event\n * that's handling the request.\n *\n * The constructor also initializes the state that will be passed to each of\n * the plugins handling this request.\n *\n * @param {workbox-strategies.Strategy} strategy\n * @param {Object} options\n * @param {Request|string} options.request A request to run this strategy for.\n * @param {ExtendableEvent} options.event The event associated with the\n * request.\n * @param {URL} [options.url]\n * @param {*} [options.params] The return value from the\n * {@link workbox-routing~matchCallback} (if applicable).\n */\n constructor(strategy, options) {\n this._cacheKeys = {};\n /**\n * The request the strategy is performing (passed to the strategy's\n * `handle()` or `handleAll()` method).\n * @name request\n * @instance\n * @type {Request}\n * @memberof workbox-strategies.StrategyHandler\n */\n /**\n * The event associated with this request.\n * @name event\n * @instance\n * @type {ExtendableEvent}\n * @memberof workbox-strategies.StrategyHandler\n */\n /**\n * A `URL` instance of `request.url` (if passed to the strategy's\n * `handle()` or `handleAll()` method).\n * Note: the `url` param will be present if the strategy was invoked\n * from a workbox `Route` object.\n * @name url\n * @instance\n * @type {URL|undefined}\n * @memberof workbox-strategies.StrategyHandler\n */\n /**\n * A `param` value (if passed to the strategy's\n * `handle()` or `handleAll()` method).\n * Note: the `param` param will be present if the strategy was invoked\n * from a workbox `Route` object and the\n * {@link workbox-routing~matchCallback} returned\n * a truthy value (it will be that value).\n * @name params\n * @instance\n * @type {*|undefined}\n * @memberof workbox-strategies.StrategyHandler\n */\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(options.event, ExtendableEvent, {\n moduleName: 'workbox-strategies',\n className: 'StrategyHandler',\n funcName: 'constructor',\n paramName: 'options.event',\n });\n }\n Object.assign(this, options);\n this.event = options.event;\n this._strategy = strategy;\n this._handlerDeferred = new Deferred();\n this._extendLifetimePromises = [];\n // Copy the plugins list (since it's mutable on the strategy),\n // so any mutations don't affect this handler instance.\n this._plugins = [...strategy.plugins];\n this._pluginStateMap = new Map();\n for (const plugin of this._plugins) {\n this._pluginStateMap.set(plugin, {});\n }\n this.event.waitUntil(this._handlerDeferred.promise);\n }\n /**\n * Fetches a given request (and invokes any applicable plugin callback\n * methods) using the `fetchOptions` (for non-navigation requests) and\n * `plugins` defined on the `Strategy` object.\n *\n * The following plugin lifecycle methods are invoked when using this method:\n * - `requestWillFetch()`\n * - `fetchDidSucceed()`\n * - `fetchDidFail()`\n *\n * @param {Request|string} input The URL or request to fetch.\n * @return {Promise}\n */\n async fetch(input) {\n const { event } = this;\n let request = toRequest(input);\n if (request.mode === 'navigate' &&\n event instanceof FetchEvent &&\n event.preloadResponse) {\n const possiblePreloadResponse = (await event.preloadResponse);\n if (possiblePreloadResponse) {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`Using a preloaded navigation response for ` +\n `'${getFriendlyURL(request.url)}'`);\n }\n return possiblePreloadResponse;\n }\n }\n // If there is a fetchDidFail plugin, we need to save a clone of the\n // original request before it's either modified by a requestWillFetch\n // plugin or before the original request's body is consumed via fetch().\n const originalRequest = this.hasCallback('fetchDidFail')\n ? request.clone()\n : null;\n try {\n for (const cb of this.iterateCallbacks('requestWillFetch')) {\n request = await cb({ request: request.clone(), event });\n }\n }\n catch (err) {\n if (err instanceof Error) {\n throw new WorkboxError('plugin-error-request-will-fetch', {\n thrownErrorMessage: err.message,\n });\n }\n }\n // The request can be altered by plugins with `requestWillFetch` making\n // the original request (most likely from a `fetch` event) different\n // from the Request we make. Pass both to `fetchDidFail` to aid debugging.\n const pluginFilteredRequest = request.clone();\n try {\n let fetchResponse;\n // See https://github.com/GoogleChrome/workbox/issues/1796\n fetchResponse = await fetch(request, request.mode === 'navigate' ? undefined : this._strategy.fetchOptions);\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Network request for ` +\n `'${getFriendlyURL(request.url)}' returned a response with ` +\n `status '${fetchResponse.status}'.`);\n }\n for (const callback of this.iterateCallbacks('fetchDidSucceed')) {\n fetchResponse = await callback({\n event,\n request: pluginFilteredRequest,\n response: fetchResponse,\n });\n }\n return fetchResponse;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`Network request for ` +\n `'${getFriendlyURL(request.url)}' threw an error.`, error);\n }\n // `originalRequest` will only exist if a `fetchDidFail` callback\n // is being used (see above).\n if (originalRequest) {\n await this.runCallbacks('fetchDidFail', {\n error: error,\n event,\n originalRequest: originalRequest.clone(),\n request: pluginFilteredRequest.clone(),\n });\n }\n throw error;\n }\n }\n /**\n * Calls `this.fetch()` and (in the background) runs `this.cachePut()` on\n * the response generated by `this.fetch()`.\n *\n * The call to `this.cachePut()` automatically invokes `this.waitUntil()`,\n * so you do not have to manually call `waitUntil()` on the event.\n *\n * @param {Request|string} input The request or URL to fetch and cache.\n * @return {Promise}\n */\n async fetchAndCachePut(input) {\n const response = await this.fetch(input);\n const responseClone = response.clone();\n void this.waitUntil(this.cachePut(input, responseClone));\n return response;\n }\n /**\n * Matches a request from the cache (and invokes any applicable plugin\n * callback methods) using the `cacheName`, `matchOptions`, and `plugins`\n * defined on the strategy object.\n *\n * The following plugin lifecycle methods are invoked when using this method:\n * - cacheKeyWillByUsed()\n * - cachedResponseWillByUsed()\n *\n * @param {Request|string} key The Request or URL to use as the cache key.\n * @return {Promise} A matching response, if found.\n */\n async cacheMatch(key) {\n const request = toRequest(key);\n let cachedResponse;\n const { cacheName, matchOptions } = this._strategy;\n const effectiveRequest = await this.getCacheKey(request, 'read');\n const multiMatchOptions = Object.assign(Object.assign({}, matchOptions), { cacheName });\n cachedResponse = await caches.match(effectiveRequest, multiMatchOptions);\n if (process.env.NODE_ENV !== 'production') {\n if (cachedResponse) {\n logger.debug(`Found a cached response in '${cacheName}'.`);\n }\n else {\n logger.debug(`No cached response found in '${cacheName}'.`);\n }\n }\n for (const callback of this.iterateCallbacks('cachedResponseWillBeUsed')) {\n cachedResponse =\n (await callback({\n cacheName,\n matchOptions,\n cachedResponse,\n request: effectiveRequest,\n event: this.event,\n })) || undefined;\n }\n return cachedResponse;\n }\n /**\n * Puts a request/response pair in the cache (and invokes any applicable\n * plugin callback methods) using the `cacheName` and `plugins` defined on\n * the strategy object.\n *\n * The following plugin lifecycle methods are invoked when using this method:\n * - cacheKeyWillByUsed()\n * - cacheWillUpdate()\n * - cacheDidUpdate()\n *\n * @param {Request|string} key The request or URL to use as the cache key.\n * @param {Response} response The response to cache.\n * @return {Promise} `false` if a cacheWillUpdate caused the response\n * not be cached, and `true` otherwise.\n */\n async cachePut(key, response) {\n const request = toRequest(key);\n // Run in the next task to avoid blocking other cache reads.\n // https://github.com/w3c/ServiceWorker/issues/1397\n await timeout(0);\n const effectiveRequest = await this.getCacheKey(request, 'write');\n if (process.env.NODE_ENV !== 'production') {\n if (effectiveRequest.method && effectiveRequest.method !== 'GET') {\n throw new WorkboxError('attempt-to-cache-non-get-request', {\n url: getFriendlyURL(effectiveRequest.url),\n method: effectiveRequest.method,\n });\n }\n // See https://github.com/GoogleChrome/workbox/issues/2818\n const vary = response.headers.get('Vary');\n if (vary) {\n logger.debug(`The response for ${getFriendlyURL(effectiveRequest.url)} ` +\n `has a 'Vary: ${vary}' header. ` +\n `Consider setting the {ignoreVary: true} option on your strategy ` +\n `to ensure cache matching and deletion works as expected.`);\n }\n }\n if (!response) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(`Cannot cache non-existent response for ` +\n `'${getFriendlyURL(effectiveRequest.url)}'.`);\n }\n throw new WorkboxError('cache-put-with-no-response', {\n url: getFriendlyURL(effectiveRequest.url),\n });\n }\n const responseToCache = await this._ensureResponseSafeToCache(response);\n if (!responseToCache) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Response '${getFriendlyURL(effectiveRequest.url)}' ` +\n `will not be cached.`, responseToCache);\n }\n return false;\n }\n const { cacheName, matchOptions } = this._strategy;\n const cache = await self.caches.open(cacheName);\n const hasCacheUpdateCallback = this.hasCallback('cacheDidUpdate');\n const oldResponse = hasCacheUpdateCallback\n ? await cacheMatchIgnoreParams(\n // TODO(philipwalton): the `__WB_REVISION__` param is a precaching\n // feature. Consider into ways to only add this behavior if using\n // precaching.\n cache, effectiveRequest.clone(), ['__WB_REVISION__'], matchOptions)\n : null;\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Updating the '${cacheName}' cache with a new Response ` +\n `for ${getFriendlyURL(effectiveRequest.url)}.`);\n }\n try {\n await cache.put(effectiveRequest, hasCacheUpdateCallback ? responseToCache.clone() : responseToCache);\n }\n catch (error) {\n if (error instanceof Error) {\n // See https://developer.mozilla.org/en-US/docs/Web/API/DOMException#exception-QuotaExceededError\n if (error.name === 'QuotaExceededError') {\n await executeQuotaErrorCallbacks();\n }\n throw error;\n }\n }\n for (const callback of this.iterateCallbacks('cacheDidUpdate')) {\n await callback({\n cacheName,\n oldResponse,\n newResponse: responseToCache.clone(),\n request: effectiveRequest,\n event: this.event,\n });\n }\n return true;\n }\n /**\n * Checks the list of plugins for the `cacheKeyWillBeUsed` callback, and\n * executes any of those callbacks found in sequence. The final `Request`\n * object returned by the last plugin is treated as the cache key for cache\n * reads and/or writes. If no `cacheKeyWillBeUsed` plugin callbacks have\n * been registered, the passed request is returned unmodified\n *\n * @param {Request} request\n * @param {string} mode\n * @return {Promise}\n */\n async getCacheKey(request, mode) {\n const key = `${request.url} | ${mode}`;\n if (!this._cacheKeys[key]) {\n let effectiveRequest = request;\n for (const callback of this.iterateCallbacks('cacheKeyWillBeUsed')) {\n effectiveRequest = toRequest(await callback({\n mode,\n request: effectiveRequest,\n event: this.event,\n // params has a type any can't change right now.\n params: this.params, // eslint-disable-line\n }));\n }\n this._cacheKeys[key] = effectiveRequest;\n }\n return this._cacheKeys[key];\n }\n /**\n * Returns true if the strategy has at least one plugin with the given\n * callback.\n *\n * @param {string} name The name of the callback to check for.\n * @return {boolean}\n */\n hasCallback(name) {\n for (const plugin of this._strategy.plugins) {\n if (name in plugin) {\n return true;\n }\n }\n return false;\n }\n /**\n * Runs all plugin callbacks matching the given name, in order, passing the\n * given param object (merged ith the current plugin state) as the only\n * argument.\n *\n * Note: since this method runs all plugins, it's not suitable for cases\n * where the return value of a callback needs to be applied prior to calling\n * the next callback. See\n * {@link workbox-strategies.StrategyHandler#iterateCallbacks}\n * below for how to handle that case.\n *\n * @param {string} name The name of the callback to run within each plugin.\n * @param {Object} param The object to pass as the first (and only) param\n * when executing each callback. This object will be merged with the\n * current plugin state prior to callback execution.\n */\n async runCallbacks(name, param) {\n for (const callback of this.iterateCallbacks(name)) {\n // TODO(philipwalton): not sure why `any` is needed. It seems like\n // this should work with `as WorkboxPluginCallbackParam[C]`.\n await callback(param);\n }\n }\n /**\n * Accepts a callback and returns an iterable of matching plugin callbacks,\n * where each callback is wrapped with the current handler state (i.e. when\n * you call each callback, whatever object parameter you pass it will\n * be merged with the plugin's current state).\n *\n * @param {string} name The name fo the callback to run\n * @return {Array}\n */\n *iterateCallbacks(name) {\n for (const plugin of this._strategy.plugins) {\n if (typeof plugin[name] === 'function') {\n const state = this._pluginStateMap.get(plugin);\n const statefulCallback = (param) => {\n const statefulParam = Object.assign(Object.assign({}, param), { state });\n // TODO(philipwalton): not sure why `any` is needed. It seems like\n // this should work with `as WorkboxPluginCallbackParam[C]`.\n return plugin[name](statefulParam);\n };\n yield statefulCallback;\n }\n }\n }\n /**\n * Adds a promise to the\n * [extend lifetime promises]{@link https://w3c.github.io/ServiceWorker/#extendableevent-extend-lifetime-promises}\n * of the event event associated with the request being handled (usually a\n * `FetchEvent`).\n *\n * Note: you can await\n * {@link workbox-strategies.StrategyHandler~doneWaiting}\n * to know when all added promises have settled.\n *\n * @param {Promise} promise A promise to add to the extend lifetime promises\n * of the event that triggered the request.\n */\n waitUntil(promise) {\n this._extendLifetimePromises.push(promise);\n return promise;\n }\n /**\n * Returns a promise that resolves once all promises passed to\n * {@link workbox-strategies.StrategyHandler~waitUntil}\n * have settled.\n *\n * Note: any work done after `doneWaiting()` settles should be manually\n * passed to an event's `waitUntil()` method (not this handler's\n * `waitUntil()` method), otherwise the service worker thread my be killed\n * prior to your work completing.\n */\n async doneWaiting() {\n let promise;\n while ((promise = this._extendLifetimePromises.shift())) {\n await promise;\n }\n }\n /**\n * Stops running the strategy and immediately resolves any pending\n * `waitUntil()` promises.\n */\n destroy() {\n this._handlerDeferred.resolve(null);\n }\n /**\n * This method will call cacheWillUpdate on the available plugins (or use\n * status === 200) to determine if the Response is safe and valid to cache.\n *\n * @param {Request} options.request\n * @param {Response} options.response\n * @return {Promise}\n *\n * @private\n */\n async _ensureResponseSafeToCache(response) {\n let responseToCache = response;\n let pluginsUsed = false;\n for (const callback of this.iterateCallbacks('cacheWillUpdate')) {\n responseToCache =\n (await callback({\n request: this.request,\n response: responseToCache,\n event: this.event,\n })) || undefined;\n pluginsUsed = true;\n if (!responseToCache) {\n break;\n }\n }\n if (!pluginsUsed) {\n if (responseToCache && responseToCache.status !== 200) {\n responseToCache = undefined;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (responseToCache) {\n if (responseToCache.status !== 200) {\n if (responseToCache.status === 0) {\n logger.warn(`The response for '${this.request.url}' ` +\n `is an opaque response. The caching strategy that you're ` +\n `using will not cache opaque responses by default.`);\n }\n else {\n logger.debug(`The response for '${this.request.url}' ` +\n `returned a status code of '${response.status}' and won't ` +\n `be cached as a result.`);\n }\n }\n }\n }\n }\n return responseToCache;\n }\n}\nexport { StrategyHandler };\n","/*\n Copyright 2020 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 { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { StrategyHandler } from './StrategyHandler.js';\nimport './_version.js';\n/**\n * An abstract base class that all other strategy classes must extend from:\n *\n * @memberof workbox-strategies\n */\nclass Strategy {\n /**\n * Creates a new instance of the strategy and sets all documented option\n * properties as public instance properties.\n *\n * Note: if a custom strategy class extends the base Strategy class and does\n * not need more than these properties, it does not need to define its own\n * constructor.\n *\n * @param {Object} [options]\n * @param {string} [options.cacheName] Cache name to store and retrieve\n * requests. Defaults to the cache names provided by\n * {@link workbox-core.cacheNames}.\n * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins}\n * to use in conjunction with this caching strategy.\n * @param {Object} [options.fetchOptions] Values passed along to the\n * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters)\n * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796)\n * `fetch()` requests made by this strategy.\n * @param {Object} [options.matchOptions] The\n * [`CacheQueryOptions`]{@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions}\n * for any `cache.match()` or `cache.put()` calls made by this strategy.\n */\n constructor(options = {}) {\n /**\n * Cache name to store and retrieve\n * requests. Defaults to the cache names provided by\n * {@link workbox-core.cacheNames}.\n *\n * @type {string}\n */\n this.cacheName = cacheNames.getRuntimeName(options.cacheName);\n /**\n * The list\n * [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins}\n * used by this strategy.\n *\n * @type {Array}\n */\n this.plugins = options.plugins || [];\n /**\n * Values passed along to the\n * [`init`]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters}\n * of all fetch() requests made by this strategy.\n *\n * @type {Object}\n */\n this.fetchOptions = options.fetchOptions;\n /**\n * The\n * [`CacheQueryOptions`]{@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions}\n * for any `cache.match()` or `cache.put()` calls made by this strategy.\n *\n * @type {Object}\n */\n this.matchOptions = options.matchOptions;\n }\n /**\n * Perform a request strategy and returns a `Promise` that will resolve with\n * a `Response`, invoking all relevant plugin callbacks.\n *\n * When a strategy instance is registered with a Workbox\n * {@link workbox-routing.Route}, this method is automatically\n * called when the route matches.\n *\n * Alternatively, this method can be used in a standalone `FetchEvent`\n * listener by passing it to `event.respondWith()`.\n *\n * @param {FetchEvent|Object} options A `FetchEvent` or an object with the\n * properties listed below.\n * @param {Request|string} options.request A request to run this strategy for.\n * @param {ExtendableEvent} options.event The event associated with the\n * request.\n * @param {URL} [options.url]\n * @param {*} [options.params]\n */\n handle(options) {\n const [responseDone] = this.handleAll(options);\n return responseDone;\n }\n /**\n * Similar to {@link workbox-strategies.Strategy~handle}, but\n * instead of just returning a `Promise` that resolves to a `Response` it\n * it will return an tuple of `[response, done]` promises, where the former\n * (`response`) is equivalent to what `handle()` returns, and the latter is a\n * Promise that will resolve once any promises that were added to\n * `event.waitUntil()` as part of performing the strategy have completed.\n *\n * You can await the `done` promise to ensure any extra work performed by\n * the strategy (usually caching responses) completes successfully.\n *\n * @param {FetchEvent|Object} options A `FetchEvent` or an object with the\n * properties listed below.\n * @param {Request|string} options.request A request to run this strategy for.\n * @param {ExtendableEvent} options.event The event associated with the\n * request.\n * @param {URL} [options.url]\n * @param {*} [options.params]\n * @return {Array} A tuple of [response, done]\n * promises that can be used to determine when the response resolves as\n * well as when the handler has completed all its work.\n */\n handleAll(options) {\n // Allow for flexible options to be passed.\n if (options instanceof FetchEvent) {\n options = {\n event: options,\n request: options.request,\n };\n }\n const event = options.event;\n const request = typeof options.request === 'string'\n ? new Request(options.request)\n : options.request;\n const params = 'params' in options ? options.params : undefined;\n const handler = new StrategyHandler(this, { event, request, params });\n const responseDone = this._getResponse(handler, request, event);\n const handlerDone = this._awaitComplete(responseDone, handler, request, event);\n // Return an array of promises, suitable for use with Promise.all().\n return [responseDone, handlerDone];\n }\n async _getResponse(handler, request, event) {\n await handler.runCallbacks('handlerWillStart', { event, request });\n let response = undefined;\n try {\n response = await this._handle(request, handler);\n // The \"official\" Strategy subclasses all throw this error automatically,\n // but in case a third-party Strategy doesn't, ensure that we have a\n // consistent failure when there's no response or an error response.\n if (!response || response.type === 'error') {\n throw new WorkboxError('no-response', { url: request.url });\n }\n }\n catch (error) {\n if (error instanceof Error) {\n for (const callback of handler.iterateCallbacks('handlerDidError')) {\n response = await callback({ error, event, request });\n if (response) {\n break;\n }\n }\n }\n if (!response) {\n throw error;\n }\n else if (process.env.NODE_ENV !== 'production') {\n logger.log(`While responding to '${getFriendlyURL(request.url)}', ` +\n `an ${error instanceof Error ? error.toString() : ''} error occurred. Using a fallback response provided by ` +\n `a handlerDidError plugin.`);\n }\n }\n for (const callback of handler.iterateCallbacks('handlerWillRespond')) {\n response = await callback({ event, request, response });\n }\n return response;\n }\n async _awaitComplete(responseDone, handler, request, event) {\n let response;\n let error;\n try {\n response = await responseDone;\n }\n catch (error) {\n // Ignore errors, as response errors should be caught via the `response`\n // promise above. The `done` promise will only throw for errors in\n // promises passed to `handler.waitUntil()`.\n }\n try {\n await handler.runCallbacks('handlerDidRespond', {\n event,\n request,\n response,\n });\n await handler.doneWaiting();\n }\n catch (waitUntilError) {\n if (waitUntilError instanceof Error) {\n error = waitUntilError;\n }\n }\n await handler.runCallbacks('handlerDidComplete', {\n event,\n request,\n response,\n error: error,\n });\n handler.destroy();\n if (error) {\n throw error;\n }\n }\n}\nexport { Strategy };\n/**\n * Classes extending the `Strategy` based class should implement this method,\n * and leverage the {@link workbox-strategies.StrategyHandler}\n * arg to perform all fetching and cache logic, which will ensure all relevant\n * cache, cache options, fetch options and plugins are used (per the current\n * strategy instance).\n *\n * @name _handle\n * @instance\n * @abstract\n * @function\n * @param {Request} request\n * @param {workbox-strategies.StrategyHandler} handler\n * @return {Promise}\n *\n * @memberof workbox-strategies.Strategy\n */\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 { logger } from 'workbox-core/_private/logger.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport '../_version.js';\nexport const messages = {\n strategyStart: (strategyName, request) => `Using ${strategyName} to respond to '${getFriendlyURL(request.url)}'`,\n printFinalResponse: (response) => {\n if (response) {\n logger.groupCollapsed(`View the final response here.`);\n logger.log(response || '[No response returned]');\n logger.groupEnd();\n }\n },\n};\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 { assert } from 'workbox-core/_private/assert.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { cacheOkAndOpaquePlugin } from './plugins/cacheOkAndOpaquePlugin.js';\nimport { Strategy } from './Strategy.js';\nimport { messages } from './utils/messages.js';\nimport './_version.js';\n/**\n * An implementation of a\n * [network first](https://developer.chrome.com/docs/workbox/caching-strategies-overview/#network-first-falling-back-to-cache)\n * request strategy.\n *\n * By default, this strategy will cache responses with a 200 status code as\n * well as [opaque responses](https://developer.chrome.com/docs/workbox/caching-resources-during-runtime/#opaque-responses).\n * Opaque responses are are cross-origin requests where the response doesn't\n * support [CORS](https://enable-cors.org/).\n *\n * If the network request fails, and there is no cache match, this will throw\n * a `WorkboxError` exception.\n *\n * @extends workbox-strategies.Strategy\n * @memberof workbox-strategies\n */\nclass NetworkFirst extends Strategy {\n /**\n * @param {Object} [options]\n * @param {string} [options.cacheName] Cache name to store and retrieve\n * requests. Defaults to cache names provided by\n * {@link workbox-core.cacheNames}.\n * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins}\n * to use in conjunction with this caching strategy.\n * @param {Object} [options.fetchOptions] Values passed along to the\n * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters)\n * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796)\n * `fetch()` requests made by this strategy.\n * @param {Object} [options.matchOptions] [`CacheQueryOptions`](https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions)\n * @param {number} [options.networkTimeoutSeconds] If set, any network requests\n * that fail to respond within the timeout will fallback to the cache.\n *\n * This option can be used to combat\n * \"[lie-fi]{@link https://developers.google.com/web/fundamentals/performance/poor-connectivity/#lie-fi}\"\n * scenarios.\n */\n constructor(options = {}) {\n super(options);\n // If this instance contains no plugins with a 'cacheWillUpdate' callback,\n // prepend the `cacheOkAndOpaquePlugin` plugin to the plugins list.\n if (!this.plugins.some((p) => 'cacheWillUpdate' in p)) {\n this.plugins.unshift(cacheOkAndOpaquePlugin);\n }\n this._networkTimeoutSeconds = options.networkTimeoutSeconds || 0;\n if (process.env.NODE_ENV !== 'production') {\n if (this._networkTimeoutSeconds) {\n assert.isType(this._networkTimeoutSeconds, 'number', {\n moduleName: 'workbox-strategies',\n className: this.constructor.name,\n funcName: 'constructor',\n paramName: 'networkTimeoutSeconds',\n });\n }\n }\n }\n /**\n * @private\n * @param {Request|string} request A request to run this strategy for.\n * @param {workbox-strategies.StrategyHandler} handler The event that\n * triggered the request.\n * @return {Promise}\n */\n async _handle(request, handler) {\n const logs = [];\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(request, Request, {\n moduleName: 'workbox-strategies',\n className: this.constructor.name,\n funcName: 'handle',\n paramName: 'makeRequest',\n });\n }\n const promises = [];\n let timeoutId;\n if (this._networkTimeoutSeconds) {\n const { id, promise } = this._getTimeoutPromise({ request, logs, handler });\n timeoutId = id;\n promises.push(promise);\n }\n const networkPromise = this._getNetworkPromise({\n timeoutId,\n request,\n logs,\n handler,\n });\n promises.push(networkPromise);\n const response = await handler.waitUntil((async () => {\n // Promise.race() will resolve as soon as the first promise resolves.\n return ((await handler.waitUntil(Promise.race(promises))) ||\n // If Promise.race() resolved with null, it might be due to a network\n // timeout + a cache miss. If that were to happen, we'd rather wait until\n // the networkPromise resolves instead of returning null.\n // Note that it's fine to await an already-resolved promise, so we don't\n // have to check to see if it's still \"in flight\".\n (await networkPromise));\n })());\n if (process.env.NODE_ENV !== 'production') {\n logger.groupCollapsed(messages.strategyStart(this.constructor.name, request));\n for (const log of logs) {\n logger.log(log);\n }\n messages.printFinalResponse(response);\n logger.groupEnd();\n }\n if (!response) {\n throw new WorkboxError('no-response', { url: request.url });\n }\n return response;\n }\n /**\n * @param {Object} options\n * @param {Request} options.request\n * @param {Array} options.logs A reference to the logs array\n * @param {Event} options.event\n * @return {Promise}\n *\n * @private\n */\n _getTimeoutPromise({ request, logs, handler, }) {\n let timeoutId;\n const timeoutPromise = new Promise((resolve) => {\n const onNetworkTimeout = async () => {\n if (process.env.NODE_ENV !== 'production') {\n logs.push(`Timing out the network response at ` +\n `${this._networkTimeoutSeconds} seconds.`);\n }\n resolve(await handler.cacheMatch(request));\n };\n timeoutId = setTimeout(onNetworkTimeout, this._networkTimeoutSeconds * 1000);\n });\n return {\n promise: timeoutPromise,\n id: timeoutId,\n };\n }\n /**\n * @param {Object} options\n * @param {number|undefined} options.timeoutId\n * @param {Request} options.request\n * @param {Array} options.logs A reference to the logs Array.\n * @param {Event} options.event\n * @return {Promise}\n *\n * @private\n */\n async _getNetworkPromise({ timeoutId, request, logs, handler, }) {\n let error;\n let response;\n try {\n response = await handler.fetchAndCachePut(request);\n }\n catch (fetchError) {\n if (fetchError instanceof Error) {\n error = fetchError;\n }\n }\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n if (process.env.NODE_ENV !== 'production') {\n if (response) {\n logs.push(`Got response from network.`);\n }\n else {\n logs.push(`Unable to get a response from the network. Will respond ` +\n `with a cached response.`);\n }\n }\n if (error || !response) {\n response = await handler.cacheMatch(request);\n if (process.env.NODE_ENV !== 'production') {\n if (response) {\n logs.push(`Found a cached response in the '${this.cacheName}'` + ` cache.`);\n }\n else {\n logs.push(`No response found in the '${this.cacheName}' cache.`);\n }\n }\n }\n return response;\n }\n}\nexport { NetworkFirst };\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 { assert } from 'workbox-core/_private/assert.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { timeout } from 'workbox-core/_private/timeout.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { Strategy } from './Strategy.js';\nimport { messages } from './utils/messages.js';\nimport './_version.js';\n/**\n * An implementation of a\n * [network-only](https://developer.chrome.com/docs/workbox/caching-strategies-overview/#network-only)\n * request strategy.\n *\n * This class is useful if you want to take advantage of any\n * [Workbox plugins](https://developer.chrome.com/docs/workbox/using-plugins/).\n *\n * If the network request fails, this will throw a `WorkboxError` exception.\n *\n * @extends workbox-strategies.Strategy\n * @memberof workbox-strategies\n */\nclass NetworkOnly extends Strategy {\n /**\n * @param {Object} [options]\n * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins}\n * to use in conjunction with this caching strategy.\n * @param {Object} [options.fetchOptions] Values passed along to the\n * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters)\n * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796)\n * `fetch()` requests made by this strategy.\n * @param {number} [options.networkTimeoutSeconds] If set, any network requests\n * that fail to respond within the timeout will result in a network error.\n */\n constructor(options = {}) {\n super(options);\n this._networkTimeoutSeconds = options.networkTimeoutSeconds || 0;\n }\n /**\n * @private\n * @param {Request|string} request A request to run this strategy for.\n * @param {workbox-strategies.StrategyHandler} handler The event that\n * triggered the request.\n * @return {Promise}\n */\n async _handle(request, handler) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(request, Request, {\n moduleName: 'workbox-strategies',\n className: this.constructor.name,\n funcName: '_handle',\n paramName: 'request',\n });\n }\n let error = undefined;\n let response;\n try {\n const promises = [\n handler.fetch(request),\n ];\n if (this._networkTimeoutSeconds) {\n const timeoutPromise = timeout(this._networkTimeoutSeconds * 1000);\n promises.push(timeoutPromise);\n }\n response = await Promise.race(promises);\n if (!response) {\n throw new Error(`Timed out the network response after ` +\n `${this._networkTimeoutSeconds} seconds.`);\n }\n }\n catch (err) {\n if (err instanceof Error) {\n error = err;\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.groupCollapsed(messages.strategyStart(this.constructor.name, request));\n if (response) {\n logger.log(`Got response from network.`);\n }\n else {\n logger.log(`Unable to get a response from the network.`);\n }\n messages.printFinalResponse(response);\n logger.groupEnd();\n }\n if (!response) {\n throw new WorkboxError('no-response', { url: request.url, error });\n }\n return response;\n }\n}\nexport { NetworkOnly };\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 * Claim any currently available clients once the service worker\n * becomes active. This is normally used in conjunction with `skipWaiting()`.\n *\n * @memberof workbox-core\n */\nfunction clientsClaim() {\n self.addEventListener('activate', () => self.clients.claim());\n}\nexport { clientsClaim };\n"],"names":["self","_","e","logger","__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","messages","paramName","validValueDescription","value","Error","JSON","stringify","moduleName","className","funcName","expectedType","classNameStr","expectedClassName","isReturnValueProblem","expectedMethod","entry","firstEntry","secondEntry","thrownErrorMessage","cacheNameId","name","methodName","expectedClass","normalizedRangeHeader","size","start","end","url","message","status","cacheName","origin","type","generatorFunction","code","details","messageGenerator","WorkboxError","constructor","errorCode","isArray","Array","hasMethod","object","isType","isInstance","isOneOf","validValues","includes","isArrayOfClass","item","finalAssertExports","defaultMethod","validMethods","normalizeHandler","handler","assert","handle","Route","match","setCatchHandler","catchHandler","RegExpRoute","regExp","RegExp","result","exec","href","location","index","toString","slice","getFriendlyURL","urlObj","URL","String","replace","Router","_routes","Map","_defaultHandlerMap","routes","addFetchListener","addEventListener","event","request","responsePromise","handleRequest","respondWith","addCacheListener","data","payload","urlsToCache","requestPromises","Promise","all","map","Request","waitUntil","ports","then","postMessage","protocol","startsWith","sameOrigin","params","route","findMatchingRoute","debugMessages","push","has","get","forEach","msg","err","reject","_catchHandler","catch","catchErr","matchResult","length","undefined","setDefaultHandler","set","registerRoute","unregisterRoute","routeIndex","indexOf","splice","defaultRouter","getOrCreateDefaultRouter","capture","captureUrl","valueToCheck","pathname","wildcards","matchCallback","cacheOkAndOpaquePlugin","cacheWillUpdate","response","_cacheNameDetails","googleAnalytics","precache","prefix","runtime","suffix","registration","scope","_createCacheName","filter","eachCacheNameDetail","fn","cacheNames","updateDetails","getGoogleAnalyticsName","userCacheName","getPrecacheName","getPrefix","getRuntimeName","getSuffix","stripParams","fullURL","ignoreParams","strippedURL","param","searchParams","delete","cacheMatchIgnoreParams","cache","matchOptions","strippedRequestURL","keysOptions","assign","ignoreSearch","cacheKeys","cacheKey","strippedCacheKeyURL","Deferred","promise","resolve","quotaErrorCallbacks","Set","executeQuotaErrorCallbacks","callback","timeout","ms","setTimeout","toRequest","input","StrategyHandler","strategy","options","_cacheKeys","ExtendableEvent","_strategy","_handlerDeferred","_extendLifetimePromises","_plugins","plugins","_pluginStateMap","plugin","fetch","mode","FetchEvent","preloadResponse","possiblePreloadResponse","originalRequest","hasCallback","clone","cb","iterateCallbacks","pluginFilteredRequest","fetchResponse","fetchOptions","runCallbacks","fetchAndCachePut","responseClone","cachePut","cacheMatch","cachedResponse","effectiveRequest","getCacheKey","multiMatchOptions","caches","vary","headers","responseToCache","_ensureResponseSafeToCache","open","hasCacheUpdateCallback","oldResponse","put","newResponse","state","statefulCallback","statefulParam","doneWaiting","shift","destroy","pluginsUsed","Strategy","responseDone","handleAll","_getResponse","handlerDone","_awaitComplete","_handle","waitUntilError","strategyStart","strategyName","printFinalResponse","NetworkFirst","some","p","unshift","_networkTimeoutSeconds","networkTimeoutSeconds","logs","promises","timeoutId","id","_getTimeoutPromise","networkPromise","_getNetworkPromise","race","timeoutPromise","onNetworkTimeout","fetchError","clearTimeout","NetworkOnly","clientsClaim","clients","claim"],"mappings":"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"} \ No newline at end of file diff --git a/src/components/button/socialButtons.jsx b/src/components/button/socialButtons.jsx new file mode 100644 index 0000000..ada61f2 --- /dev/null +++ b/src/components/button/socialButtons.jsx @@ -0,0 +1,23 @@ +import Head from 'next/head'; + +const SocialButtons = () => { + + const socials = []; + + return ( + <> + + + +
+ + + + + +
+ + ); +}; + +export default SocialButtons; diff --git a/src/components/button/themeButton.jsx b/src/components/button/themeButton.jsx new file mode 100644 index 0000000..eb04f33 --- /dev/null +++ b/src/components/button/themeButton.jsx @@ -0,0 +1,44 @@ +import useDarkMode from 'use-dark-mode'; +import { useSpring, animated } from 'react-spring'; +import { useEffect } from 'react'; + +import { SunIcon, MoonIcon } from '@heroicons/react/solid'; + +const ThemeButton = () => { + const darkMode = useDarkMode(false, { + classNameDark: 'dark', + classNameLight: 'light', + }); + + const anim = useSpring({ + from: { rotateZ: 0 }, + to: { rotateZ: darkMode.value ? 0 : 180 }, + }); + + const { scale } = useSpring({ scale: 0 }); + useEffect(() => { + scale.start({ from: 0.8, to: 1 }); + }); + + return ( + + + {darkMode.value ? ( + + ) : ( + + )} + + + ); +}; + +export default ThemeButton; diff --git a/src/components/footer.jsx b/src/components/footer.jsx new file mode 100644 index 0000000..ddc8fd0 --- /dev/null +++ b/src/components/footer.jsx @@ -0,0 +1,11 @@ +import ThemeButton from '@components/button/themeButton'; + +const Si = () => { + return ( +
+ +
+ ); +}; + +export default Footer; diff --git a/src/components/sideBar.jsx b/src/components/sideBar.jsx new file mode 100644 index 0000000..411dcf5 --- /dev/null +++ b/src/components/sideBar.jsx @@ -0,0 +1,127 @@ +import { + MenuIcon, + ArrowSmLeftIcon, + CodeIcon, + DocumentTextIcon, +} from '@heroicons/react/solid'; +import { useSpring, animated } from 'react-spring'; +import { useState, useEffect } from 'react'; +import { useSwipeable } from 'react-swipeable'; +import useWinSize from '@hooks/useWinSize'; + +import ThemeButton from '@components/button/themeButton'; +import SocialButtons from '@components/button/socialButtons'; + +const SideBar = () => { + const [opened, setOpen] = useState(false); + + const { width } = useWinSize(); + + const [animSideBar, animButton, animBg, { scale }] = [ + useSpring({ + from: { x: 0 }, + to: { x: opened ? 0 : -360 }, + }), + useSpring({ + from: { x: 0, rotateZ: 0 }, + to: { + x: opened ? 0 : width < 640 ? -320 : -380, + rotateZ: opened ? 0 : 180, + }, + }), + useSpring({ + from: { opacity: 0 }, + to: { opacity: opened ? 0.25 : 0 }, + }), + useSpring({ scale: 0 }), + ]; + useEffect(() => { + scale.start({ from: 0.8, to: 1 }); + }); + + const handlers = useSwipeable({ + onSwipedRight: () => setOpen(true), + onSwipedLeft: () => setOpen(false), + }); + + return ( +
+ + + { + if (opened) setOpen(!opened); + }} + id='side-bar-background' + className='fixed top-0 bg-[#000000] w-screen h-screen' + style={animBg} + > +
+ ); +}; + +export default SideBar; diff --git a/src/libs/hooks/useWinSize.ts b/src/libs/hooks/useWinSize.ts new file mode 100644 index 0000000..6f9b77c --- /dev/null +++ b/src/libs/hooks/useWinSize.ts @@ -0,0 +1,22 @@ +import { useState, useEffect } from 'react'; + +const getSize = () => { + const { innerWidth: width, innerHeight: height } = typeof window !== 'undefined' ? window : { innerWidth: 0, innerHeight: 0 }; + return { width, height }; +}; + +const useWinSize = () => { + const [winSize, setWinSize] = useState(getSize()); + + useEffect(() => { + function resizeHandler() { + setWinSize(getSize()); + } + window.addEventListener('resize', resizeHandler); + return () => window.removeEventListener('resize', resizeHandler); + }, []) + + return winSize; +} + +export default useWinSize; diff --git a/src/pages/_app.tsx b/src/pages/_app.tsx index e286496..f858114 100644 --- a/src/pages/_app.tsx +++ b/src/pages/_app.tsx @@ -1,7 +1,9 @@ -import Head from 'next/head'; import '../styles/globals.css'; import { AppProps } from 'next/app'; +import Head from 'next/head'; +import SideBar from '@components/sideBar'; + export default function MyApp({ Component, pageProps }: AppProps) { return ( <> @@ -14,7 +16,7 @@ export default function MyApp({ Component, pageProps }: AppProps) { /> - Next.js PWA Example + Homework.app - +
+ +
+ +
+
); } diff --git a/src/pages/_document.tsx b/src/pages/_document.tsx new file mode 100644 index 0000000..aa16970 --- /dev/null +++ b/src/pages/_document.tsx @@ -0,0 +1,19 @@ +import Document, { Html, Head, Main, NextScript } from 'next/document'; + +class MyDocument extends Document { + render() { + return ( + + + + {/* eslint-disable-next-line @next/next/no-sync-scripts */} +