From fa518facfa1871d64e5b70cecfcceff575133ff6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D8=AD=D8=B3=DB=8C=D9=86=20=D9=85=D8=B9=D8=B5=D9=88=D9=85?= =?UTF-8?q?=DB=8C=20=D9=BE=D9=88=D8=B1?= Date: Mon, 16 Sep 2024 01:49:19 +0330 Subject: [PATCH] edit en landing --- components/TaskPage/ActivityCardFake/page.jsx | 8 +- components/landingComponents/Experience.jsx | 6 +- components/landingComponents/Footer/page.jsx | 22 +- components/landingComponents/Navbar.jsx | 2 +- .../landingComponents/PricingHero/page.jsx | 200 +- components/landingComponents/StepProduct.jsx | 4 - components/landingComponents/StressTest.jsx | 57 +- public/fallback-ce627215c0e4a9af.js | 1 + public/fallback-development.js | 102 - public/images/tuk.png | Bin 94892 -> 20476 bytes public/sw.js | 116 +- public/sw.js.map | 1 - public/swe-worker-5c72df51bb1f6ee0.js | 1 + public/swe-worker-development.js | 102 - public/workbox-1e54d6fe.js | 3593 ----------------- public/workbox-1e54d6fe.js.map | 1 - public/workbox-c06b064f.js | 1 + src/app/about-us/page.jsx | 20 +- style/globals.css | 5 + 19 files changed, 264 insertions(+), 3978 deletions(-) create mode 100644 public/fallback-ce627215c0e4a9af.js delete mode 100644 public/fallback-development.js delete mode 100644 public/sw.js.map create mode 100644 public/swe-worker-5c72df51bb1f6ee0.js delete mode 100644 public/swe-worker-development.js delete mode 100644 public/workbox-1e54d6fe.js delete mode 100644 public/workbox-1e54d6fe.js.map create mode 100644 public/workbox-c06b064f.js diff --git a/components/TaskPage/ActivityCardFake/page.jsx b/components/TaskPage/ActivityCardFake/page.jsx index b1c5b3c..4669360 100644 --- a/components/TaskPage/ActivityCardFake/page.jsx +++ b/components/TaskPage/ActivityCardFake/page.jsx @@ -42,12 +42,12 @@ const ActivityCardFake = ({ data }) => { const handleUndoneResone = () => { setConditionTask(4); - CTX.UnDoneActivity(data.id, undoneResone); + // CTX.UnDoneActivity(data.id, undoneResone); }; const handleDone = () => { setConditionTask(3); - CTX.DoneActivity(data.id); + // CTX.DoneActivity(data.id); }; return ( @@ -102,12 +102,12 @@ const ActivityCardFake = ({ data }) => {
handleConditionTaskCircle()} > diff --git a/components/landingComponents/Experience.jsx b/components/landingComponents/Experience.jsx index ba94fdc..ec86915 100644 --- a/components/landingComponents/Experience.jsx +++ b/components/landingComponents/Experience.jsx @@ -81,14 +81,14 @@ const ExperienceCard = ({ experience }) => { }; const Experience = () => { - const [number, setNumber] = useState(2001); - const [prevNumber, setPrevNumber] = useState(2001); + const [number, setNumber] = useState(4521); + const [prevNumber, setPrevNumber] = useState(4521); useEffect(() => { const interval = setInterval(() => { setPrevNumber(number); setNumber((prev) => prev + 1); - }, 3000); + }, 15000); return () => clearInterval(interval); }, [number]); diff --git a/components/landingComponents/Footer/page.jsx b/components/landingComponents/Footer/page.jsx index 93e8218..c704352 100644 --- a/components/landingComponents/Footer/page.jsx +++ b/components/landingComponents/Footer/page.jsx @@ -5,10 +5,26 @@ import Link from "next/link"; const Footer = () => { return ( -
+
+
+
+
+ +
+

+ " + Briz, Harmonious routine +

+

+ management + " +

+
+
+
-
+

@@ -17,7 +33,7 @@ const Footer = () => { {process.env.NEXT_PUBLIC_VERSION}

-
+

pricing

diff --git a/components/landingComponents/Navbar.jsx b/components/landingComponents/Navbar.jsx index 154b096..9173c10 100644 --- a/components/landingComponents/Navbar.jsx +++ b/components/landingComponents/Navbar.jsx @@ -72,7 +72,7 @@ const Navbar = () => {
- + diff --git a/components/landingComponents/PricingHero/page.jsx b/components/landingComponents/PricingHero/page.jsx index 6a416e5..d84265d 100644 --- a/components/landingComponents/PricingHero/page.jsx +++ b/components/landingComponents/PricingHero/page.jsx @@ -1,6 +1,10 @@ -import React from "react"; +import Link from "next/link"; +import React, { useState } from "react"; const PricingHero = () => { + const [oneMonth, setOneMonth] = useState(0); + const [threeMonth, setThreeMonth] = useState(0); + const [oneYear, setOneYear] = useState(0); return (
@@ -16,37 +20,177 @@ const PricingHero = () => {

-
-
-

- per Month -

+
+
+
+
setOneMonth(0)} + > +

up 10 user

+
+
setOneMonth(1)} + > +

up 25 user

+
-

46 €

-
- -
-

- 3 Months -

-
- - 138 € - +
setOneMonth(2)} + > +

up 50 user

+
-

110 €

-
-
-

- 12 Months -

-
- - 552 € - +
+

+ 1 Mounth +

+ +

+ {oneMonth == 0 + ? " 15,000,000 R" + : oneMonth == 1 + ? " 24,000,000 R" + : oneMonth == 2 + ? " 29,500,000 R" + : " 15,000,000 R"} +

+ +

+ It could be the best package for you, so feel free to use the + 14-day free trial +

+
+ + + +
+
+
+
+
+
setThreeMonth(0)} + > +

up 10 user

+
+
setThreeMonth(1)} + > +

up 25 user

+
+ +
setThreeMonth(2)} + > +

up 50 user

+
+
+ +
+

+ 3 Mounth +

+ +

+ {threeMonth == 0 + ? " 36,000,000 R" + : threeMonth == 1 + ? " 57,600,000 R" + : threeMonth == 2 + ? " 70,800,000 R" + : " 36,000,000 R"}{" "} +

+ +

+ It could be the best package for you, so feel free to use the + 14-day free trial +

+
+ + + +
+
+
+
+
+
setOneYear(0)} + > +

up 10 user

+
+
setOneYear(1)} + > +

up 25 user

+
+ +
setOneYear(2)} + > +

up 50 user

+
+
+ +
+

+ 12 Mounth +

+ +

+ {oneYear == 0 + ? " 108,000,000 R" + : oneYear == 1 + ? " 172,800,000 R" + : oneYear == 2 + ? " 212,400,000 R" + : " 108,000,000 R"}{" "} +

+ +

+ It could be the best package for you, so feel free to use the + 14-day free trial +

+
+ + + +
-

390 €

diff --git a/components/landingComponents/StepProduct.jsx b/components/landingComponents/StepProduct.jsx index eb54ae2..cb5b772 100644 --- a/components/landingComponents/StepProduct.jsx +++ b/components/landingComponents/StepProduct.jsx @@ -861,10 +861,6 @@ const StepProduct = ({}) => {
- -

- Briz, Harmonious routine management -

); }; diff --git a/components/landingComponents/StressTest.jsx b/components/landingComponents/StressTest.jsx index 737b1ea..20577dc 100644 --- a/components/landingComponents/StressTest.jsx +++ b/components/landingComponents/StressTest.jsx @@ -1,4 +1,4 @@ -import React from "react"; +import React, { useState } from "react"; import { Tilt } from "react-tilt"; import { motion } from "framer-motion"; @@ -8,6 +8,8 @@ import { styles } from "src/style"; import { SectionWrapper } from "src/hoc"; import Image from "next/image"; import vector1 from "@img/Vector1.png"; +import validateIranPhone from "plugins/IranPhoneRegex"; +import { toast } from "react-toastify"; const ServiceCard = ({ index, title, icon }) => ( @@ -48,6 +50,24 @@ const ServiceCard = ({ index, title, icon }) => ( ); const StressTest = () => { + const [subscribe, setSubscribe] = useState(false); + const [subscribeNumber, setSubscribeNumber] = useState(""); + + const handleSubscribeNumber = () => { + if ( + subscribeNumber && + subscribeNumber.trim() !== "" && + validateIranPhone(subscribeNumber.trim()) + ) { + setSubscribe(true); + } else { + toast.error(`contact number is not acceptable`, { + position: "bottom-right", + closeOnClick: true, + }); + } + }; + return (
@@ -67,16 +87,31 @@ const StressTest = () => { -
- - -
+ {subscribe ? ( +
+

+ Thank you for your trust, we will contact you +

+
+ ) : ( +
+ setSubscribeNumber(e.target.value)} + value={subscribeNumber} + /> + +
+ )}
diff --git a/public/fallback-ce627215c0e4a9af.js b/public/fallback-ce627215c0e4a9af.js new file mode 100644 index 0000000..f02f9ce --- /dev/null +++ b/public/fallback-ce627215c0e4a9af.js @@ -0,0 +1 @@ +self.fallback=async e=>{let{destination:a,url:n}=e,o={document:"/offline",image:!1,audio:!1,video:!1,font:!1}[a];return o?caches.match(o,{ignoreSearch:!0}):Response.error()}; \ No newline at end of file diff --git a/public/fallback-development.js b/public/fallback-development.js deleted file mode 100644 index 9610be1..0000000 --- a/public/fallback-development.js +++ /dev/null @@ -1,102 +0,0 @@ -/* - * ATTENTION: An "eval-source-map" devtool has been used. - * This devtool is neither made for production nor for readable output files. - * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. - * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) - * or disable the default devtool with "devtool: false". - * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). - */ -/******/ (function() { // webpackBootstrap -/******/ "use strict"; -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@ducanh2912/next-pwa/dist/fallback.js": -/*!************************************************************!*\ - !*** ./node_modules/@ducanh2912/next-pwa/dist/fallback.js ***! - \************************************************************/ -/***/ (function(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) { - -eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\nself.fallback = async (_)=>{\n let { destination: e, url: A } = _, s = {\n document: \"/offline\",\n image: false,\n audio: false,\n video: false,\n font: false\n }[e];\n return s ? caches.match(s, {\n ignoreSearch: !0\n }) : \"\" === e && false && 0 ? 0 : Response.error();\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvQGR1Y2FuaDI5MTIvbmV4dC1wd2EvZGlzdC9mYWxsYmFjay5qcyIsIm1hcHBpbmdzIjoiO0FBQUE7QUFDQSxVQUFVLHlCQUF5QjtBQUNuQyxrQkFBa0IsVUFBcUM7QUFDdkQsZUFBZSxLQUFrQztBQUNqRCxlQUFlLEtBQWtDO0FBQ2pELGVBQWUsS0FBa0M7QUFDakQsY0FBYyxLQUFpQztBQUMvQyxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUssZ0JBQWdCLEtBQWlDLElBQUksQ0FBd0MsR0FBRyxDQUUvRjtBQUNOIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vX05fRS8uL25vZGVfbW9kdWxlcy9AZHVjYW5oMjkxMi9uZXh0LXB3YS9kaXN0L2ZhbGxiYWNrLmpzP2NlNGIiXSwic291cmNlc0NvbnRlbnQiOlsic2VsZi5mYWxsYmFjayA9IGFzeW5jIChfKT0+e1xuICAgIGxldCB7IGRlc3RpbmF0aW9uOiBlLCB1cmw6IEEgfSA9IF8sIHMgPSB7XG4gICAgICAgIGRvY3VtZW50OiBwcm9jZXNzLmVudi5fX1BXQV9GQUxMQkFDS19ET0NVTUVOVF9fLFxuICAgICAgICBpbWFnZTogcHJvY2Vzcy5lbnYuX19QV0FfRkFMTEJBQ0tfSU1BR0VfXyxcbiAgICAgICAgYXVkaW86IHByb2Nlc3MuZW52Ll9fUFdBX0ZBTExCQUNLX0FVRElPX18sXG4gICAgICAgIHZpZGVvOiBwcm9jZXNzLmVudi5fX1BXQV9GQUxMQkFDS19WSURFT19fLFxuICAgICAgICBmb250OiBwcm9jZXNzLmVudi5fX1BXQV9GQUxMQkFDS19GT05UX19cbiAgICB9W2VdO1xuICAgIHJldHVybiBzID8gY2FjaGVzLm1hdGNoKHMsIHtcbiAgICAgICAgaWdub3JlU2VhcmNoOiAhMFxuICAgIH0pIDogXCJcIiA9PT0gZSAmJiBwcm9jZXNzLmVudi5fX1BXQV9GQUxMQkFDS19EQVRBX18gJiYgQS5tYXRjaCgvXFwvX25leHRcXC9kYXRhXFwvLitcXC8uK1xcLmpzb24kL2kpID8gY2FjaGVzLm1hdGNoKHByb2Nlc3MuZW52Ll9fUFdBX0ZBTExCQUNLX0RBVEFfXywge1xuICAgICAgICBpZ25vcmVTZWFyY2g6ICEwXG4gICAgfSkgOiBSZXNwb25zZS5lcnJvcigpO1xufTsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./node_modules/@ducanh2912/next-pwa/dist/fallback.js\n")); - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The require scope -/******/ var __webpack_require__ = {}; -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/make namespace object */ -/******/ !function() { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = function(exports) { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ }(); -/******/ -/******/ /* webpack/runtime/trusted types policy */ -/******/ !function() { -/******/ var policy; -/******/ __webpack_require__.tt = function() { -/******/ // Create Trusted Type policy if Trusted Types are available and the policy doesn't exist yet. -/******/ if (policy === undefined) { -/******/ policy = { -/******/ createScript: function(script) { return script; } -/******/ }; -/******/ if (typeof trustedTypes !== "undefined" && trustedTypes.createPolicy) { -/******/ policy = trustedTypes.createPolicy("nextjs#bundler", policy); -/******/ } -/******/ } -/******/ return policy; -/******/ }; -/******/ }(); -/******/ -/******/ /* webpack/runtime/trusted types script */ -/******/ !function() { -/******/ __webpack_require__.ts = function(script) { return __webpack_require__.tt().createScript(script); }; -/******/ }(); -/******/ -/******/ /* webpack/runtime/react refresh */ -/******/ !function() { -/******/ if (__webpack_require__.i) { -/******/ __webpack_require__.i.push(function(options) { -/******/ var originalFactory = options.factory; -/******/ options.factory = function(moduleObject, moduleExports, webpackRequire) { -/******/ var hasRefresh = typeof self !== "undefined" && !!self.$RefreshInterceptModuleExecution$; -/******/ var cleanup = hasRefresh ? self.$RefreshInterceptModuleExecution$(moduleObject.id) : function() {}; -/******/ try { -/******/ originalFactory.call(this, moduleObject, moduleExports, webpackRequire); -/******/ } finally { -/******/ cleanup(); -/******/ } -/******/ } -/******/ }) -/******/ } -/******/ }(); -/******/ -/******/ /* webpack/runtime/compat */ -/******/ -/******/ -/******/ // noop fns to prevent runtime errors during initialization -/******/ if (typeof self !== "undefined") { -/******/ self.$RefreshReg$ = function () {}; -/******/ self.$RefreshSig$ = function () { -/******/ return function (type) { -/******/ return type; -/******/ }; -/******/ }; -/******/ } -/******/ -/************************************************************************/ -/******/ -/******/ // startup -/******/ // Load entry module and return exports -/******/ // This entry module can't be inlined because the eval-source-map devtool is used. -/******/ var __webpack_exports__ = {}; -/******/ __webpack_modules__["./node_modules/@ducanh2912/next-pwa/dist/fallback.js"](0, __webpack_exports__, __webpack_require__); -/******/ -/******/ })() -; \ No newline at end of file diff --git a/public/images/tuk.png b/public/images/tuk.png index f8560bf6c221b205c8f2354c3e5b38340cd66bd6..1133b94586fb72a18c812f92557b329012a74e1c 100644 GIT binary patch literal 20476 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 MsNaxdgJ-P%FSXYZjsO4v literal 94892 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 z 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 KdMKR-k^cu6>pSuQ diff --git a/public/sw.js b/public/sw.js index 6d6df48..039a261 100644 --- a/public/sw.js +++ b/public/sw.js @@ -1,115 +1 @@ -/** - * 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-1e54d6fe'], (function (workbox) { 'use strict'; - - importScripts("/fallback-development.js"); - self.skipWaiting(); - workbox.clientsClaim(); - - /** - * The precacheAndRoute() method efficiently caches and responds to - * requests for URLs in the manifest. - * See https://goo.gl/S9QRab - */ - workbox.precacheAndRoute([{ - "url": "/offline", - "revision": "development" - }], { - "ignoreURLParametersMatching": [/^utm_/, /^fbclid$/, /ts/] - }); - workbox.cleanupOutdatedCaches(); - workbox.registerRoute("/", new workbox.NetworkFirst({ - "cacheName": "start-url", - plugins: [{ - cacheWillUpdate: async ({ - response: e - }) => e && "opaqueredirect" === e.type ? new Response(e.body, { - status: 200, - statusText: "OK", - headers: e.headers - }) : e - }, { - handlerDidError: async ({ - request: e - }) => "undefined" != typeof self ? self.fallback(e) : Response.error() - }] - }), 'GET'); - workbox.registerRoute(/.*/i, new workbox.NetworkOnly({ - "cacheName": "dev", - plugins: [{ - handlerDidError: async ({ - request: e - }) => "undefined" != typeof self ? self.fallback(e) : Response.error() - }] - }), 'GET'); - self.__WB_DISABLE_DEV_LOGS = true; - -})); -//# sourceMappingURL=sw.js.map +if(!self.define){let e,a={};const i=(i,s)=>(i=new URL(i+".js",s).href,a[i]||new Promise((a=>{if("document"in self){const e=document.createElement("script");e.src=i,e.onload=a,document.head.appendChild(e)}else e=i,importScripts(i),a()})).then((()=>{let e=a[i];if(!e)throw new Error(`Module ${i} didn’t register its module`);return e})));self.define=(s,n)=>{const c=e||("document"in self?document.currentScript.src:"")||location.href;if(a[c])return;let f={};const r=e=>i(e,c),t={module:{uri:c},exports:f,require:r};a[c]=Promise.all(s.map((e=>t[e]||r(e)))).then((e=>(n(...e),f)))}}define(["./workbox-c06b064f"],(function(e){"use strict";importScripts("/fallback-ce627215c0e4a9af.js"),self.skipWaiting(),e.clientsClaim(),e.precacheAndRoute([{url:"/_next/static/8SwNB7Vor9i8q3FPf39le/_buildManifest.js",revision:"66a650a40453999ca40002ee32e3481e"},{url:"/_next/static/8SwNB7Vor9i8q3FPf39le/_ssgManifest.js",revision:"b6652df95db52feb4daf4eca35380933"},{url:"/_next/static/chunks/135-fbe9e1bd4358248a.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/13b76428-56ef92d027d6786a.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/148-76a3e61f8b509e85.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/235-44d31a43a4a9f007.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/245-7a31a50c90ece09f.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/313-189f3f7d71a2a2f2.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/361-1eadcd47b00762f2.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/375-4f8a86f3ce3adcd3.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/396-d24fc3578f46fc4e.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/478-18c8f2345006432f.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/525-4c1f9a0f7eae889b.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/568-fd836c769a6919a6.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/747-1e11f0325e4f5aa5.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/778-315d8ff4db0336f1.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/807-9065b9e93d5afb07.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/874-3409183e9254cad1.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/889-df7963611fc20968.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/906-47764d1840e263ce.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/92-41d871ab515da13f.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/986-62db81ee10936871.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/about-us/page-d568f8727b630ebf.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/add-buy/page-f2c872005a0397bc.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/acount/page-f83ba430764f1ea1.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/coffee-brew/page-b5f5e7bb4c561fa1.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/employees/page-abb35b7c2cf5b86b.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/home/page-435b85b59b5f64cc.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/login/page-f4896bdf871fdd06.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/news/page-306d2a28306dc14d.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/shifts/complete-shift/page-cd28ad634fcfd257.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/shifts/manage-shift/page-83bf971f64f5349f.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/shifts/page-5b77d58a9800268f.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/tasks/add-task/page-d7ff93922fa8a331.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/app/tasks/page-5ff180539e8c08eb.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/layout-af8163e103cc63f0.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/page-e21bcf16376be1c4.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/app/pricing/page-4fbf6ee400c9a19e.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/ca377847-c7b13a2d3dbd7978.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/fd9d1056-76aadce26f555392.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/framework-89837f5784be6e42.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/main-5485f73f6f712ade.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/main-app-463a5ceba39d13c0.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/pages/_app-52924524f99094ab.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/pages/_error-c92d5c4bb2b49926.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/chunks/polyfills-78c92fac7aa8fdd8.js",revision:"79330112775102f91e1010318bae2bd3"},{url:"/_next/static/chunks/webpack-7229836dc7004761.js",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/_next/static/css/0ef3245532385a33.css",revision:"0ef3245532385a33"},{url:"/_next/static/css/2d0b62e6e148789e.css",revision:"2d0b62e6e148789e"},{url:"/_next/static/css/34c26eb5be187d8a.css",revision:"34c26eb5be187d8a"},{url:"/_next/static/css/afd026d3c415d315.css",revision:"afd026d3c415d315"},{url:"/_next/static/media/26a46d62cd723877-s.woff2",revision:"befd9c0fdfa3d8a645d5f95717ed6420"},{url:"/_next/static/media/55c55f0601d81cf3-s.woff2",revision:"43828e14271c77b87e3ed582dbff9f74"},{url:"/_next/static/media/581909926a08bbc8-s.woff2",revision:"f0b86e7c24f455280b8df606b89af891"},{url:"/_next/static/media/6d93bde91c0c2823-s.woff2",revision:"621a07228c8ccbfd647918f1021b4868"},{url:"/_next/static/media/97e0cb1ae144a2a9-s.woff2",revision:"e360c61c5bd8d90639fd4503c829c2dc"},{url:"/_next/static/media/Vector1.8129c6ce.png",revision:"17a7084f16c85847f17977f594679ced"},{url:"/_next/static/media/a34f9d1faa5f3315-s.p.woff2",revision:"d4fe31e6a2aebc06b8d6e558c9141119"},{url:"/_next/static/media/adjust.8a4e8d0e.png",revision:"5211a7519534ca172844a42bce17465a"},{url:"/_next/static/media/adjustw.750c874c.png",revision:"cdde1aad7bebb72f4badb0789f7e6e27"},{url:"/_next/static/media/app.542d2db5.png",revision:"5cf2e6ff5ef3237a6f9ad369cc92dc76"},{url:"/_next/static/media/backend.8008d8ae.png",revision:"b6f97a0bb77c12636d32a57efacd1d10"},{url:"/_next/static/media/bg.64a109c7.png",revision:"64a109c7"},{url:"/_next/static/media/carrent.f51c1ee5.png",revision:"de7775e7e769abcd0478a0f32554addf"},{url:"/_next/static/media/close.64934c3b.svg",revision:"333c66a5dff1d7cc3968f6e7af4c5b2c"},{url:"/_next/static/media/creator.69ea3236.png",revision:"2fb53dc768e9f2b21e8eba0b31c50f1d"},{url:"/_next/static/media/css.a39d8948.png",revision:"562320553594c7fc047b9d0cf55233ab"},{url:"/_next/static/media/df0a9ae256c0569c-s.woff2",revision:"d54db44de5ccb18886ece2fda72bdfe0"},{url:"/_next/static/media/docker.888df998.png",revision:"48daa53dc2e75aa18777f55eb610c4f1"},{url:"/_next/static/media/figma.522534b7.png",revision:"897539713a3105b6ee3b797851459130"},{url:"/_next/static/media/git.3337db5a.png",revision:"91e38c1fb4b2410c06d56542d09086d0"},{url:"/_next/static/media/github.665bfffe.png",revision:"69b7e397e348747e802b90e5eb0bfbd4"},{url:"/_next/static/media/html.5faed4ed.png",revision:"ff5aca29bd447b791c743ad0075e5aa3"},{url:"/_next/static/media/ig.1b04410f.png",revision:"ad3e83bda02be12d20e80665a2d35d0d"},{url:"/_next/static/media/javascript.80891722.png",revision:"c1f39577de277de6ff5f654e996f1028"},{url:"/_next/static/media/jobit.2df3aeaa.png",revision:"261dcd8d434a22a8ce067dcfe77160b8"},{url:"/_next/static/media/lam.bd7609da.png",revision:"c821000c912deb2ec64787f8c7341851"},{url:"/_next/static/media/loading.5d5a7205.gif",revision:"bac61c8d9306edae5b74e399d1485ad3"},{url:"/_next/static/media/logo.82328059.svg",revision:"2c844ef471eafcba8331c476cfef883b"},{url:"/_next/static/media/logo.9568c8e7.png",revision:"9cde4940e517fbafd74784802b462e5b"},{url:"/_next/static/media/logo2.26701545.png",revision:"a876896a85faad3f81a50af5ac1392f9"},{url:"/_next/static/media/logo2.8d20420d.png",revision:"97bc09c6257714ce55faa41bc2da88b5"},{url:"/_next/static/media/menu.3fc6164d.svg",revision:"d4926d3f2dc6c41bdcb19909d4ae93c8"},{url:"/_next/static/media/meta.3b282ee4.png",revision:"c39c206e11ef45ddc19167e6c167e1d8"},{url:"/_next/static/media/mobile.6333563d.png",revision:"9537758db1d756949a924fcd4404895f"},{url:"/_next/static/media/mongodb.004a26cb.png",revision:"1fb83876d8f00b2f67374b05838d09d2"},{url:"/_next/static/media/nodejs.fbe4a5b0.png",revision:"9e79e8c3cdcccfc06c9840883f15b2c1"},{url:"/_next/static/media/notif.1e9f8243.png",revision:"bd85e30b2bf85bc83b9189b47bbac828"},{url:"/_next/static/media/phi1.ba638ea9.png",revision:"1116ff7c816453d26ea5fe9ae84169d1"},{url:"/_next/static/media/phi2.8f52adc1.png",revision:"72f098a8c6fd79ff2300e47467237f0d"},{url:"/_next/static/media/phi3.00f9ce61.png",revision:"a80bc58f24f702839feb34b5043679d8"},{url:"/_next/static/media/reactjs.38edcd3f.png",revision:"f70556624353bdc24ec1e69a2d979630"},{url:"/_next/static/media/redux.fd412f4b.png",revision:"31f3e54c7d49efed1b6a03edc4476ba2"},{url:"/_next/static/media/ros.990a7841.png",revision:"145618df97c1ecb76a6ef3d349248e0c"},{url:"/_next/static/media/setting.752bec9e.png",revision:"8a4a4a0bc0dc99c74dfb06ab82183f1c"},{url:"/_next/static/media/shopify.c8963632.png",revision:"7d0c465185ea1aa651737aedf2e889f9"},{url:"/_next/static/media/starbucks.ca9c1564.png",revision:"739125c98702ba3575a572618abc82f6"},{url:"/_next/static/media/tailwind.cd1d4bac.png",revision:"c73f9afce409c73a75bb36ce9da84a94"},{url:"/_next/static/media/tesla.cd57c981.png",revision:"00f12a1675ac2554f83449c254abfc66"},{url:"/_next/static/media/threejs.fe404a12.svg",revision:"d75c09a5a967d4425a175b6bfe5ca4e5"},{url:"/_next/static/media/tuk.425b3733.png",revision:"442ebd84643f1a763391b4a547879b59"},{url:"/_next/static/media/tuk.e4f3e0e2.png",revision:"f0ef8c133b136488c44fbee1c27aba25"},{url:"/_next/static/media/typescript.ccdf44e2.png",revision:"6a41ab01fd39f8bae6bad97ef7109cf9"},{url:"/_next/static/media/vee.6a66cc44.png",revision:"8c717a303c20ee4a83f47787b7db119d"},{url:"/_next/static/media/web.a0fb760b.png",revision:"f59df0f5b55cde9fc8e02c3dfe1e3540"},{url:"/_next/static/media/woo.abc77e01.png",revision:"e40cf597740cf29d2cab57b3720a4c26"},{url:"/android-chrome-192x192.png",revision:"5a2b679c2087c606306393171e90e5e3"},{url:"/android-chrome-512x512.png",revision:"70e7c2793f6a0cc9cf2e15bf618938d0"},{url:"/apple-touch-icon.png",revision:"73ac676e78dc2f3a4ca9fb7f6d7ab8a2"},{url:"/browserconfig.xml",revision:"a493ba0aa0b8ec8068d786d7248bb92c"},{url:"/fallback-ce627215c0e4a9af.js",revision:"a5281aa1504c5d6bcd7ba1097870376a"},{url:"/favicon-16x16.png",revision:"b59e99894c6ece0c4acf1bd30a61f293"},{url:"/favicon-32x32.png",revision:"722bded6887acd0241f8e05917a4b180"},{url:"/favicon.ico",revision:"9292c7c8eef1860fa5093b1ce664c11c"},{url:"/fonts/woff/KalamehWeb-Black.woff",revision:"76927eb3c8978995345660385aff7ec4"},{url:"/fonts/woff/KalamehWeb-Bold.woff",revision:"962a46f356f93fe9a4aadc4dd2ed0eec"},{url:"/fonts/woff/KalamehWeb-ExtraBold.woff",revision:"2bc26bafe58675b967b6679f0c988702"},{url:"/fonts/woff/KalamehWeb-ExtraLight.woff",revision:"2c34c6b56cf5d5f28b855a26e12c7903"},{url:"/fonts/woff/KalamehWeb-Light.woff",revision:"bcf5ef6b7b982e0ab7290e6c2cda510b"},{url:"/fonts/woff/KalamehWeb-Medium.woff",revision:"f10476fa00c806a8862f8d28510e0d61"},{url:"/fonts/woff/KalamehWeb-Regular.woff",revision:"7aa63793827e31b8e41fda71f8072de6"},{url:"/fonts/woff/KalamehWeb-SemiBold.woff",revision:"494ba66e4eaa329a55c61419b2054fcf"},{url:"/fonts/woff/KalamehWeb-Thin.woff",revision:"bd4a8af2c70bebc7ec5342da46b27cdc"},{url:"/fonts/woff2/KalamehWeb-Black.woff2",revision:"64befedcea62edb8d51adf7b6c9e0cf9"},{url:"/fonts/woff2/KalamehWeb-Bold.woff2",revision:"341e8d81a6ad98239138dfe2f29c7e3d"},{url:"/fonts/woff2/KalamehWeb-ExtraBold.woff2",revision:"a3d26b194c12792fe056884bb54be360"},{url:"/fonts/woff2/KalamehWeb-ExtraLight.woff2",revision:"3d0141c1e3552bdc2cb5ce9d2d49c573"},{url:"/fonts/woff2/KalamehWeb-Light.woff2",revision:"a7aaf4d231f0df6371846801379cb489"},{url:"/fonts/woff2/KalamehWeb-Medium.woff2",revision:"847e07561576a0465bc688345bfef035"},{url:"/fonts/woff2/KalamehWeb-Regular.woff2",revision:"14520e3d88672cebe595a4dd4e8d1e68"},{url:"/fonts/woff2/KalamehWeb-SemiBold.woff2",revision:"25c8a9f46296bf3edb1e9c9b24a98ad5"},{url:"/fonts/woff2/KalamehWeb-Thin.woff2",revision:"416a93f37781ddfc7bc91f75d0f0a9f5"},{url:"/images/Vector1.png",revision:"17a7084f16c85847f17977f594679ced"},{url:"/images/adjust.png",revision:"5211a7519534ca172844a42bce17465a"},{url:"/images/adjustw.png",revision:"cdde1aad7bebb72f4badb0789f7e6e27"},{url:"/images/bg.png",revision:"d59230ecd8a56fd3d09d20a5f367cfbf"},{url:"/images/cloud1.png",revision:"36648f073e8cce0a55e579fd550e5d84"},{url:"/images/cloud2.png",revision:"972cec38053ef477ffad876d5fcd423c"},{url:"/images/cloud3.png",revision:"9815b2f8a56546d759ff529c2ed0df13"},{url:"/images/core.png",revision:"aa45ef82e9a55762a3a4c70fa2e703fa"},{url:"/images/extract.png",revision:"300f35767658e1c01700daf62ebad59f"},{url:"/images/ig.png",revision:"ad3e83bda02be12d20e80665a2d35d0d"},{url:"/images/loading.gif",revision:"bac61c8d9306edae5b74e399d1485ad3"},{url:"/images/logo-t.png",revision:"d5ca78535960c4937278993900a53423"},{url:"/images/logo.png",revision:"9cde4940e517fbafd74784802b462e5b"},{url:"/images/logo/lam.png",revision:"c821000c912deb2ec64787f8c7341851"},{url:"/images/logo/ros.png",revision:"145618df97c1ecb76a6ef3d349248e0c"},{url:"/images/logo/tuk.png",revision:"f0ef8c133b136488c44fbee1c27aba25"},{url:"/images/logo/vee.png",revision:"8c717a303c20ee4a83f47787b7db119d"},{url:"/images/logo/woo.png",revision:"e40cf597740cf29d2cab57b3720a4c26"},{url:"/images/logo2.png",revision:"97bc09c6257714ce55faa41bc2da88b5"},{url:"/images/notif.png",revision:"bd85e30b2bf85bc83b9189b47bbac828"},{url:"/images/person.png",revision:"686018c95d96501c6f78256e85c6fed3"},{url:"/images/phi1t.png",revision:"c45c717d505a6a26c87ee68a8b47e5b6"},{url:"/images/scales.png",revision:"9878c309208f0879891bec07e1d728b2"},{url:"/images/setting.png",revision:"8a4a4a0bc0dc99c74dfb06ab82183f1c"},{url:"/images/smile.gif",revision:"82896dd0e700e257a4d6a0002663a806"},{url:"/images/task.png",revision:"d7b1ada9aacebb1c1b32b4a17976a39e"},{url:"/images/test.gif",revision:"d3869163799f9c6055a3a6c96ace08ee"},{url:"/images/timer.png",revision:"c3122960ecb8cada6c9f5970fc85e750"},{url:"/images/tuk.png",revision:"442ebd84643f1a763391b4a547879b59"},{url:"/manifest.json",revision:"8c6744a64965df82f708eb8d04bc1b22"},{url:"/mstile-150x150.png",revision:"078e558a0511af65e96a21bfe3dad74c"},{url:"/offline",revision:"8SwNB7Vor9i8q3FPf39le"},{url:"/safari-pinned-tab.svg",revision:"d7f01631a8bb713216ac118b4fd19730"},{url:"/site.webmanifest",revision:"ff21f16e80257e0b9256bd0eee876b87"},{url:"/swe-worker-5c72df51bb1f6ee0.js",revision:"5a47d90db13bb1309b25bdf7b363570e"}],{ignoreURLParametersMatching:[/^utm_/,/^fbclid$/]}),e.cleanupOutdatedCaches(),e.registerRoute("/",new e.NetworkFirst({cacheName:"start-url",plugins:[{cacheWillUpdate:async({response:e})=>e&&"opaqueredirect"===e.type?new Response(e.body,{status:200,statusText:"OK",headers:e.headers}):e},{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/^https:\/\/fonts\.(?:gstatic)\.com\/.*/i,new e.CacheFirst({cacheName:"google-fonts-webfonts",plugins:[new e.ExpirationPlugin({maxEntries:4,maxAgeSeconds:31536e3}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/^https:\/\/fonts\.(?:googleapis)\.com\/.*/i,new e.StaleWhileRevalidate({cacheName:"google-fonts-stylesheets",plugins:[new e.ExpirationPlugin({maxEntries:4,maxAgeSeconds:604800}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"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}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"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:2592e3}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\/_next\/static.+\.js$/i,new e.CacheFirst({cacheName:"next-static-js-assets",plugins:[new e.ExpirationPlugin({maxEntries:64,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\/_next\/image\?url=.+$/i,new e.StaleWhileRevalidate({cacheName:"next-image",plugins:[new e.ExpirationPlugin({maxEntries:64,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"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}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\.(?:mp4|webm)$/i,new e.CacheFirst({cacheName:"static-video-assets",plugins:[new e.RangeRequestsPlugin,new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\.(?:js)$/i,new e.StaleWhileRevalidate({cacheName:"static-js-assets",plugins:[new e.ExpirationPlugin({maxEntries:48,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\.(?:css|less)$/i,new e.StaleWhileRevalidate({cacheName:"static-style-assets",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\/_next\/data\/.+\/.+\.json$/i,new e.StaleWhileRevalidate({cacheName:"next-data",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute(/\.(?:json|xml|csv)$/i,new e.NetworkFirst({cacheName:"static-data-assets",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute((({sameOrigin:e,url:{pathname:a}})=>!(!e||a.startsWith("/api/auth/callback")||!a.startsWith("/api/"))),new e.NetworkFirst({cacheName:"apis",networkTimeoutSeconds:10,plugins:[new e.ExpirationPlugin({maxEntries:16,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute((({request:e,url:{pathname:a},sameOrigin:i})=>"1"===e.headers.get("RSC")&&"1"===e.headers.get("Next-Router-Prefetch")&&i&&!a.startsWith("/api/")),new e.NetworkFirst({cacheName:"pages-rsc-prefetch",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute((({request:e,url:{pathname:a},sameOrigin:i})=>"1"===e.headers.get("RSC")&&i&&!a.startsWith("/api/")),new e.NetworkFirst({cacheName:"pages-rsc",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute((({url:{pathname:e},sameOrigin:a})=>a&&!e.startsWith("/api/")),new e.NetworkFirst({cacheName:"pages",plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:86400}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),e.registerRoute((({sameOrigin:e})=>!e),new e.NetworkFirst({cacheName:"cross-origin",networkTimeoutSeconds:10,plugins:[new e.ExpirationPlugin({maxEntries:32,maxAgeSeconds:3600}),{handlerDidError:async({request:e})=>"undefined"!=typeof self?self.fallback(e):Response.error()}]}),"GET"),self.__WB_DISABLE_DEV_LOGS=!0})); diff --git a/public/sw.js.map b/public/sw.js.map deleted file mode 100644 index d3f7bf9..0000000 --- a/public/sw.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"sw.js","sources":["C:/Users/jp/AppData/Local/Temp/22e5eb117e35b3c05e1938dba23b1eb0/sw.js"],"sourcesContent":["import {registerRoute as workbox_routing_registerRoute} from 'Y:/projects/brizco/node_modules/workbox-routing/registerRoute.mjs';\nimport {NetworkFirst as workbox_strategies_NetworkFirst} from 'Y:/projects/brizco/node_modules/workbox-strategies/NetworkFirst.mjs';\nimport {NetworkOnly as workbox_strategies_NetworkOnly} from 'Y:/projects/brizco/node_modules/workbox-strategies/NetworkOnly.mjs';\nimport {clientsClaim as workbox_core_clientsClaim} from 'Y:/projects/brizco/node_modules/workbox-core/clientsClaim.mjs';\nimport {precacheAndRoute as workbox_precaching_precacheAndRoute} from 'Y:/projects/brizco/node_modules/workbox-precaching/precacheAndRoute.mjs';\nimport {cleanupOutdatedCaches as workbox_precaching_cleanupOutdatedCaches} from 'Y:/projects/brizco/node_modules/workbox-precaching/cleanupOutdatedCaches.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 \"/fallback-development.js\"\n);\n\n\n\n\n\n\n\nself.skipWaiting();\n\nworkbox_core_clientsClaim();\n\n\n/**\n * The precacheAndRoute() method efficiently caches and responds to\n * requests for URLs in the manifest.\n * See https://goo.gl/S9QRab\n */\nworkbox_precaching_precacheAndRoute([\n {\n \"url\": \"/offline\",\n \"revision\": \"development\"\n }\n], {\n \"ignoreURLParametersMatching\": [/^utm_/, /^fbclid$/, /ts/]\n});\nworkbox_precaching_cleanupOutdatedCaches();\n\n\n\nworkbox_routing_registerRoute(\"/\", new workbox_strategies_NetworkFirst({ \"cacheName\":\"start-url\", plugins: [{ cacheWillUpdate: async ({ response: e })=>e && \"opaqueredirect\" === e.type ? new Response(e.body, { status: 200, statusText: \"OK\", headers: e.headers }) : e }, { handlerDidError: async ({ request: e })=>\"undefined\" != typeof self ? self.fallback(e) : Response.error() }] }), 'GET');\nworkbox_routing_registerRoute(/.*/i, new workbox_strategies_NetworkOnly({ \"cacheName\":\"dev\", plugins: [{ handlerDidError: async ({ request: e })=>\"undefined\" != typeof self ? self.fallback(e) : Response.error() }] }), 'GET');\n\n\n\n\nself.__WB_DISABLE_DEV_LOGS = true;"],"names":["importScripts","self","skipWaiting","workbox_core_clientsClaim","workbox_precaching_precacheAndRoute","workbox_precaching_cleanupOutdatedCaches","workbox_routing_registerRoute","workbox_strategies_NetworkFirst","plugins","cacheWillUpdate","response","e","type","Response","body","status","statusText","headers","handlerDidError","request","fallback","error","workbox_strategies_NetworkOnly","__WB_DISABLE_DEV_LOGS"],"mappings":"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"} \ No newline at end of file diff --git a/public/swe-worker-5c72df51bb1f6ee0.js b/public/swe-worker-5c72df51bb1f6ee0.js new file mode 100644 index 0000000..36e6e59 --- /dev/null +++ b/public/swe-worker-5c72df51bb1f6ee0.js @@ -0,0 +1 @@ +self.onmessage=async e=>{switch(e.data.type){case"__START_URL_CACHE__":{let t=e.data.url,a=await fetch(t);if(!a.redirected)return(await caches.open("start-url")).put(t,a);return Promise.resolve()}case"__FRONTEND_NAV_CACHE__":{let t=e.data.url,a=await caches.open("pages");if(await a.match(t,{ignoreSearch:!0}))return;let s=await fetch(t);if(!s.ok)return;if(a.put(t,s.clone()),e.data.shouldCacheAggressively&&s.headers.get("Content-Type")?.includes("text/html"))try{let e=await s.text(),t=[],a=await caches.open("static-style-assets"),r=await caches.open("next-static-js-assets"),c=await caches.open("static-js-assets");for(let[s,r]of e.matchAll(//g))/rel=['"]stylesheet['"]/.test(s)&&t.push(a.match(r).then(e=>e?Promise.resolve():a.add(r)));for(let[,a]of e.matchAll(//g)){let e=/\/_next\/static.+\.js$/i.test(a)?r:c;t.push(e.match(a).then(t=>t?Promise.resolve():e.add(a)))}return await Promise.all(t)}catch{}return Promise.resolve()}default:return Promise.resolve()}}; \ No newline at end of file diff --git a/public/swe-worker-development.js b/public/swe-worker-development.js deleted file mode 100644 index d8ae94f..0000000 --- a/public/swe-worker-development.js +++ /dev/null @@ -1,102 +0,0 @@ -/* - * ATTENTION: An "eval-source-map" devtool has been used. - * This devtool is neither made for production nor for readable output files. - * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. - * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) - * or disable the default devtool with "devtool: false". - * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). - */ -/******/ (function() { // webpackBootstrap -/******/ "use strict"; -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@ducanh2912/next-pwa/dist/sw-entry-worker.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@ducanh2912/next-pwa/dist/sw-entry-worker.js ***! - \*******************************************************************/ -/***/ (function(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) { - -eval(__webpack_require__.ts("__webpack_require__.r(__webpack_exports__);\nself.onmessage = async (e)=>{\n switch(e.data.type){\n case \"__START_URL_CACHE__\":\n {\n let t = e.data.url, a = await fetch(t);\n if (!a.redirected) return (await caches.open(\"start-url\")).put(t, a);\n return Promise.resolve();\n }\n case \"__FRONTEND_NAV_CACHE__\":\n {\n let t = e.data.url, a = await caches.open(\"pages\");\n if (await a.match(t, {\n ignoreSearch: !0\n })) return;\n let s = await fetch(t);\n if (!s.ok) return;\n if (a.put(t, s.clone()), e.data.shouldCacheAggressively && s.headers.get(\"Content-Type\")?.includes(\"text/html\")) try {\n let e = await s.text(), t = [], a = await caches.open(\"static-style-assets\"), r = await caches.open(\"next-static-js-assets\"), c = await caches.open(\"static-js-assets\");\n for (let [s, r] of e.matchAll(//g))/rel=['\"]stylesheet['\"]/.test(s) && t.push(a.match(r).then((e)=>e ? Promise.resolve() : a.add(r)));\n for (let [, a] of e.matchAll(//g)){\n let e = /\\/_next\\/static.+\\.js$/i.test(a) ? r : c;\n t.push(e.match(a).then((t)=>t ? Promise.resolve() : e.add(a)));\n }\n return await Promise.all(t);\n } catch {}\n return Promise.resolve();\n }\n default:\n return Promise.resolve();\n }\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvQGR1Y2FuaDI5MTIvbmV4dC1wd2EvZGlzdC9zdy1lbnRyeS13b3JrZXIuanMiLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0JBQWtCO0FBQ2xCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL19OX0UvLi9ub2RlX21vZHVsZXMvQGR1Y2FuaDI5MTIvbmV4dC1wd2EvZGlzdC9zdy1lbnRyeS13b3JrZXIuanM/NmM4NCJdLCJzb3VyY2VzQ29udGVudCI6WyJzZWxmLm9ubWVzc2FnZSA9IGFzeW5jIChlKT0+e1xuICAgIHN3aXRjaChlLmRhdGEudHlwZSl7XG4gICAgICAgIGNhc2UgXCJfX1NUQVJUX1VSTF9DQUNIRV9fXCI6XG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbGV0IHQgPSBlLmRhdGEudXJsLCBhID0gYXdhaXQgZmV0Y2godCk7XG4gICAgICAgICAgICAgICAgaWYgKCFhLnJlZGlyZWN0ZWQpIHJldHVybiAoYXdhaXQgY2FjaGVzLm9wZW4oXCJzdGFydC11cmxcIikpLnB1dCh0LCBhKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIGNhc2UgXCJfX0ZST05URU5EX05BVl9DQUNIRV9fXCI6XG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgbGV0IHQgPSBlLmRhdGEudXJsLCBhID0gYXdhaXQgY2FjaGVzLm9wZW4oXCJwYWdlc1wiKTtcbiAgICAgICAgICAgICAgICBpZiAoYXdhaXQgYS5tYXRjaCh0LCB7XG4gICAgICAgICAgICAgICAgICAgIGlnbm9yZVNlYXJjaDogITBcbiAgICAgICAgICAgICAgICB9KSkgcmV0dXJuO1xuICAgICAgICAgICAgICAgIGxldCBzID0gYXdhaXQgZmV0Y2godCk7XG4gICAgICAgICAgICAgICAgaWYgKCFzLm9rKSByZXR1cm47XG4gICAgICAgICAgICAgICAgaWYgKGEucHV0KHQsIHMuY2xvbmUoKSksIGUuZGF0YS5zaG91bGRDYWNoZUFnZ3Jlc3NpdmVseSAmJiBzLmhlYWRlcnMuZ2V0KFwiQ29udGVudC1UeXBlXCIpPy5pbmNsdWRlcyhcInRleHQvaHRtbFwiKSkgdHJ5IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IGUgPSBhd2FpdCBzLnRleHQoKSwgdCA9IFtdLCBhID0gYXdhaXQgY2FjaGVzLm9wZW4oXCJzdGF0aWMtc3R5bGUtYXNzZXRzXCIpLCByID0gYXdhaXQgY2FjaGVzLm9wZW4oXCJuZXh0LXN0YXRpYy1qcy1hc3NldHNcIiksIGMgPSBhd2FpdCBjYWNoZXMub3BlbihcInN0YXRpYy1qcy1hc3NldHNcIik7XG4gICAgICAgICAgICAgICAgICAgIGZvciAobGV0IFtzLCByXSBvZiBlLm1hdGNoQWxsKC88bGluay4qP2hyZWY9WydcIl0oLio/KVsnXCJdLio/Pi9nKSkvcmVsPVsnXCJdc3R5bGVzaGVldFsnXCJdLy50ZXN0KHMpICYmIHQucHVzaChhLm1hdGNoKHIpLnRoZW4oKGUpPT5lID8gUHJvbWlzZS5yZXNvbHZlKCkgOiBhLmFkZChyKSkpO1xuICAgICAgICAgICAgICAgICAgICBmb3IgKGxldCBbLCBhXSBvZiBlLm1hdGNoQWxsKC88c2NyaXB0Lio/c3JjPVsnXCJdKC4qPylbJ1wiXS4qPz4vZykpe1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IGUgPSAvXFwvX25leHRcXC9zdGF0aWMuK1xcLmpzJC9pLnRlc3QoYSkgPyByIDogYztcbiAgICAgICAgICAgICAgICAgICAgICAgIHQucHVzaChlLm1hdGNoKGEpLnRoZW4oKHQpPT50ID8gUHJvbWlzZS5yZXNvbHZlKCkgOiBlLmFkZChhKSkpO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBhd2FpdCBQcm9taXNlLmFsbCh0KTtcbiAgICAgICAgICAgICAgICB9IGNhdGNoICB7fVxuICAgICAgICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoKTtcbiAgICB9XG59OyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./node_modules/@ducanh2912/next-pwa/dist/sw-entry-worker.js\n")); - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The require scope -/******/ var __webpack_require__ = {}; -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/make namespace object */ -/******/ !function() { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = function(exports) { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ }(); -/******/ -/******/ /* webpack/runtime/trusted types policy */ -/******/ !function() { -/******/ var policy; -/******/ __webpack_require__.tt = function() { -/******/ // Create Trusted Type policy if Trusted Types are available and the policy doesn't exist yet. -/******/ if (policy === undefined) { -/******/ policy = { -/******/ createScript: function(script) { return script; } -/******/ }; -/******/ if (typeof trustedTypes !== "undefined" && trustedTypes.createPolicy) { -/******/ policy = trustedTypes.createPolicy("nextjs#bundler", policy); -/******/ } -/******/ } -/******/ return policy; -/******/ }; -/******/ }(); -/******/ -/******/ /* webpack/runtime/trusted types script */ -/******/ !function() { -/******/ __webpack_require__.ts = function(script) { return __webpack_require__.tt().createScript(script); }; -/******/ }(); -/******/ -/******/ /* webpack/runtime/react refresh */ -/******/ !function() { -/******/ if (__webpack_require__.i) { -/******/ __webpack_require__.i.push(function(options) { -/******/ var originalFactory = options.factory; -/******/ options.factory = function(moduleObject, moduleExports, webpackRequire) { -/******/ var hasRefresh = typeof self !== "undefined" && !!self.$RefreshInterceptModuleExecution$; -/******/ var cleanup = hasRefresh ? self.$RefreshInterceptModuleExecution$(moduleObject.id) : function() {}; -/******/ try { -/******/ originalFactory.call(this, moduleObject, moduleExports, webpackRequire); -/******/ } finally { -/******/ cleanup(); -/******/ } -/******/ } -/******/ }) -/******/ } -/******/ }(); -/******/ -/******/ /* webpack/runtime/compat */ -/******/ -/******/ -/******/ // noop fns to prevent runtime errors during initialization -/******/ if (typeof self !== "undefined") { -/******/ self.$RefreshReg$ = function () {}; -/******/ self.$RefreshSig$ = function () { -/******/ return function (type) { -/******/ return type; -/******/ }; -/******/ }; -/******/ } -/******/ -/************************************************************************/ -/******/ -/******/ // startup -/******/ // Load entry module and return exports -/******/ // This entry module can't be inlined because the eval-source-map devtool is used. -/******/ var __webpack_exports__ = {}; -/******/ __webpack_modules__["./node_modules/@ducanh2912/next-pwa/dist/sw-entry-worker.js"](0, __webpack_exports__, __webpack_require__); -/******/ -/******/ })() -; \ No newline at end of file diff --git a/public/workbox-1e54d6fe.js b/public/workbox-1e54d6fe.js deleted file mode 100644 index 876a7ee..0000000 --- a/public/workbox-1e54d6fe.js +++ /dev/null @@ -1,3593 +0,0 @@ -define(['exports'], (function (exports) { 'use strict'; - - // @ts-ignore - try { - self['workbox:core:7.0.0'] && _(); - } 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 globalThis)) { - 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 - }; - - // @ts-ignore - try { - self['workbox:routing:7.0.0'] && _(); - } 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; - } - - // @ts-ignore - try { - self['workbox:strategies:7.0.0'] && _(); - } 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. - */ - // Callbacks to be executed whenever there's a quota error. - // 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()); - } - - /* - 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. - */ - /** - * A utility method that makes it easier to use `event.waitUntil` with - * async functions and return the result. - * - * @param {ExtendableEvent} event - * @param {Function} asyncFn - * @return {Function} - * @private - */ - function waitUntil(event, asyncFn) { - const returnPromise = asyncFn(); - event.waitUntil(returnPromise); - return returnPromise; - } - - // @ts-ignore - try { - self['workbox:precaching:7.0.0'] && _(); - } 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. - */ - // Name of the search parameter used to store revision info. - const REVISION_SEARCH_PARAM = '__WB_REVISION__'; - /** - * Converts a manifest entry into a versioned URL suitable for precaching. - * - * @param {Object|string} entry - * @return {string} A URL with versioning info. - * - * @private - * @memberof workbox-precaching - */ - function createCacheKey(entry) { - if (!entry) { - throw new WorkboxError('add-to-cache-list-unexpected-type', { - entry - }); - } - // If a precache manifest entry is a string, it's assumed to be a versioned - // URL, like '/app.abcd1234.js'. Return as-is. - if (typeof entry === 'string') { - const urlObject = new URL(entry, location.href); - return { - cacheKey: urlObject.href, - url: urlObject.href - }; - } - const { - revision, - url - } = entry; - if (!url) { - throw new WorkboxError('add-to-cache-list-unexpected-type', { - entry - }); - } - // If there's just a URL and no revision, then it's also assumed to be a - // versioned URL. - if (!revision) { - const urlObject = new URL(url, location.href); - return { - cacheKey: urlObject.href, - url: urlObject.href - }; - } - // Otherwise, construct a properly versioned URL using the custom Workbox - // search parameter along with the revision info. - const cacheKeyURL = new URL(url, location.href); - const originalURL = new URL(url, location.href); - cacheKeyURL.searchParams.set(REVISION_SEARCH_PARAM, revision); - return { - cacheKey: cacheKeyURL.href, - url: originalURL.href - }; - } - - /* - 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. - */ - /** - * A plugin, designed to be used with PrecacheController, to determine the - * of assets that were updated (or not updated) during the install event. - * - * @private - */ - class PrecacheInstallReportPlugin { - constructor() { - this.updatedURLs = []; - this.notUpdatedURLs = []; - this.handlerWillStart = async ({ - request, - state - }) => { - // TODO: `state` should never be undefined... - if (state) { - state.originalRequest = request; - } - }; - this.cachedResponseWillBeUsed = async ({ - event, - state, - cachedResponse - }) => { - if (event.type === 'install') { - if (state && state.originalRequest && state.originalRequest instanceof Request) { - // TODO: `state` should never be undefined... - const url = state.originalRequest.url; - if (cachedResponse) { - this.notUpdatedURLs.push(url); - } else { - this.updatedURLs.push(url); - } - } - } - return cachedResponse; - }; - } - } - - /* - 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. - */ - /** - * A plugin, designed to be used with PrecacheController, to translate URLs into - * the corresponding cache key, based on the current revision info. - * - * @private - */ - class PrecacheCacheKeyPlugin { - constructor({ - precacheController - }) { - this.cacheKeyWillBeUsed = async ({ - request, - params - }) => { - // Params is type any, can't change right now. - /* eslint-disable */ - const cacheKey = (params === null || params === void 0 ? void 0 : params.cacheKey) || this._precacheController.getCacheKeyForURL(request.url); - /* eslint-enable */ - return cacheKey ? new Request(cacheKey, { - headers: request.headers - }) : request; - }; - this._precacheController = precacheController; - } - } - - /* - 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 {string} groupTitle - * @param {Array} deletedURLs - * - * @private - */ - const logGroup = (groupTitle, deletedURLs) => { - logger.groupCollapsed(groupTitle); - for (const url of deletedURLs) { - logger.log(url); - } - logger.groupEnd(); - }; - /** - * @param {Array} deletedURLs - * - * @private - * @memberof workbox-precaching - */ - function printCleanupDetails(deletedURLs) { - const deletionCount = deletedURLs.length; - if (deletionCount > 0) { - logger.groupCollapsed(`During precaching cleanup, ` + `${deletionCount} cached ` + `request${deletionCount === 1 ? ' was' : 's were'} deleted.`); - logGroup('Deleted Cache Requests', deletedURLs); - 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. - */ - /** - * @param {string} groupTitle - * @param {Array} urls - * - * @private - */ - function _nestedGroup(groupTitle, urls) { - if (urls.length === 0) { - return; - } - logger.groupCollapsed(groupTitle); - for (const url of urls) { - logger.log(url); - } - logger.groupEnd(); - } - /** - * @param {Array} urlsToPrecache - * @param {Array} urlsAlreadyPrecached - * - * @private - * @memberof workbox-precaching - */ - function printInstallDetails(urlsToPrecache, urlsAlreadyPrecached) { - const precachedCount = urlsToPrecache.length; - const alreadyPrecachedCount = urlsAlreadyPrecached.length; - if (precachedCount || alreadyPrecachedCount) { - let message = `Precaching ${precachedCount} file${precachedCount === 1 ? '' : 's'}.`; - if (alreadyPrecachedCount > 0) { - message += ` ${alreadyPrecachedCount} ` + `file${alreadyPrecachedCount === 1 ? ' is' : 's are'} already cached.`; - } - logger.groupCollapsed(message); - _nestedGroup(`View newly precached URLs.`, urlsToPrecache); - _nestedGroup(`View previously precached URLs.`, urlsAlreadyPrecached); - logger.groupEnd(); - } - } - - /* - 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 supportStatus; - /** - * A utility function that determines whether the current browser supports - * constructing a new `Response` from a `response.body` stream. - * - * @return {boolean} `true`, if the current browser can successfully - * construct a `Response` from a `response.body` stream, `false` otherwise. - * - * @private - */ - function canConstructResponseFromBodyStream() { - if (supportStatus === undefined) { - const testResponse = new Response(''); - if ('body' in testResponse) { - try { - new Response(testResponse.body); - supportStatus = true; - } catch (error) { - supportStatus = false; - } - } - supportStatus = false; - } - return supportStatus; - } - - /* - 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. - */ - /** - * Allows developers to copy a response and modify its `headers`, `status`, - * or `statusText` values (the values settable via a - * [`ResponseInit`]{@link https://developer.mozilla.org/en-US/docs/Web/API/Response/Response#Syntax} - * object in the constructor). - * To modify these values, pass a function as the second argument. That - * function will be invoked with a single object with the response properties - * `{headers, status, statusText}`. The return value of this function will - * be used as the `ResponseInit` for the new `Response`. To change the values - * either modify the passed parameter(s) and return it, or return a totally - * new object. - * - * This method is intentionally limited to same-origin responses, regardless of - * whether CORS was used or not. - * - * @param {Response} response - * @param {Function} modifier - * @memberof workbox-core - */ - async function copyResponse(response, modifier) { - let origin = null; - // If response.url isn't set, assume it's cross-origin and keep origin null. - if (response.url) { - const responseURL = new URL(response.url); - origin = responseURL.origin; - } - if (origin !== self.location.origin) { - throw new WorkboxError('cross-origin-copy-response', { - origin - }); - } - const clonedResponse = response.clone(); - // Create a fresh `ResponseInit` object by cloning the headers. - const responseInit = { - headers: new Headers(clonedResponse.headers), - status: clonedResponse.status, - statusText: clonedResponse.statusText - }; - // Apply any user modifications. - const modifiedResponseInit = modifier ? modifier(responseInit) : responseInit; - // Create the new response from the body stream and `ResponseInit` - // modifications. Note: not all browsers support the Response.body stream, - // so fall back to reading the entire body into memory as a blob. - const body = canConstructResponseFromBodyStream() ? clonedResponse.body : await clonedResponse.blob(); - return new Response(body, modifiedResponseInit); - } - - /* - 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. - */ - /** - * A {@link workbox-strategies.Strategy} implementation - * specifically designed to work with - * {@link workbox-precaching.PrecacheController} - * to both cache and fetch precached assets. - * - * Note: an instance of this class is created automatically when creating a - * `PrecacheController`; it's generally not necessary to create this yourself. - * - * @extends workbox-strategies.Strategy - * @memberof workbox-precaching - */ - class PrecacheStrategy extends Strategy { - /** - * - * @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] {@link https://developers.google.com/web/tools/workbox/guides/using-plugins|Plugins} - * to use in conjunction with this caching strategy. - * @param {Object} [options.fetchOptions] Values passed along to the - * {@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters|init} - * of all fetch() requests made by this strategy. - * @param {Object} [options.matchOptions] The - * {@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions|CacheQueryOptions} - * for any `cache.match()` or `cache.put()` calls made by this strategy. - * @param {boolean} [options.fallbackToNetwork=true] Whether to attempt to - * get the response from the network if there's a precache miss. - */ - constructor(options = {}) { - options.cacheName = cacheNames.getPrecacheName(options.cacheName); - super(options); - this._fallbackToNetwork = options.fallbackToNetwork === false ? false : true; - // Redirected responses cannot be used to satisfy a navigation request, so - // any redirected response must be "copied" rather than cloned, so the new - // response doesn't contain the `redirected` flag. See: - // https://bugs.chromium.org/p/chromium/issues/detail?id=669363&desc=2#c1 - this.plugins.push(PrecacheStrategy.copyRedirectedCacheableResponsesPlugin); - } - /** - * @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 response = await handler.cacheMatch(request); - if (response) { - return response; - } - // If this is an `install` event for an entry that isn't already cached, - // then populate the cache. - if (handler.event && handler.event.type === 'install') { - return await this._handleInstall(request, handler); - } - // Getting here means something went wrong. An entry that should have been - // precached wasn't found in the cache. - return await this._handleFetch(request, handler); - } - async _handleFetch(request, handler) { - let response; - const params = handler.params || {}; - // Fall back to the network if we're configured to do so. - if (this._fallbackToNetwork) { - { - logger.warn(`The precached response for ` + `${getFriendlyURL(request.url)} in ${this.cacheName} was not ` + `found. Falling back to the network.`); - } - const integrityInManifest = params.integrity; - const integrityInRequest = request.integrity; - const noIntegrityConflict = !integrityInRequest || integrityInRequest === integrityInManifest; - // Do not add integrity if the original request is no-cors - // See https://github.com/GoogleChrome/workbox/issues/3096 - response = await handler.fetch(new Request(request, { - integrity: request.mode !== 'no-cors' ? integrityInRequest || integrityInManifest : undefined - })); - // It's only "safe" to repair the cache if we're using SRI to guarantee - // that the response matches the precache manifest's expectations, - // and there's either a) no integrity property in the incoming request - // or b) there is an integrity, and it matches the precache manifest. - // See https://github.com/GoogleChrome/workbox/issues/2858 - // Also if the original request users no-cors we don't use integrity. - // See https://github.com/GoogleChrome/workbox/issues/3096 - if (integrityInManifest && noIntegrityConflict && request.mode !== 'no-cors') { - this._useDefaultCacheabilityPluginIfNeeded(); - const wasCached = await handler.cachePut(request, response.clone()); - { - if (wasCached) { - logger.log(`A response for ${getFriendlyURL(request.url)} ` + `was used to "repair" the precache.`); - } - } - } - } else { - // This shouldn't normally happen, but there are edge cases: - // https://github.com/GoogleChrome/workbox/issues/1441 - throw new WorkboxError('missing-precache-entry', { - cacheName: this.cacheName, - url: request.url - }); - } - { - const cacheKey = params.cacheKey || (await handler.getCacheKey(request, 'read')); - // Workbox is going to handle the route. - // print the routing details to the console. - logger.groupCollapsed(`Precaching is responding to: ` + getFriendlyURL(request.url)); - logger.log(`Serving the precached url: ${getFriendlyURL(cacheKey instanceof Request ? cacheKey.url : cacheKey)}`); - logger.groupCollapsed(`View request details here.`); - logger.log(request); - logger.groupEnd(); - logger.groupCollapsed(`View response details here.`); - logger.log(response); - logger.groupEnd(); - logger.groupEnd(); - } - return response; - } - async _handleInstall(request, handler) { - this._useDefaultCacheabilityPluginIfNeeded(); - const response = await handler.fetch(request); - // Make sure we defer cachePut() until after we know the response - // should be cached; see https://github.com/GoogleChrome/workbox/issues/2737 - const wasCached = await handler.cachePut(request, response.clone()); - if (!wasCached) { - // Throwing here will lead to the `install` handler failing, which - // we want to do if *any* of the responses aren't safe to cache. - throw new WorkboxError('bad-precaching-response', { - url: request.url, - status: response.status - }); - } - return response; - } - /** - * This method is complex, as there a number of things to account for: - * - * The `plugins` array can be set at construction, and/or it might be added to - * to at any time before the strategy is used. - * - * At the time the strategy is used (i.e. during an `install` event), there - * needs to be at least one plugin that implements `cacheWillUpdate` in the - * array, other than `copyRedirectedCacheableResponsesPlugin`. - * - * - If this method is called and there are no suitable `cacheWillUpdate` - * plugins, we need to add `defaultPrecacheCacheabilityPlugin`. - * - * - If this method is called and there is exactly one `cacheWillUpdate`, then - * we don't have to do anything (this might be a previously added - * `defaultPrecacheCacheabilityPlugin`, or it might be a custom plugin). - * - * - If this method is called and there is more than one `cacheWillUpdate`, - * then we need to check if one is `defaultPrecacheCacheabilityPlugin`. If so, - * we need to remove it. (This situation is unlikely, but it could happen if - * the strategy is used multiple times, the first without a `cacheWillUpdate`, - * and then later on after manually adding a custom `cacheWillUpdate`.) - * - * See https://github.com/GoogleChrome/workbox/issues/2737 for more context. - * - * @private - */ - _useDefaultCacheabilityPluginIfNeeded() { - let defaultPluginIndex = null; - let cacheWillUpdatePluginCount = 0; - for (const [index, plugin] of this.plugins.entries()) { - // Ignore the copy redirected plugin when determining what to do. - if (plugin === PrecacheStrategy.copyRedirectedCacheableResponsesPlugin) { - continue; - } - // Save the default plugin's index, in case it needs to be removed. - if (plugin === PrecacheStrategy.defaultPrecacheCacheabilityPlugin) { - defaultPluginIndex = index; - } - if (plugin.cacheWillUpdate) { - cacheWillUpdatePluginCount++; - } - } - if (cacheWillUpdatePluginCount === 0) { - this.plugins.push(PrecacheStrategy.defaultPrecacheCacheabilityPlugin); - } else if (cacheWillUpdatePluginCount > 1 && defaultPluginIndex !== null) { - // Only remove the default plugin; multiple custom plugins are allowed. - this.plugins.splice(defaultPluginIndex, 1); - } - // Nothing needs to be done if cacheWillUpdatePluginCount is 1 - } - } - PrecacheStrategy.defaultPrecacheCacheabilityPlugin = { - async cacheWillUpdate({ - response - }) { - if (!response || response.status >= 400) { - return null; - } - return response; - } - }; - PrecacheStrategy.copyRedirectedCacheableResponsesPlugin = { - async cacheWillUpdate({ - response - }) { - return response.redirected ? await copyResponse(response) : 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. - */ - /** - * Performs efficient precaching of assets. - * - * @memberof workbox-precaching - */ - class PrecacheController { - /** - * Create a new PrecacheController. - * - * @param {Object} [options] - * @param {string} [options.cacheName] The cache to use for precaching. - * @param {string} [options.plugins] Plugins to use when precaching as well - * as responding to fetch events for precached assets. - * @param {boolean} [options.fallbackToNetwork=true] Whether to attempt to - * get the response from the network if there's a precache miss. - */ - constructor({ - cacheName, - plugins = [], - fallbackToNetwork = true - } = {}) { - this._urlsToCacheKeys = new Map(); - this._urlsToCacheModes = new Map(); - this._cacheKeysToIntegrities = new Map(); - this._strategy = new PrecacheStrategy({ - cacheName: cacheNames.getPrecacheName(cacheName), - plugins: [...plugins, new PrecacheCacheKeyPlugin({ - precacheController: this - })], - fallbackToNetwork - }); - // Bind the install and activate methods to the instance. - this.install = this.install.bind(this); - this.activate = this.activate.bind(this); - } - /** - * @type {workbox-precaching.PrecacheStrategy} The strategy created by this controller and - * used to cache assets and respond to fetch events. - */ - get strategy() { - return this._strategy; - } - /** - * Adds items to the precache list, removing any duplicates and - * stores the files in the - * {@link workbox-core.cacheNames|"precache cache"} when the service - * worker installs. - * - * This method can be called multiple times. - * - * @param {Array} [entries=[]] Array of entries to precache. - */ - precache(entries) { - this.addToCacheList(entries); - if (!this._installAndActiveListenersAdded) { - self.addEventListener('install', this.install); - self.addEventListener('activate', this.activate); - this._installAndActiveListenersAdded = true; - } - } - /** - * This method will add items to the precache list, removing duplicates - * and ensuring the information is valid. - * - * @param {Array} entries - * Array of entries to precache. - */ - addToCacheList(entries) { - { - finalAssertExports.isArray(entries, { - moduleName: 'workbox-precaching', - className: 'PrecacheController', - funcName: 'addToCacheList', - paramName: 'entries' - }); - } - const urlsToWarnAbout = []; - for (const entry of entries) { - // See https://github.com/GoogleChrome/workbox/issues/2259 - if (typeof entry === 'string') { - urlsToWarnAbout.push(entry); - } else if (entry && entry.revision === undefined) { - urlsToWarnAbout.push(entry.url); - } - const { - cacheKey, - url - } = createCacheKey(entry); - const cacheMode = typeof entry !== 'string' && entry.revision ? 'reload' : 'default'; - if (this._urlsToCacheKeys.has(url) && this._urlsToCacheKeys.get(url) !== cacheKey) { - throw new WorkboxError('add-to-cache-list-conflicting-entries', { - firstEntry: this._urlsToCacheKeys.get(url), - secondEntry: cacheKey - }); - } - if (typeof entry !== 'string' && entry.integrity) { - if (this._cacheKeysToIntegrities.has(cacheKey) && this._cacheKeysToIntegrities.get(cacheKey) !== entry.integrity) { - throw new WorkboxError('add-to-cache-list-conflicting-integrities', { - url - }); - } - this._cacheKeysToIntegrities.set(cacheKey, entry.integrity); - } - this._urlsToCacheKeys.set(url, cacheKey); - this._urlsToCacheModes.set(url, cacheMode); - if (urlsToWarnAbout.length > 0) { - const warningMessage = `Workbox is precaching URLs without revision ` + `info: ${urlsToWarnAbout.join(', ')}\nThis is generally NOT safe. ` + `Learn more at https://bit.ly/wb-precache`; - { - logger.warn(warningMessage); - } - } - } - } - /** - * Precaches new and updated assets. Call this method from the service worker - * install event. - * - * Note: this method calls `event.waitUntil()` for you, so you do not need - * to call it yourself in your event handlers. - * - * @param {ExtendableEvent} event - * @return {Promise} - */ - install(event) { - // waitUntil returns Promise - // eslint-disable-next-line @typescript-eslint/no-unsafe-return - return waitUntil(event, async () => { - const installReportPlugin = new PrecacheInstallReportPlugin(); - this.strategy.plugins.push(installReportPlugin); - // Cache entries one at a time. - // See https://github.com/GoogleChrome/workbox/issues/2528 - for (const [url, cacheKey] of this._urlsToCacheKeys) { - const integrity = this._cacheKeysToIntegrities.get(cacheKey); - const cacheMode = this._urlsToCacheModes.get(url); - const request = new Request(url, { - integrity, - cache: cacheMode, - credentials: 'same-origin' - }); - await Promise.all(this.strategy.handleAll({ - params: { - cacheKey - }, - request, - event - })); - } - const { - updatedURLs, - notUpdatedURLs - } = installReportPlugin; - { - printInstallDetails(updatedURLs, notUpdatedURLs); - } - return { - updatedURLs, - notUpdatedURLs - }; - }); - } - /** - * Deletes assets that are no longer present in the current precache manifest. - * Call this method from the service worker activate event. - * - * Note: this method calls `event.waitUntil()` for you, so you do not need - * to call it yourself in your event handlers. - * - * @param {ExtendableEvent} event - * @return {Promise} - */ - activate(event) { - // waitUntil returns Promise - // eslint-disable-next-line @typescript-eslint/no-unsafe-return - return waitUntil(event, async () => { - const cache = await self.caches.open(this.strategy.cacheName); - const currentlyCachedRequests = await cache.keys(); - const expectedCacheKeys = new Set(this._urlsToCacheKeys.values()); - const deletedURLs = []; - for (const request of currentlyCachedRequests) { - if (!expectedCacheKeys.has(request.url)) { - await cache.delete(request); - deletedURLs.push(request.url); - } - } - { - printCleanupDetails(deletedURLs); - } - return { - deletedURLs - }; - }); - } - /** - * Returns a mapping of a precached URL to the corresponding cache key, taking - * into account the revision information for the URL. - * - * @return {Map} A URL to cache key mapping. - */ - getURLsToCacheKeys() { - return this._urlsToCacheKeys; - } - /** - * Returns a list of all the URLs that have been precached by the current - * service worker. - * - * @return {Array} The precached URLs. - */ - getCachedURLs() { - return [...this._urlsToCacheKeys.keys()]; - } - /** - * Returns the cache key used for storing a given URL. If that URL is - * unversioned, like `/index.html', then the cache key will be the original - * URL with a search parameter appended to it. - * - * @param {string} url A URL whose cache key you want to look up. - * @return {string} The versioned URL that corresponds to a cache key - * for the original URL, or undefined if that URL isn't precached. - */ - getCacheKeyForURL(url) { - const urlObject = new URL(url, location.href); - return this._urlsToCacheKeys.get(urlObject.href); - } - /** - * @param {string} url A cache key whose SRI you want to look up. - * @return {string} The subresource integrity associated with the cache key, - * or undefined if it's not set. - */ - getIntegrityForCacheKey(cacheKey) { - return this._cacheKeysToIntegrities.get(cacheKey); - } - /** - * This acts as a drop-in replacement for - * [`cache.match()`](https://developer.mozilla.org/en-US/docs/Web/API/Cache/match) - * with the following differences: - * - * - It knows what the name of the precache is, and only checks in that cache. - * - It allows you to pass in an "original" URL without versioning parameters, - * and it will automatically look up the correct cache key for the currently - * active revision of that URL. - * - * E.g., `matchPrecache('index.html')` will find the correct precached - * response for the currently active service worker, even if the actual cache - * key is `'/index.html?__WB_REVISION__=1234abcd'`. - * - * @param {string|Request} request The key (without revisioning parameters) - * to look up in the precache. - * @return {Promise} - */ - async matchPrecache(request) { - const url = request instanceof Request ? request.url : request; - const cacheKey = this.getCacheKeyForURL(url); - if (cacheKey) { - const cache = await self.caches.open(this.strategy.cacheName); - return cache.match(cacheKey); - } - return undefined; - } - /** - * Returns a function that looks up `url` in the precache (taking into - * account revision information), and returns the corresponding `Response`. - * - * @param {string} url The precached URL which will be used to lookup the - * `Response`. - * @return {workbox-routing~handlerCallback} - */ - createHandlerBoundToURL(url) { - const cacheKey = this.getCacheKeyForURL(url); - if (!cacheKey) { - throw new WorkboxError('non-precached-url', { - url - }); - } - return options => { - options.request = new Request(url); - options.params = Object.assign({ - cacheKey - }, options.params); - return this.strategy.handle(options); - }; - } - } - - /* - 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 precacheController; - /** - * @return {PrecacheController} - * @private - */ - const getOrCreatePrecacheController = () => { - if (!precacheController) { - precacheController = new PrecacheController(); - } - return precacheController; - }; - - /* - 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. - */ - /** - * Removes any URL search parameters that should be ignored. - * - * @param {URL} urlObject The original URL. - * @param {Array} ignoreURLParametersMatching RegExps to test against - * each search parameter name. Matches mean that the search parameter should be - * ignored. - * @return {URL} The URL with any ignored search parameters removed. - * - * @private - * @memberof workbox-precaching - */ - function removeIgnoredSearchParams(urlObject, ignoreURLParametersMatching = []) { - // Convert the iterable into an array at the start of the loop to make sure - // deletion doesn't mess up iteration. - for (const paramName of [...urlObject.searchParams.keys()]) { - if (ignoreURLParametersMatching.some(regExp => regExp.test(paramName))) { - urlObject.searchParams.delete(paramName); - } - } - return urlObject; - } - - /* - 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. - */ - /** - * Generator function that yields possible variations on the original URL to - * check, one at a time. - * - * @param {string} url - * @param {Object} options - * - * @private - * @memberof workbox-precaching - */ - function* generateURLVariations(url, { - ignoreURLParametersMatching = [/^utm_/, /^fbclid$/], - directoryIndex = 'index.html', - cleanURLs = true, - urlManipulation - } = {}) { - const urlObject = new URL(url, location.href); - urlObject.hash = ''; - yield urlObject.href; - const urlWithoutIgnoredParams = removeIgnoredSearchParams(urlObject, ignoreURLParametersMatching); - yield urlWithoutIgnoredParams.href; - if (directoryIndex && urlWithoutIgnoredParams.pathname.endsWith('/')) { - const directoryURL = new URL(urlWithoutIgnoredParams.href); - directoryURL.pathname += directoryIndex; - yield directoryURL.href; - } - if (cleanURLs) { - const cleanURL = new URL(urlWithoutIgnoredParams.href); - cleanURL.pathname += '.html'; - yield cleanURL.href; - } - if (urlManipulation) { - const additionalURLs = urlManipulation({ - url: urlObject - }); - for (const urlToAttempt of additionalURLs) { - yield urlToAttempt.href; - } - } - } - - /* - 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. - */ - /** - * A subclass of {@link workbox-routing.Route} that takes a - * {@link workbox-precaching.PrecacheController} - * instance and uses it to match incoming requests and handle fetching - * responses from the precache. - * - * @memberof workbox-precaching - * @extends workbox-routing.Route - */ - class PrecacheRoute extends Route { - /** - * @param {PrecacheController} precacheController A `PrecacheController` - * instance used to both match requests and respond to fetch events. - * @param {Object} [options] Options to control how requests are matched - * against the list of precached URLs. - * @param {string} [options.directoryIndex=index.html] The `directoryIndex` will - * check cache entries for a URLs ending with '/' to see if there is a hit when - * appending the `directoryIndex` value. - * @param {Array} [options.ignoreURLParametersMatching=[/^utm_/, /^fbclid$/]] An - * array of regex's to remove search params when looking for a cache match. - * @param {boolean} [options.cleanURLs=true] The `cleanURLs` option will - * check the cache for the URL with a `.html` added to the end of the end. - * @param {workbox-precaching~urlManipulation} [options.urlManipulation] - * This is a function that should take a URL and return an array of - * alternative URLs that should be checked for precache matches. - */ - constructor(precacheController, options) { - const match = ({ - request - }) => { - const urlsToCacheKeys = precacheController.getURLsToCacheKeys(); - for (const possibleURL of generateURLVariations(request.url, options)) { - const cacheKey = urlsToCacheKeys.get(possibleURL); - if (cacheKey) { - const integrity = precacheController.getIntegrityForCacheKey(cacheKey); - return { - cacheKey, - integrity - }; - } - } - { - logger.debug(`Precaching did not find a match for ` + getFriendlyURL(request.url)); - } - return; - }; - super(match, precacheController.strategy); - } - } - - /* - 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. - */ - /** - * Add a `fetch` listener to the service worker that will - * respond to - * [network requests]{@link https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API/Using_Service_Workers#Custom_responses_to_requests} - * with precached assets. - * - * Requests for assets that aren't precached, the `FetchEvent` will not be - * responded to, allowing the event to fall through to other `fetch` event - * listeners. - * - * @param {Object} [options] See the {@link workbox-precaching.PrecacheRoute} - * options. - * - * @memberof workbox-precaching - */ - function addRoute(options) { - const precacheController = getOrCreatePrecacheController(); - const precacheRoute = new PrecacheRoute(precacheController, options); - registerRoute(precacheRoute); - } - - /* - 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. - */ - /** - * Adds items to the precache list, removing any duplicates and - * stores the files in the - * {@link workbox-core.cacheNames|"precache cache"} when the service - * worker installs. - * - * This method can be called multiple times. - * - * Please note: This method **will not** serve any of the cached files for you. - * It only precaches files. To respond to a network request you call - * {@link workbox-precaching.addRoute}. - * - * If you have a single array of files to precache, you can just call - * {@link workbox-precaching.precacheAndRoute}. - * - * @param {Array} [entries=[]] Array of entries to precache. - * - * @memberof workbox-precaching - */ - function precache(entries) { - const precacheController = getOrCreatePrecacheController(); - precacheController.precache(entries); - } - - /* - 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. - */ - /** - * This method will add entries to the precache list and add a route to - * respond to fetch events. - * - * This is a convenience method that will call - * {@link workbox-precaching.precache} and - * {@link workbox-precaching.addRoute} in a single call. - * - * @param {Array} entries Array of entries to precache. - * @param {Object} [options] See the - * {@link workbox-precaching.PrecacheRoute} options. - * - * @memberof workbox-precaching - */ - function precacheAndRoute(entries, options) { - precache(entries); - addRoute(options); - } - - /* - 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 SUBSTRING_TO_FIND = '-precache-'; - /** - * Cleans up incompatible precaches that were created by older versions of - * Workbox, by a service worker registered under the current scope. - * - * This is meant to be called as part of the `activate` event. - * - * This should be safe to use as long as you don't include `substringToFind` - * (defaulting to `-precache-`) in your non-precache cache names. - * - * @param {string} currentPrecacheName The cache name currently in use for - * precaching. This cache won't be deleted. - * @param {string} [substringToFind='-precache-'] Cache names which include this - * substring will be deleted (excluding `currentPrecacheName`). - * @return {Array} A list of all the cache names that were deleted. - * - * @private - * @memberof workbox-precaching - */ - const deleteOutdatedCaches = async (currentPrecacheName, substringToFind = SUBSTRING_TO_FIND) => { - const cacheNames = await self.caches.keys(); - const cacheNamesToDelete = cacheNames.filter(cacheName => { - return cacheName.includes(substringToFind) && cacheName.includes(self.registration.scope) && cacheName !== currentPrecacheName; - }); - await Promise.all(cacheNamesToDelete.map(cacheName => self.caches.delete(cacheName))); - return cacheNamesToDelete; - }; - - /* - 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. - */ - /** - * Adds an `activate` event listener which will clean up incompatible - * precaches that were created by older versions of Workbox. - * - * @memberof workbox-precaching - */ - function cleanupOutdatedCaches() { - // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705 - self.addEventListener('activate', event => { - const cacheName = cacheNames.getPrecacheName(); - event.waitUntil(deleteOutdatedCaches(cacheName).then(cachesDeleted => { - { - if (cachesDeleted.length > 0) { - logger.log(`The following out-of-date precaches were cleaned up ` + `automatically:`, cachesDeleted); - } - } - })); - }); - } - - exports.NetworkFirst = NetworkFirst; - exports.NetworkOnly = NetworkOnly; - exports.cleanupOutdatedCaches = cleanupOutdatedCaches; - exports.clientsClaim = clientsClaim; - exports.precacheAndRoute = precacheAndRoute; - exports.registerRoute = registerRoute; - -})); -//# sourceMappingURL=workbox-1e54d6fe.js.map diff --git a/public/workbox-1e54d6fe.js.map b/public/workbox-1e54d6fe.js.map deleted file mode 100644 index ad45f3b..0000000 --- a/public/workbox-1e54d6fe.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"workbox-1e54d6fe.js","sources":["node_modules/workbox-core/_version.js","node_modules/workbox-core/_private/logger.js","node_modules/workbox-core/models/messages/messages.js","node_modules/workbox-core/models/messages/messageGenerator.js","node_modules/workbox-core/_private/WorkboxError.js","node_modules/workbox-core/_private/assert.js","node_modules/workbox-routing/_version.js","node_modules/workbox-routing/utils/constants.js","node_modules/workbox-routing/utils/normalizeHandler.js","node_modules/workbox-routing/Route.js","node_modules/workbox-routing/RegExpRoute.js","node_modules/workbox-core/_private/getFriendlyURL.js","node_modules/workbox-routing/Router.js","node_modules/workbox-routing/utils/getOrCreateDefaultRouter.js","node_modules/workbox-routing/registerRoute.js","node_modules/workbox-strategies/_version.js","node_modules/workbox-strategies/plugins/cacheOkAndOpaquePlugin.js","node_modules/workbox-core/_private/cacheNames.js","node_modules/workbox-core/_private/cacheMatchIgnoreParams.js","node_modules/workbox-core/_private/Deferred.js","node_modules/workbox-core/models/quotaErrorCallbacks.js","node_modules/workbox-core/_private/executeQuotaErrorCallbacks.js","node_modules/workbox-core/_private/timeout.js","node_modules/workbox-strategies/StrategyHandler.js","node_modules/workbox-strategies/Strategy.js","node_modules/workbox-strategies/utils/messages.js","node_modules/workbox-strategies/NetworkFirst.js","node_modules/workbox-strategies/NetworkOnly.js","node_modules/workbox-core/clientsClaim.js","node_modules/workbox-core/_private/waitUntil.js","node_modules/workbox-precaching/_version.js","node_modules/workbox-precaching/utils/createCacheKey.js","node_modules/workbox-precaching/utils/PrecacheInstallReportPlugin.js","node_modules/workbox-precaching/utils/PrecacheCacheKeyPlugin.js","node_modules/workbox-precaching/utils/printCleanupDetails.js","node_modules/workbox-precaching/utils/printInstallDetails.js","node_modules/workbox-core/_private/canConstructResponseFromBodyStream.js","node_modules/workbox-core/copyResponse.js","node_modules/workbox-precaching/PrecacheStrategy.js","node_modules/workbox-precaching/PrecacheController.js","node_modules/workbox-precaching/utils/getOrCreatePrecacheController.js","node_modules/workbox-precaching/utils/removeIgnoredSearchParams.js","node_modules/workbox-precaching/utils/generateURLVariations.js","node_modules/workbox-precaching/PrecacheRoute.js","node_modules/workbox-precaching/addRoute.js","node_modules/workbox-precaching/precache.js","node_modules/workbox-precaching/precacheAndRoute.js","node_modules/workbox-precaching/utils/deleteOutdatedCaches.js","node_modules/workbox-precaching/cleanupOutdatedCaches.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:7.0.0'] && _();\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 globalThis)) {\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:7.0.0'] && _();\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:7.0.0'] && _();\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","/*\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';\n/**\n * A utility method that makes it easier to use `event.waitUntil` with\n * async functions and return the result.\n *\n * @param {ExtendableEvent} event\n * @param {Function} asyncFn\n * @return {Function}\n * @private\n */\nfunction waitUntil(event, asyncFn) {\n const returnPromise = asyncFn();\n event.waitUntil(returnPromise);\n return returnPromise;\n}\nexport { waitUntil };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:precaching:7.0.0'] && _();\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 { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport '../_version.js';\n// Name of the search parameter used to store revision info.\nconst REVISION_SEARCH_PARAM = '__WB_REVISION__';\n/**\n * Converts a manifest entry into a versioned URL suitable for precaching.\n *\n * @param {Object|string} entry\n * @return {string} A URL with versioning info.\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function createCacheKey(entry) {\n if (!entry) {\n throw new WorkboxError('add-to-cache-list-unexpected-type', { entry });\n }\n // If a precache manifest entry is a string, it's assumed to be a versioned\n // URL, like '/app.abcd1234.js'. Return as-is.\n if (typeof entry === 'string') {\n const urlObject = new URL(entry, location.href);\n return {\n cacheKey: urlObject.href,\n url: urlObject.href,\n };\n }\n const { revision, url } = entry;\n if (!url) {\n throw new WorkboxError('add-to-cache-list-unexpected-type', { entry });\n }\n // If there's just a URL and no revision, then it's also assumed to be a\n // versioned URL.\n if (!revision) {\n const urlObject = new URL(url, location.href);\n return {\n cacheKey: urlObject.href,\n url: urlObject.href,\n };\n }\n // Otherwise, construct a properly versioned URL using the custom Workbox\n // search parameter along with the revision info.\n const cacheKeyURL = new URL(url, location.href);\n const originalURL = new URL(url, location.href);\n cacheKeyURL.searchParams.set(REVISION_SEARCH_PARAM, revision);\n return {\n cacheKey: cacheKeyURL.href,\n url: originalURL.href,\n };\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 '../_version.js';\n/**\n * A plugin, designed to be used with PrecacheController, to determine the\n * of assets that were updated (or not updated) during the install event.\n *\n * @private\n */\nclass PrecacheInstallReportPlugin {\n constructor() {\n this.updatedURLs = [];\n this.notUpdatedURLs = [];\n this.handlerWillStart = async ({ request, state, }) => {\n // TODO: `state` should never be undefined...\n if (state) {\n state.originalRequest = request;\n }\n };\n this.cachedResponseWillBeUsed = async ({ event, state, cachedResponse, }) => {\n if (event.type === 'install') {\n if (state &&\n state.originalRequest &&\n state.originalRequest instanceof Request) {\n // TODO: `state` should never be undefined...\n const url = state.originalRequest.url;\n if (cachedResponse) {\n this.notUpdatedURLs.push(url);\n }\n else {\n this.updatedURLs.push(url);\n }\n }\n }\n return cachedResponse;\n };\n }\n}\nexport { PrecacheInstallReportPlugin };\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 '../_version.js';\n/**\n * A plugin, designed to be used with PrecacheController, to translate URLs into\n * the corresponding cache key, based on the current revision info.\n *\n * @private\n */\nclass PrecacheCacheKeyPlugin {\n constructor({ precacheController }) {\n this.cacheKeyWillBeUsed = async ({ request, params, }) => {\n // Params is type any, can't change right now.\n /* eslint-disable */\n const cacheKey = (params === null || params === void 0 ? void 0 : params.cacheKey) ||\n this._precacheController.getCacheKeyForURL(request.url);\n /* eslint-enable */\n return cacheKey\n ? new Request(cacheKey, { headers: request.headers })\n : request;\n };\n this._precacheController = precacheController;\n }\n}\nexport { PrecacheCacheKeyPlugin };\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 '../_version.js';\n/**\n * @param {string} groupTitle\n * @param {Array} deletedURLs\n *\n * @private\n */\nconst logGroup = (groupTitle, deletedURLs) => {\n logger.groupCollapsed(groupTitle);\n for (const url of deletedURLs) {\n logger.log(url);\n }\n logger.groupEnd();\n};\n/**\n * @param {Array} deletedURLs\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function printCleanupDetails(deletedURLs) {\n const deletionCount = deletedURLs.length;\n if (deletionCount > 0) {\n logger.groupCollapsed(`During precaching cleanup, ` +\n `${deletionCount} cached ` +\n `request${deletionCount === 1 ? ' was' : 's were'} deleted.`);\n logGroup('Deleted Cache Requests', deletedURLs);\n logger.groupEnd();\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 { logger } from 'workbox-core/_private/logger.js';\nimport '../_version.js';\n/**\n * @param {string} groupTitle\n * @param {Array} urls\n *\n * @private\n */\nfunction _nestedGroup(groupTitle, urls) {\n if (urls.length === 0) {\n return;\n }\n logger.groupCollapsed(groupTitle);\n for (const url of urls) {\n logger.log(url);\n }\n logger.groupEnd();\n}\n/**\n * @param {Array} urlsToPrecache\n * @param {Array} urlsAlreadyPrecached\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function printInstallDetails(urlsToPrecache, urlsAlreadyPrecached) {\n const precachedCount = urlsToPrecache.length;\n const alreadyPrecachedCount = urlsAlreadyPrecached.length;\n if (precachedCount || alreadyPrecachedCount) {\n let message = `Precaching ${precachedCount} file${precachedCount === 1 ? '' : 's'}.`;\n if (alreadyPrecachedCount > 0) {\n message +=\n ` ${alreadyPrecachedCount} ` +\n `file${alreadyPrecachedCount === 1 ? ' is' : 's are'} already cached.`;\n }\n logger.groupCollapsed(message);\n _nestedGroup(`View newly precached URLs.`, urlsToPrecache);\n _nestedGroup(`View previously precached URLs.`, urlsAlreadyPrecached);\n logger.groupEnd();\n }\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nlet supportStatus;\n/**\n * A utility function that determines whether the current browser supports\n * constructing a new `Response` from a `response.body` stream.\n *\n * @return {boolean} `true`, if the current browser can successfully\n * construct a `Response` from a `response.body` stream, `false` otherwise.\n *\n * @private\n */\nfunction canConstructResponseFromBodyStream() {\n if (supportStatus === undefined) {\n const testResponse = new Response('');\n if ('body' in testResponse) {\n try {\n new Response(testResponse.body);\n supportStatus = true;\n }\n catch (error) {\n supportStatus = false;\n }\n }\n supportStatus = false;\n }\n return supportStatus;\n}\nexport { canConstructResponseFromBodyStream };\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 { canConstructResponseFromBodyStream } from './_private/canConstructResponseFromBodyStream.js';\nimport { WorkboxError } from './_private/WorkboxError.js';\nimport './_version.js';\n/**\n * Allows developers to copy a response and modify its `headers`, `status`,\n * or `statusText` values (the values settable via a\n * [`ResponseInit`]{@link https://developer.mozilla.org/en-US/docs/Web/API/Response/Response#Syntax}\n * object in the constructor).\n * To modify these values, pass a function as the second argument. That\n * function will be invoked with a single object with the response properties\n * `{headers, status, statusText}`. The return value of this function will\n * be used as the `ResponseInit` for the new `Response`. To change the values\n * either modify the passed parameter(s) and return it, or return a totally\n * new object.\n *\n * This method is intentionally limited to same-origin responses, regardless of\n * whether CORS was used or not.\n *\n * @param {Response} response\n * @param {Function} modifier\n * @memberof workbox-core\n */\nasync function copyResponse(response, modifier) {\n let origin = null;\n // If response.url isn't set, assume it's cross-origin and keep origin null.\n if (response.url) {\n const responseURL = new URL(response.url);\n origin = responseURL.origin;\n }\n if (origin !== self.location.origin) {\n throw new WorkboxError('cross-origin-copy-response', { origin });\n }\n const clonedResponse = response.clone();\n // Create a fresh `ResponseInit` object by cloning the headers.\n const responseInit = {\n headers: new Headers(clonedResponse.headers),\n status: clonedResponse.status,\n statusText: clonedResponse.statusText,\n };\n // Apply any user modifications.\n const modifiedResponseInit = modifier ? modifier(responseInit) : responseInit;\n // Create the new response from the body stream and `ResponseInit`\n // modifications. Note: not all browsers support the Response.body stream,\n // so fall back to reading the entire body into memory as a blob.\n const body = canConstructResponseFromBodyStream()\n ? clonedResponse.body\n : await clonedResponse.blob();\n return new Response(body, modifiedResponseInit);\n}\nexport { copyResponse };\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 { copyResponse } from 'workbox-core/copyResponse.js';\nimport { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { Strategy } from 'workbox-strategies/Strategy.js';\nimport './_version.js';\n/**\n * A {@link workbox-strategies.Strategy} implementation\n * specifically designed to work with\n * {@link workbox-precaching.PrecacheController}\n * to both cache and fetch precached assets.\n *\n * Note: an instance of this class is created automatically when creating a\n * `PrecacheController`; it's generally not necessary to create this yourself.\n *\n * @extends workbox-strategies.Strategy\n * @memberof workbox-precaching\n */\nclass PrecacheStrategy extends Strategy {\n /**\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] {@link https://developers.google.com/web/tools/workbox/guides/using-plugins|Plugins}\n * to use in conjunction with this caching strategy.\n * @param {Object} [options.fetchOptions] Values passed along to the\n * {@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters|init}\n * of all fetch() requests made by this strategy.\n * @param {Object} [options.matchOptions] The\n * {@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions|CacheQueryOptions}\n * for any `cache.match()` or `cache.put()` calls made by this strategy.\n * @param {boolean} [options.fallbackToNetwork=true] Whether to attempt to\n * get the response from the network if there's a precache miss.\n */\n constructor(options = {}) {\n options.cacheName = cacheNames.getPrecacheName(options.cacheName);\n super(options);\n this._fallbackToNetwork =\n options.fallbackToNetwork === false ? false : true;\n // Redirected responses cannot be used to satisfy a navigation request, so\n // any redirected response must be \"copied\" rather than cloned, so the new\n // response doesn't contain the `redirected` flag. See:\n // https://bugs.chromium.org/p/chromium/issues/detail?id=669363&desc=2#c1\n this.plugins.push(PrecacheStrategy.copyRedirectedCacheableResponsesPlugin);\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 response = await handler.cacheMatch(request);\n if (response) {\n return response;\n }\n // If this is an `install` event for an entry that isn't already cached,\n // then populate the cache.\n if (handler.event && handler.event.type === 'install') {\n return await this._handleInstall(request, handler);\n }\n // Getting here means something went wrong. An entry that should have been\n // precached wasn't found in the cache.\n return await this._handleFetch(request, handler);\n }\n async _handleFetch(request, handler) {\n let response;\n const params = (handler.params || {});\n // Fall back to the network if we're configured to do so.\n if (this._fallbackToNetwork) {\n if (process.env.NODE_ENV !== 'production') {\n logger.warn(`The precached response for ` +\n `${getFriendlyURL(request.url)} in ${this.cacheName} was not ` +\n `found. Falling back to the network.`);\n }\n const integrityInManifest = params.integrity;\n const integrityInRequest = request.integrity;\n const noIntegrityConflict = !integrityInRequest || integrityInRequest === integrityInManifest;\n // Do not add integrity if the original request is no-cors\n // See https://github.com/GoogleChrome/workbox/issues/3096\n response = await handler.fetch(new Request(request, {\n integrity: request.mode !== 'no-cors'\n ? integrityInRequest || integrityInManifest\n : undefined,\n }));\n // It's only \"safe\" to repair the cache if we're using SRI to guarantee\n // that the response matches the precache manifest's expectations,\n // and there's either a) no integrity property in the incoming request\n // or b) there is an integrity, and it matches the precache manifest.\n // See https://github.com/GoogleChrome/workbox/issues/2858\n // Also if the original request users no-cors we don't use integrity.\n // See https://github.com/GoogleChrome/workbox/issues/3096\n if (integrityInManifest &&\n noIntegrityConflict &&\n request.mode !== 'no-cors') {\n this._useDefaultCacheabilityPluginIfNeeded();\n const wasCached = await handler.cachePut(request, response.clone());\n if (process.env.NODE_ENV !== 'production') {\n if (wasCached) {\n logger.log(`A response for ${getFriendlyURL(request.url)} ` +\n `was used to \"repair\" the precache.`);\n }\n }\n }\n }\n else {\n // This shouldn't normally happen, but there are edge cases:\n // https://github.com/GoogleChrome/workbox/issues/1441\n throw new WorkboxError('missing-precache-entry', {\n cacheName: this.cacheName,\n url: request.url,\n });\n }\n if (process.env.NODE_ENV !== 'production') {\n const cacheKey = params.cacheKey || (await handler.getCacheKey(request, 'read'));\n // Workbox is going to handle the route.\n // print the routing details to the console.\n logger.groupCollapsed(`Precaching is responding to: ` + getFriendlyURL(request.url));\n logger.log(`Serving the precached url: ${getFriendlyURL(cacheKey instanceof Request ? cacheKey.url : cacheKey)}`);\n logger.groupCollapsed(`View request details here.`);\n logger.log(request);\n logger.groupEnd();\n logger.groupCollapsed(`View response details here.`);\n logger.log(response);\n logger.groupEnd();\n logger.groupEnd();\n }\n return response;\n }\n async _handleInstall(request, handler) {\n this._useDefaultCacheabilityPluginIfNeeded();\n const response = await handler.fetch(request);\n // Make sure we defer cachePut() until after we know the response\n // should be cached; see https://github.com/GoogleChrome/workbox/issues/2737\n const wasCached = await handler.cachePut(request, response.clone());\n if (!wasCached) {\n // Throwing here will lead to the `install` handler failing, which\n // we want to do if *any* of the responses aren't safe to cache.\n throw new WorkboxError('bad-precaching-response', {\n url: request.url,\n status: response.status,\n });\n }\n return response;\n }\n /**\n * This method is complex, as there a number of things to account for:\n *\n * The `plugins` array can be set at construction, and/or it might be added to\n * to at any time before the strategy is used.\n *\n * At the time the strategy is used (i.e. during an `install` event), there\n * needs to be at least one plugin that implements `cacheWillUpdate` in the\n * array, other than `copyRedirectedCacheableResponsesPlugin`.\n *\n * - If this method is called and there are no suitable `cacheWillUpdate`\n * plugins, we need to add `defaultPrecacheCacheabilityPlugin`.\n *\n * - If this method is called and there is exactly one `cacheWillUpdate`, then\n * we don't have to do anything (this might be a previously added\n * `defaultPrecacheCacheabilityPlugin`, or it might be a custom plugin).\n *\n * - If this method is called and there is more than one `cacheWillUpdate`,\n * then we need to check if one is `defaultPrecacheCacheabilityPlugin`. If so,\n * we need to remove it. (This situation is unlikely, but it could happen if\n * the strategy is used multiple times, the first without a `cacheWillUpdate`,\n * and then later on after manually adding a custom `cacheWillUpdate`.)\n *\n * See https://github.com/GoogleChrome/workbox/issues/2737 for more context.\n *\n * @private\n */\n _useDefaultCacheabilityPluginIfNeeded() {\n let defaultPluginIndex = null;\n let cacheWillUpdatePluginCount = 0;\n for (const [index, plugin] of this.plugins.entries()) {\n // Ignore the copy redirected plugin when determining what to do.\n if (plugin === PrecacheStrategy.copyRedirectedCacheableResponsesPlugin) {\n continue;\n }\n // Save the default plugin's index, in case it needs to be removed.\n if (plugin === PrecacheStrategy.defaultPrecacheCacheabilityPlugin) {\n defaultPluginIndex = index;\n }\n if (plugin.cacheWillUpdate) {\n cacheWillUpdatePluginCount++;\n }\n }\n if (cacheWillUpdatePluginCount === 0) {\n this.plugins.push(PrecacheStrategy.defaultPrecacheCacheabilityPlugin);\n }\n else if (cacheWillUpdatePluginCount > 1 && defaultPluginIndex !== null) {\n // Only remove the default plugin; multiple custom plugins are allowed.\n this.plugins.splice(defaultPluginIndex, 1);\n }\n // Nothing needs to be done if cacheWillUpdatePluginCount is 1\n }\n}\nPrecacheStrategy.defaultPrecacheCacheabilityPlugin = {\n async cacheWillUpdate({ response }) {\n if (!response || response.status >= 400) {\n return null;\n }\n return response;\n },\n};\nPrecacheStrategy.copyRedirectedCacheableResponsesPlugin = {\n async cacheWillUpdate({ response }) {\n return response.redirected ? await copyResponse(response) : response;\n },\n};\nexport { PrecacheStrategy };\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 { assert } from 'workbox-core/_private/assert.js';\nimport { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { waitUntil } from 'workbox-core/_private/waitUntil.js';\nimport { createCacheKey } from './utils/createCacheKey.js';\nimport { PrecacheInstallReportPlugin } from './utils/PrecacheInstallReportPlugin.js';\nimport { PrecacheCacheKeyPlugin } from './utils/PrecacheCacheKeyPlugin.js';\nimport { printCleanupDetails } from './utils/printCleanupDetails.js';\nimport { printInstallDetails } from './utils/printInstallDetails.js';\nimport { PrecacheStrategy } from './PrecacheStrategy.js';\nimport './_version.js';\n/**\n * Performs efficient precaching of assets.\n *\n * @memberof workbox-precaching\n */\nclass PrecacheController {\n /**\n * Create a new PrecacheController.\n *\n * @param {Object} [options]\n * @param {string} [options.cacheName] The cache to use for precaching.\n * @param {string} [options.plugins] Plugins to use when precaching as well\n * as responding to fetch events for precached assets.\n * @param {boolean} [options.fallbackToNetwork=true] Whether to attempt to\n * get the response from the network if there's a precache miss.\n */\n constructor({ cacheName, plugins = [], fallbackToNetwork = true, } = {}) {\n this._urlsToCacheKeys = new Map();\n this._urlsToCacheModes = new Map();\n this._cacheKeysToIntegrities = new Map();\n this._strategy = new PrecacheStrategy({\n cacheName: cacheNames.getPrecacheName(cacheName),\n plugins: [\n ...plugins,\n new PrecacheCacheKeyPlugin({ precacheController: this }),\n ],\n fallbackToNetwork,\n });\n // Bind the install and activate methods to the instance.\n this.install = this.install.bind(this);\n this.activate = this.activate.bind(this);\n }\n /**\n * @type {workbox-precaching.PrecacheStrategy} The strategy created by this controller and\n * used to cache assets and respond to fetch events.\n */\n get strategy() {\n return this._strategy;\n }\n /**\n * Adds items to the precache list, removing any duplicates and\n * stores the files in the\n * {@link workbox-core.cacheNames|\"precache cache\"} when the service\n * worker installs.\n *\n * This method can be called multiple times.\n *\n * @param {Array} [entries=[]] Array of entries to precache.\n */\n precache(entries) {\n this.addToCacheList(entries);\n if (!this._installAndActiveListenersAdded) {\n self.addEventListener('install', this.install);\n self.addEventListener('activate', this.activate);\n this._installAndActiveListenersAdded = true;\n }\n }\n /**\n * This method will add items to the precache list, removing duplicates\n * and ensuring the information is valid.\n *\n * @param {Array} entries\n * Array of entries to precache.\n */\n addToCacheList(entries) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isArray(entries, {\n moduleName: 'workbox-precaching',\n className: 'PrecacheController',\n funcName: 'addToCacheList',\n paramName: 'entries',\n });\n }\n const urlsToWarnAbout = [];\n for (const entry of entries) {\n // See https://github.com/GoogleChrome/workbox/issues/2259\n if (typeof entry === 'string') {\n urlsToWarnAbout.push(entry);\n }\n else if (entry && entry.revision === undefined) {\n urlsToWarnAbout.push(entry.url);\n }\n const { cacheKey, url } = createCacheKey(entry);\n const cacheMode = typeof entry !== 'string' && entry.revision ? 'reload' : 'default';\n if (this._urlsToCacheKeys.has(url) &&\n this._urlsToCacheKeys.get(url) !== cacheKey) {\n throw new WorkboxError('add-to-cache-list-conflicting-entries', {\n firstEntry: this._urlsToCacheKeys.get(url),\n secondEntry: cacheKey,\n });\n }\n if (typeof entry !== 'string' && entry.integrity) {\n if (this._cacheKeysToIntegrities.has(cacheKey) &&\n this._cacheKeysToIntegrities.get(cacheKey) !== entry.integrity) {\n throw new WorkboxError('add-to-cache-list-conflicting-integrities', {\n url,\n });\n }\n this._cacheKeysToIntegrities.set(cacheKey, entry.integrity);\n }\n this._urlsToCacheKeys.set(url, cacheKey);\n this._urlsToCacheModes.set(url, cacheMode);\n if (urlsToWarnAbout.length > 0) {\n const warningMessage = `Workbox is precaching URLs without revision ` +\n `info: ${urlsToWarnAbout.join(', ')}\\nThis is generally NOT safe. ` +\n `Learn more at https://bit.ly/wb-precache`;\n if (process.env.NODE_ENV === 'production') {\n // Use console directly to display this warning without bloating\n // bundle sizes by pulling in all of the logger codebase in prod.\n console.warn(warningMessage);\n }\n else {\n logger.warn(warningMessage);\n }\n }\n }\n }\n /**\n * Precaches new and updated assets. Call this method from the service worker\n * install event.\n *\n * Note: this method calls `event.waitUntil()` for you, so you do not need\n * to call it yourself in your event handlers.\n *\n * @param {ExtendableEvent} event\n * @return {Promise}\n */\n install(event) {\n // waitUntil returns Promise\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return waitUntil(event, async () => {\n const installReportPlugin = new PrecacheInstallReportPlugin();\n this.strategy.plugins.push(installReportPlugin);\n // Cache entries one at a time.\n // See https://github.com/GoogleChrome/workbox/issues/2528\n for (const [url, cacheKey] of this._urlsToCacheKeys) {\n const integrity = this._cacheKeysToIntegrities.get(cacheKey);\n const cacheMode = this._urlsToCacheModes.get(url);\n const request = new Request(url, {\n integrity,\n cache: cacheMode,\n credentials: 'same-origin',\n });\n await Promise.all(this.strategy.handleAll({\n params: { cacheKey },\n request,\n event,\n }));\n }\n const { updatedURLs, notUpdatedURLs } = installReportPlugin;\n if (process.env.NODE_ENV !== 'production') {\n printInstallDetails(updatedURLs, notUpdatedURLs);\n }\n return { updatedURLs, notUpdatedURLs };\n });\n }\n /**\n * Deletes assets that are no longer present in the current precache manifest.\n * Call this method from the service worker activate event.\n *\n * Note: this method calls `event.waitUntil()` for you, so you do not need\n * to call it yourself in your event handlers.\n *\n * @param {ExtendableEvent} event\n * @return {Promise}\n */\n activate(event) {\n // waitUntil returns Promise\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return waitUntil(event, async () => {\n const cache = await self.caches.open(this.strategy.cacheName);\n const currentlyCachedRequests = await cache.keys();\n const expectedCacheKeys = new Set(this._urlsToCacheKeys.values());\n const deletedURLs = [];\n for (const request of currentlyCachedRequests) {\n if (!expectedCacheKeys.has(request.url)) {\n await cache.delete(request);\n deletedURLs.push(request.url);\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n printCleanupDetails(deletedURLs);\n }\n return { deletedURLs };\n });\n }\n /**\n * Returns a mapping of a precached URL to the corresponding cache key, taking\n * into account the revision information for the URL.\n *\n * @return {Map} A URL to cache key mapping.\n */\n getURLsToCacheKeys() {\n return this._urlsToCacheKeys;\n }\n /**\n * Returns a list of all the URLs that have been precached by the current\n * service worker.\n *\n * @return {Array} The precached URLs.\n */\n getCachedURLs() {\n return [...this._urlsToCacheKeys.keys()];\n }\n /**\n * Returns the cache key used for storing a given URL. If that URL is\n * unversioned, like `/index.html', then the cache key will be the original\n * URL with a search parameter appended to it.\n *\n * @param {string} url A URL whose cache key you want to look up.\n * @return {string} The versioned URL that corresponds to a cache key\n * for the original URL, or undefined if that URL isn't precached.\n */\n getCacheKeyForURL(url) {\n const urlObject = new URL(url, location.href);\n return this._urlsToCacheKeys.get(urlObject.href);\n }\n /**\n * @param {string} url A cache key whose SRI you want to look up.\n * @return {string} The subresource integrity associated with the cache key,\n * or undefined if it's not set.\n */\n getIntegrityForCacheKey(cacheKey) {\n return this._cacheKeysToIntegrities.get(cacheKey);\n }\n /**\n * This acts as a drop-in replacement for\n * [`cache.match()`](https://developer.mozilla.org/en-US/docs/Web/API/Cache/match)\n * with the following differences:\n *\n * - It knows what the name of the precache is, and only checks in that cache.\n * - It allows you to pass in an \"original\" URL without versioning parameters,\n * and it will automatically look up the correct cache key for the currently\n * active revision of that URL.\n *\n * E.g., `matchPrecache('index.html')` will find the correct precached\n * response for the currently active service worker, even if the actual cache\n * key is `'/index.html?__WB_REVISION__=1234abcd'`.\n *\n * @param {string|Request} request The key (without revisioning parameters)\n * to look up in the precache.\n * @return {Promise}\n */\n async matchPrecache(request) {\n const url = request instanceof Request ? request.url : request;\n const cacheKey = this.getCacheKeyForURL(url);\n if (cacheKey) {\n const cache = await self.caches.open(this.strategy.cacheName);\n return cache.match(cacheKey);\n }\n return undefined;\n }\n /**\n * Returns a function that looks up `url` in the precache (taking into\n * account revision information), and returns the corresponding `Response`.\n *\n * @param {string} url The precached URL which will be used to lookup the\n * `Response`.\n * @return {workbox-routing~handlerCallback}\n */\n createHandlerBoundToURL(url) {\n const cacheKey = this.getCacheKeyForURL(url);\n if (!cacheKey) {\n throw new WorkboxError('non-precached-url', { url });\n }\n return (options) => {\n options.request = new Request(url);\n options.params = Object.assign({ cacheKey }, options.params);\n return this.strategy.handle(options);\n };\n }\n}\nexport { PrecacheController };\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 { PrecacheController } from '../PrecacheController.js';\nimport '../_version.js';\nlet precacheController;\n/**\n * @return {PrecacheController}\n * @private\n */\nexport const getOrCreatePrecacheController = () => {\n if (!precacheController) {\n precacheController = new PrecacheController();\n }\n return precacheController;\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';\n/**\n * Removes any URL search parameters that should be ignored.\n *\n * @param {URL} urlObject The original URL.\n * @param {Array} ignoreURLParametersMatching RegExps to test against\n * each search parameter name. Matches mean that the search parameter should be\n * ignored.\n * @return {URL} The URL with any ignored search parameters removed.\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function removeIgnoredSearchParams(urlObject, ignoreURLParametersMatching = []) {\n // Convert the iterable into an array at the start of the loop to make sure\n // deletion doesn't mess up iteration.\n for (const paramName of [...urlObject.searchParams.keys()]) {\n if (ignoreURLParametersMatching.some((regExp) => regExp.test(paramName))) {\n urlObject.searchParams.delete(paramName);\n }\n }\n return urlObject;\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 { removeIgnoredSearchParams } from './removeIgnoredSearchParams.js';\nimport '../_version.js';\n/**\n * Generator function that yields possible variations on the original URL to\n * check, one at a time.\n *\n * @param {string} url\n * @param {Object} options\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function* generateURLVariations(url, { ignoreURLParametersMatching = [/^utm_/, /^fbclid$/], directoryIndex = 'index.html', cleanURLs = true, urlManipulation, } = {}) {\n const urlObject = new URL(url, location.href);\n urlObject.hash = '';\n yield urlObject.href;\n const urlWithoutIgnoredParams = removeIgnoredSearchParams(urlObject, ignoreURLParametersMatching);\n yield urlWithoutIgnoredParams.href;\n if (directoryIndex && urlWithoutIgnoredParams.pathname.endsWith('/')) {\n const directoryURL = new URL(urlWithoutIgnoredParams.href);\n directoryURL.pathname += directoryIndex;\n yield directoryURL.href;\n }\n if (cleanURLs) {\n const cleanURL = new URL(urlWithoutIgnoredParams.href);\n cleanURL.pathname += '.html';\n yield cleanURL.href;\n }\n if (urlManipulation) {\n const additionalURLs = urlManipulation({ url: urlObject });\n for (const urlToAttempt of additionalURLs) {\n yield urlToAttempt.href;\n }\n }\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 { logger } from 'workbox-core/_private/logger.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { Route } from 'workbox-routing/Route.js';\nimport { generateURLVariations } from './utils/generateURLVariations.js';\nimport './_version.js';\n/**\n * A subclass of {@link workbox-routing.Route} that takes a\n * {@link workbox-precaching.PrecacheController}\n * instance and uses it to match incoming requests and handle fetching\n * responses from the precache.\n *\n * @memberof workbox-precaching\n * @extends workbox-routing.Route\n */\nclass PrecacheRoute extends Route {\n /**\n * @param {PrecacheController} precacheController A `PrecacheController`\n * instance used to both match requests and respond to fetch events.\n * @param {Object} [options] Options to control how requests are matched\n * against the list of precached URLs.\n * @param {string} [options.directoryIndex=index.html] The `directoryIndex` will\n * check cache entries for a URLs ending with '/' to see if there is a hit when\n * appending the `directoryIndex` value.\n * @param {Array} [options.ignoreURLParametersMatching=[/^utm_/, /^fbclid$/]] An\n * array of regex's to remove search params when looking for a cache match.\n * @param {boolean} [options.cleanURLs=true] The `cleanURLs` option will\n * check the cache for the URL with a `.html` added to the end of the end.\n * @param {workbox-precaching~urlManipulation} [options.urlManipulation]\n * This is a function that should take a URL and return an array of\n * alternative URLs that should be checked for precache matches.\n */\n constructor(precacheController, options) {\n const match = ({ request, }) => {\n const urlsToCacheKeys = precacheController.getURLsToCacheKeys();\n for (const possibleURL of generateURLVariations(request.url, options)) {\n const cacheKey = urlsToCacheKeys.get(possibleURL);\n if (cacheKey) {\n const integrity = precacheController.getIntegrityForCacheKey(cacheKey);\n return { cacheKey, integrity };\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Precaching did not find a match for ` + getFriendlyURL(request.url));\n }\n return;\n };\n super(match, precacheController.strategy);\n }\n}\nexport { PrecacheRoute };\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 { registerRoute } from 'workbox-routing/registerRoute.js';\nimport { getOrCreatePrecacheController } from './utils/getOrCreatePrecacheController.js';\nimport { PrecacheRoute } from './PrecacheRoute.js';\nimport './_version.js';\n/**\n * Add a `fetch` listener to the service worker that will\n * respond to\n * [network requests]{@link https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API/Using_Service_Workers#Custom_responses_to_requests}\n * with precached assets.\n *\n * Requests for assets that aren't precached, the `FetchEvent` will not be\n * responded to, allowing the event to fall through to other `fetch` event\n * listeners.\n *\n * @param {Object} [options] See the {@link workbox-precaching.PrecacheRoute}\n * options.\n *\n * @memberof workbox-precaching\n */\nfunction addRoute(options) {\n const precacheController = getOrCreatePrecacheController();\n const precacheRoute = new PrecacheRoute(precacheController, options);\n registerRoute(precacheRoute);\n}\nexport { addRoute };\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 { getOrCreatePrecacheController } from './utils/getOrCreatePrecacheController.js';\nimport './_version.js';\n/**\n * Adds items to the precache list, removing any duplicates and\n * stores the files in the\n * {@link workbox-core.cacheNames|\"precache cache\"} when the service\n * worker installs.\n *\n * This method can be called multiple times.\n *\n * Please note: This method **will not** serve any of the cached files for you.\n * It only precaches files. To respond to a network request you call\n * {@link workbox-precaching.addRoute}.\n *\n * If you have a single array of files to precache, you can just call\n * {@link workbox-precaching.precacheAndRoute}.\n *\n * @param {Array} [entries=[]] Array of entries to precache.\n *\n * @memberof workbox-precaching\n */\nfunction precache(entries) {\n const precacheController = getOrCreatePrecacheController();\n precacheController.precache(entries);\n}\nexport { precache };\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 { addRoute } from './addRoute.js';\nimport { precache } from './precache.js';\nimport './_version.js';\n/**\n * This method will add entries to the precache list and add a route to\n * respond to fetch events.\n *\n * This is a convenience method that will call\n * {@link workbox-precaching.precache} and\n * {@link workbox-precaching.addRoute} in a single call.\n *\n * @param {Array} entries Array of entries to precache.\n * @param {Object} [options] See the\n * {@link workbox-precaching.PrecacheRoute} options.\n *\n * @memberof workbox-precaching\n */\nfunction precacheAndRoute(entries, options) {\n precache(entries);\n addRoute(options);\n}\nexport { precacheAndRoute };\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 SUBSTRING_TO_FIND = '-precache-';\n/**\n * Cleans up incompatible precaches that were created by older versions of\n * Workbox, by a service worker registered under the current scope.\n *\n * This is meant to be called as part of the `activate` event.\n *\n * This should be safe to use as long as you don't include `substringToFind`\n * (defaulting to `-precache-`) in your non-precache cache names.\n *\n * @param {string} currentPrecacheName The cache name currently in use for\n * precaching. This cache won't be deleted.\n * @param {string} [substringToFind='-precache-'] Cache names which include this\n * substring will be deleted (excluding `currentPrecacheName`).\n * @return {Array} A list of all the cache names that were deleted.\n *\n * @private\n * @memberof workbox-precaching\n */\nconst deleteOutdatedCaches = async (currentPrecacheName, substringToFind = SUBSTRING_TO_FIND) => {\n const cacheNames = await self.caches.keys();\n const cacheNamesToDelete = cacheNames.filter((cacheName) => {\n return (cacheName.includes(substringToFind) &&\n cacheName.includes(self.registration.scope) &&\n cacheName !== currentPrecacheName);\n });\n await Promise.all(cacheNamesToDelete.map((cacheName) => self.caches.delete(cacheName)));\n return cacheNamesToDelete;\n};\nexport { deleteOutdatedCaches };\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 { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { deleteOutdatedCaches } from './utils/deleteOutdatedCaches.js';\nimport './_version.js';\n/**\n * Adds an `activate` event listener which will clean up incompatible\n * precaches that were created by older versions of Workbox.\n *\n * @memberof workbox-precaching\n */\nfunction cleanupOutdatedCaches() {\n // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705\n self.addEventListener('activate', ((event) => {\n const cacheName = cacheNames.getPrecacheName();\n event.waitUntil(deleteOutdatedCaches(cacheName).then((cachesDeleted) => {\n if (process.env.NODE_ENV !== 'production') {\n if (cachesDeleted.length > 0) {\n logger.log(`The following out-of-date precaches were cleaned up ` +\n `automatically:`, cachesDeleted);\n }\n }\n }));\n }));\n}\nexport { cleanupOutdatedCaches };\n"],"names":["self","_","e","logger","globalThis","__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","invalid-value","paramName","validValueDescription","value","Error","JSON","stringify","not-an-array","moduleName","className","funcName","incorrect-type","expectedType","classNameStr","incorrect-class","expectedClassName","isReturnValueProblem","missing-a-method","expectedMethod","add-to-cache-list-unexpected-type","entry","add-to-cache-list-conflicting-entries","firstEntry","secondEntry","plugin-error-request-will-fetch","thrownErrorMessage","invalid-cache-name","cacheNameId","unregister-route-but-not-found-with-method","unregister-route-route-not-registered","queue-replay-failed","name","duplicate-queue-name","expired-test-without-max-age","methodName","unsupported-route-type","not-array-of-class","expectedClass","max-entries-or-age-required","statuses-or-headers-required","invalid-string","channel-name-required","invalid-responses-are-same-args","expire-custom-caches-only","unit-must-be-bytes","normalizedRangeHeader","single-range-only","invalid-range-values","no-range-header","range-not-satisfiable","size","start","end","attempt-to-cache-non-get-request","url","cache-put-with-no-response","no-response","message","bad-precaching-response","status","non-precached-url","add-to-cache-list-conflicting-integrities","missing-precache-entry","cacheName","cross-origin-copy-response","origin","opaque-streams-source","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","asyncFn","returnPromise","REVISION_SEARCH_PARAM","createCacheKey","urlObject","revision","cacheKeyURL","originalURL","PrecacheInstallReportPlugin","updatedURLs","notUpdatedURLs","handlerWillStart","cachedResponseWillBeUsed","PrecacheCacheKeyPlugin","precacheController","cacheKeyWillBeUsed","_precacheController","getCacheKeyForURL","logGroup","groupTitle","deletedURLs","printCleanupDetails","deletionCount","_nestedGroup","urls","printInstallDetails","urlsToPrecache","urlsAlreadyPrecached","precachedCount","alreadyPrecachedCount","supportStatus","canConstructResponseFromBodyStream","testResponse","Response","body","copyResponse","modifier","responseURL","clonedResponse","responseInit","Headers","statusText","modifiedResponseInit","blob","PrecacheStrategy","_fallbackToNetwork","fallbackToNetwork","copyRedirectedCacheableResponsesPlugin","_handleInstall","_handleFetch","integrityInManifest","integrity","integrityInRequest","noIntegrityConflict","_useDefaultCacheabilityPluginIfNeeded","wasCached","defaultPluginIndex","cacheWillUpdatePluginCount","entries","defaultPrecacheCacheabilityPlugin","redirected","PrecacheController","_urlsToCacheKeys","_urlsToCacheModes","_cacheKeysToIntegrities","install","bind","activate","addToCacheList","_installAndActiveListenersAdded","urlsToWarnAbout","cacheMode","warningMessage","installReportPlugin","credentials","currentlyCachedRequests","expectedCacheKeys","values","getURLsToCacheKeys","getCachedURLs","getIntegrityForCacheKey","matchPrecache","createHandlerBoundToURL","getOrCreatePrecacheController","removeIgnoredSearchParams","ignoreURLParametersMatching","generateURLVariations","directoryIndex","cleanURLs","urlManipulation","hash","urlWithoutIgnoredParams","endsWith","directoryURL","cleanURL","additionalURLs","urlToAttempt","PrecacheRoute","urlsToCacheKeys","possibleURL","addRoute","precacheRoute","precacheAndRoute","SUBSTRING_TO_FIND","deleteOutdatedCaches","currentPrecacheName","substringToFind","cacheNamesToDelete","cleanupOutdatedCaches","cachesDeleted"],"mappings":"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"} \ No newline at end of file diff --git a/public/workbox-c06b064f.js b/public/workbox-c06b064f.js new file mode 100644 index 0000000..651a719 --- /dev/null +++ b/public/workbox-c06b064f.js @@ -0,0 +1 @@ +define(["exports"],(function(t){"use strict";try{self["workbox:core:7.0.0"]&&_()}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:7.0.0"]&&_()}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:7.0.0"]&&_()}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.m=[...t.plugins],this.R=new Map;for(const t of this.m)this.R.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.v(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.R.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 v(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.q(r,s,e);return[i,this.D(i,r,s,e)]}async q(t,e,n){let r;await t.runCallbacks("handlerWillStart",{event:n,request:e});try{if(r=await this.U(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 D(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?Object.assign.bind():function(t){for(var e=1;ee.some((e=>t instanceof e));let U,x;const L=new WeakMap,I=new WeakMap,C=new WeakMap,E=new WeakMap,N=new WeakMap;let O={get(t,e,s){if(t instanceof IDBTransaction){if("done"===e)return I.get(t);if("objectStoreNames"===e)return t.objectStoreNames||C.get(t);if("store"===e)return s.objectStoreNames[1]?void 0:s.objectStore(s.objectStoreNames[0])}return B(t[e])},set:(t,e,s)=>(t[e]=s,!0),has:(t,e)=>t instanceof IDBTransaction&&("done"===e||"store"===e)||e in t};function T(t){return t!==IDBDatabase.prototype.transaction||"objectStoreNames"in IDBTransaction.prototype?(x||(x=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])).includes(t)?function(...e){return t.apply(P(this),e),B(L.get(this))}:function(...e){return B(t.apply(P(this),e))}:function(e,...s){const n=t.call(P(this),e,...s);return C.set(n,e.sort?e.sort():[e]),B(n)}}function k(t){return"function"==typeof t?T(t):(t instanceof IDBTransaction&&function(t){if(I.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)}));I.set(t,e)}(t),D(t,U||(U=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction]))?new Proxy(t,O):t)}function B(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(B(t.result)),n()},i=()=>{s(t.error),n()};t.addEventListener("success",r),t.addEventListener("error",i)}));return e.then((e=>{e instanceof IDBCursor&&L.set(e,t)})).catch((()=>{})),N.set(e,t),e}(t);if(E.has(t))return E.get(t);const e=k(t);return e!==t&&(E.set(t,e),N.set(e,t)),e}const P=t=>N.get(t);const M=["get","getKey","getAll","getAllKeys","count"],W=["put","add","delete","clear"],j=new Map;function S(t,e){if(!(t instanceof IDBDatabase)||e in t||"string"!=typeof e)return;if(j.get(e))return j.get(e);const s=e.replace(/FromIndex$/,""),n=e!==s,r=W.includes(s);if(!(s in(n?IDBIndex:IDBObjectStore).prototype)||!r&&!M.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 j.set(e,i),i}O=(t=>q({},t,{get:(e,s,n)=>S(e,s)||t.get(e,s,n),has:(e,s)=>!!S(e,s)||t.has(e,s)}))(O);try{self["workbox:expiration:7.0.0"]&&_()}catch(t){}const K="cache-entries",A=t=>{const e=new URL(t,location.href);return e.hash="",e.href};class F{constructor(t){this._=null,this.L=t}I(t){const e=t.createObjectStore(K,{keyPath:"id"});e.createIndex("cacheName","cacheName",{unique:!1}),e.createIndex("timestamp","timestamp",{unique:!1})}C(t){this.I(t),this.L&&function(t,{blocked:e}={}){const s=indexedDB.deleteDatabase(t);e&&s.addEventListener("blocked",(t=>e(t.oldVersion,t))),B(s).then((()=>{}))}(this.L)}async setTimestamp(t,e){const s={url:t=A(t),timestamp:e,cacheName:this.L,id:this.N(t)},n=(await this.getDb()).transaction(K,"readwrite",{durability:"relaxed"});await n.store.put(s),await n.done}async getTimestamp(t){const e=await this.getDb(),s=await e.get(K,this.N(t));return null==s?void 0:s.timestamp}async expireEntries(t,e){const s=await this.getDb();let n=await s.transaction(K).store.index("timestamp").openCursor(null,"prev");const r=[];let i=0;for(;n;){const s=n.value;s.cacheName===this.L&&(t&&s.timestamp=e?r.push(n.value):i++),n=await n.continue()}const a=[];for(const t of r)await s.delete(K,t.id),a.push(t.url);return a}N(t){return this.L+"|"+A(t)}async getDb(){return this._||(this._=await function(t,e,{blocked:s,upgrade:n,blocking:r,terminated:i}={}){const a=indexedDB.open(t,e),o=B(a);return n&&a.addEventListener("upgradeneeded",(t=>{n(B(a.result),t.oldVersion,t.newVersion,B(a.transaction),t)})),s&&a.addEventListener("blocked",(t=>s(t.oldVersion,t.newVersion,t))),o.then((t=>{i&&t.addEventListener("close",(()=>i())),r&&t.addEventListener("versionchange",(t=>r(t.oldVersion,t.newVersion,t)))})).catch((()=>{})),o}("workbox-expiration",1,{upgrade:this.C.bind(this)})),this._}}class H{constructor(t,e={}){this.O=!1,this.T=!1,this.k=e.maxEntries,this.B=e.maxAgeSeconds,this.P=e.matchOptions,this.L=t,this.M=new F(t)}async expireEntries(){if(this.O)return void(this.T=!0);this.O=!0;const t=this.B?Date.now()-1e3*this.B:0,e=await this.M.expireEntries(t,this.k),s=await self.caches.open(this.L);for(const t of e)await s.delete(t,this.P);this.O=!1,this.T&&(this.T=!1,b(this.expireEntries()))}async updateTimestamp(t){await this.M.setTimestamp(t,Date.now())}async isURLExpired(t){if(this.B){const e=await this.M.getTimestamp(t),s=Date.now()-1e3*this.B;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 z(t,e){const s=e();return t.waitUntil(s),s}try{self["workbox:precaching:7.0.0"]&&_()}catch(t){}function G(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 V{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 J{constructor({precacheController:t}){this.cacheKeyWillBeUsed=async({request:t,params:e})=>{const s=(null==e?void 0:e.cacheKey)||this.W.getCacheKeyForURL(t.url);return s?new Request(s,{headers:t.headers}):t},this.W=t}}let Q,X;async function Y(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===Q){const t=new Response("");if("body"in t)try{new Response(t.body),Q=!0}catch(t){Q=!1}Q=!1}return Q}()?r.body:await r.blob();return new Response(o,a)}class Z extends v{constructor(t={}){t.cacheName=w(t.cacheName),super(t),this.j=!1!==t.fallbackToNetwork,this.plugins.push(Z.copyRedirectedCacheableResponsesPlugin)}async U(t,e){const s=await e.cacheMatch(t);return s||(e.event&&"install"===e.event.type?await this.S(t,e):await this.K(t,e))}async K(t,e){let n;const r=e.params||{};if(!this.j)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:"no-cors"!==t.mode?i||s:void 0})),s&&a&&"no-cors"!==t.mode&&(this.A(),await e.cachePut(t,n.clone()))}return n}async S(t,e){this.A();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}A(){let t=null,e=0;for(const[s,n]of this.plugins.entries())n!==Z.copyRedirectedCacheableResponsesPlugin&&(n===Z.defaultPrecacheCacheabilityPlugin&&(t=s),n.cacheWillUpdate&&e++);0===e?this.plugins.push(Z.defaultPrecacheCacheabilityPlugin):e>1&&null!==t&&this.plugins.splice(t,1)}}Z.defaultPrecacheCacheabilityPlugin={cacheWillUpdate:async({response:t})=>!t||t.status>=400?null:t},Z.copyRedirectedCacheableResponsesPlugin={cacheWillUpdate:async({response:t})=>t.redirected?await Y(t):t};class tt{constructor({cacheName:t,plugins:e=[],fallbackToNetwork:s=!0}={}){this.F=new Map,this.H=new Map,this.$=new Map,this.u=new Z({cacheName:w(t),plugins:[...e,new J({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.G||(self.addEventListener("install",this.install),self.addEventListener("activate",this.activate),this.G=!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}=G(n),i="string"!=typeof n&&n.revision?"reload":"default";if(this.F.has(r)&&this.F.get(r)!==t)throw new s("add-to-cache-list-conflicting-entries",{firstEntry:this.F.get(r),secondEntry:t});if("string"!=typeof n&&n.integrity){if(this.$.has(t)&&this.$.get(t)!==n.integrity)throw new s("add-to-cache-list-conflicting-integrities",{url:r});this.$.set(t,n.integrity)}if(this.F.set(r,t),this.H.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 z(t,(async()=>{const e=new V;this.strategy.plugins.push(e);for(const[e,s]of this.F){const n=this.$.get(s),r=this.H.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 z(t,(async()=>{const t=await self.caches.open(this.strategy.cacheName),e=await t.keys(),s=new Set(this.F.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.F}getCachedURLs(){return[...this.F.keys()]}getCacheKeyForURL(t){const e=new URL(t,location.href);return this.F.get(e.href)}getIntegrityForCacheKey(t){return this.$.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 et=()=>(X||(X=new tt),X);class st 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 U(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.V(n),i=this.J(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.J(t);await s.updateTimestamp(e.url),await s.expireEntries()},this.X=t,this.B=t.maxAgeSeconds,this.Y=new Map,t.purgeOnQuotaError&&function(t){g.add(t)}((()=>this.deleteCacheAndMetadata()))}J(t){if(t===d())throw new s("expire-custom-caches-only");let e=this.Y.get(t);return e||(e=new H(t,this.X),this.Y.set(t,e)),e}V(t){if(!this.B)return!0;const e=this.Z(t);if(null===e)return!0;return e>=Date.now()-1e3*this.B}Z(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.Y)await self.caches.delete(t),await e.delete();this.Y=new Map}},t.NetworkFirst=class extends v{constructor(t={}){super(t),this.plugins.some((t=>"cacheWillUpdate"in t))||this.plugins.unshift(u),this.tt=t.networkTimeoutSeconds||0}async U(t,e){const n=[],r=[];let i;if(this.tt){const{id:s,promise:a}=this.et({request:t,logs:n,handler:e});i=s,r.push(a)}const a=this.st({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}et({request:t,logs:e,handler:s}){let n;return{promise:new Promise((e=>{n=setTimeout((async()=>{e(await s.cacheMatch(t))}),1e3*this.tt)})),id:n}}async st({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 $(t,e):e}},t.StaleWhileRevalidate=class extends v{constructor(t={}){super(t),this.plugins.some((t=>"cacheWillUpdate"in t))||this.plugins.unshift(u)}async U(t,e){const n=e.fetchAndCachePut(t).catch((()=>{}));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){et().precache(t)}(t),function(t){const e=et();h(new st(e,t))}(e)},t.registerRoute=h})); diff --git a/src/app/about-us/page.jsx b/src/app/about-us/page.jsx index 5385ea7..8dc8353 100644 --- a/src/app/about-us/page.jsx +++ b/src/app/about-us/page.jsx @@ -16,7 +16,7 @@ const AboutUs = () => {
-

+

At Briz, we envision each coffee shop as a symphony, with every element from the espresso shot to the customer service playing in perfect harmony. Our journey began with the coming together of two @@ -26,10 +26,10 @@ const AboutUs = () => { experience and passion for coffee shop excellence are the foundation of Briz.

-

+

Our Team's Heritage

-

+

Our team consists of six dedicated members, each bringing a unique blend of expertise and innovation from our roots in 'Tuk Coffee' and 'Igarson.' We are baristas, managers, tech enthusiasts, and, above @@ -38,11 +38,11 @@ const AboutUs = () => { commitment to making Briz the ace of your coffee shop orchestr

-

+

Our Team's Heritage

-

+

We believe in the power of an efficiently managed coffee shop - where every task, every role, and every shift contributes to the delightful crescendo of customer satisfaction. Briz is not just an app; it's your @@ -52,11 +52,11 @@ const AboutUs = () => { performing.

-

+

Our Commitment to Your Coffee Shop{" "}

-

+

Our mission is simple yet ambitious: to empower coffee shops to manage their spaces with unprecedented efficiency and insight. Whether it's the bustling rush of the morning crowd or the relaxed ambiance of late @@ -65,9 +65,9 @@ const AboutUs = () => { run a coffee shop, and let's make every cup of coffee an experience to remember.

-
-
- +
+
+
diff --git a/style/globals.css b/style/globals.css index fa17a95..79d7681 100644 --- a/style/globals.css +++ b/style/globals.css @@ -461,6 +461,11 @@ body { background-image: url(../public/images/bg.png); } +.bg-hero-pattern-footer { + background-image: linear-gradient(rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4)), + url(../public/images/bg.png); +} + .bg-dahs-chart { background-image: radial-gradient( circle,