titan/__sapper__/dev/service-worker.js

121 lines
12 KiB
JavaScript

(function () {
'use strict';
// This file is generated by Sapper — do not edit it!
const timestamp = 1630246359828;
const files = [
"/service-worker-index.html",
"/clipboard.svg",
"/code-brackets.svg",
"/colors.svg",
"/comments.svg",
"/direction.svg",
"/favicon.png",
"/flow.svg",
"/global.css",
"/logo-192.png",
"/logo-512.png",
"/manifest.json",
"/plugin.svg",
"/repo.svg",
"/stackalt.svg"
];
const shell = [
"/client/client.c97202b9.js",
"/client/inject_styles.5607aec6.js",
"/client/index.8acd0411.js",
"/client/settings.bc34a1df.js",
"/client/about.d6b80a2c.js",
"/client/sapper-dev-client.146c9185.js"
];
const ASSETS = `cache${timestamp}`;
// `shell` is an array of all the files generated by the bundler,
// `files` is an array of everything in the `static` directory
const to_cache = shell.concat(files);
const staticAssets = new Set(to_cache);
self.addEventListener('install', event => {
event.waitUntil(
caches
.open(ASSETS)
.then(cache => cache.addAll(to_cache))
.then(() => {
self.skipWaiting();
})
);
});
self.addEventListener('activate', event => {
event.waitUntil(
caches.keys().then(async keys => {
// delete old caches
for (const key of keys) {
if (key !== ASSETS) await caches.delete(key);
}
self.clients.claim();
})
);
});
/**
* Fetch the asset from the network and store it in the cache.
* Fall back to the cache if the user is offline.
*/
async function fetchAndCache(request) {
const cache = await caches.open(`offline${timestamp}`);
try {
const response = await fetch(request);
cache.put(request, response.clone());
return response;
} catch (err) {
const response = await cache.match(request);
if (response) return response;
throw err;
}
}
self.addEventListener('fetch', event => {
if (event.request.method !== 'GET' || event.request.headers.has('range')) return;
const url = new URL(event.request.url);
// don't try to handle e.g. data: URIs
const isHttp = url.protocol.startsWith('http');
const isDevServerRequest = url.hostname === self.location.hostname && url.port !== self.location.port;
const isStaticAsset = url.host === self.location.host && staticAssets.has(url.pathname);
const skipBecauseUncached = event.request.cache === 'only-if-cached' && !isStaticAsset;
if (isHttp && !isDevServerRequest && !skipBecauseUncached) {
event.respondWith(
(async () => {
// always serve static files and bundler-generated assets from cache.
// if your application has other URLs with data that will never change,
// set this variable to true for them and they will only be fetched once.
const cachedAsset = isStaticAsset && await caches.match(event.request);
// for pages, you might want to serve a shell `service-worker-index.html` file,
// which Sapper has generated for you. It's not right for every
// app, but if it's right for yours then uncomment this section
/*
if (!cachedAsset && url.origin === self.origin && routes.find(route => route.pattern.test(url.pathname))) {
return caches.match('/service-worker-index.html');
}
*/
return cachedAsset || fetchAndCache(event.request);
})()
);
}
});
}());
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"service-worker.js","sources":["../../src/node_modules/@sapper/service-worker.js","../../src/service-worker.js"],"sourcesContent":["// This file is generated by Sapper — do not edit it!\nexport const timestamp = 1630246359828;\n\nexport const files = [\n\t\"/service-worker-index.html\",\n\t\"/clipboard.svg\",\n\t\"/code-brackets.svg\",\n\t\"/colors.svg\",\n\t\"/comments.svg\",\n\t\"/direction.svg\",\n\t\"/favicon.png\",\n\t\"/flow.svg\",\n\t\"/global.css\",\n\t\"/logo-192.png\",\n\t\"/logo-512.png\",\n\t\"/manifest.json\",\n\t\"/plugin.svg\",\n\t\"/repo.svg\",\n\t\"/stackalt.svg\"\n];\nexport { files as assets }; // legacy\n\nexport const shell = [\n\t\"/client/client.c97202b9.js\",\n\t\"/client/inject_styles.5607aec6.js\",\n\t\"/client/index.8acd0411.js\",\n\t\"/client/settings.bc34a1df.js\",\n\t\"/client/about.d6b80a2c.js\",\n\t\"/client/sapper-dev-client.146c9185.js\"\n];\n\nexport const routes = [\n\t{ pattern: /^\\/$/ },\n\t{ pattern: /^\\/settings\\/?$/ },\n\t{ pattern: /^\\/about\\/?$/ }\n];","import { timestamp, files, shell } from '@sapper/service-worker';\n\nconst ASSETS = `cache${timestamp}`;\n\n// `shell` is an array of all the files generated by the bundler,\n// `files` is an array of everything in the `static` directory\nconst to_cache = shell.concat(files);\nconst staticAssets = new Set(to_cache);\n\nself.addEventListener('install', event => {\n\tevent.waitUntil(\n\t\tcaches\n\t\t\t.open(ASSETS)\n\t\t\t.then(cache => cache.addAll(to_cache))\n\t\t\t.then(() => {\n\t\t\t\tself.skipWaiting();\n\t\t\t})\n\t);\n});\n\nself.addEventListener('activate', event => {\n\tevent.waitUntil(\n\t\tcaches.keys().then(async keys => {\n\t\t\t// delete old caches\n\t\t\tfor (const key of keys) {\n\t\t\t\tif (key !== ASSETS) await caches.delete(key);\n\t\t\t}\n\n\t\t\tself.clients.claim();\n\t\t})\n\t);\n});\n\n\n/**\n * Fetch the asset from the network and store it in the cache. \n * Fall back to the cache if the user is offline.\n */\nasync function fetchAndCache(request) {\n\tconst cache = await caches.open(`offline${timestamp}`)\n\n\ttry {\n\t\tconst response = await fetch(request);\n\t\tcache.put(request, response.clone());\n\t\treturn response;\n\t} catch (err) {\n\t\tconst response = await cache.match(request);\n\t\tif (response) return response;\n\n\t\tthrow err;\n\t}\n}\n\nself.addEventListener('fetch', event => {\n\tif (event.request.method !== 'GET' || event.request.headers.has('range')) return;\n\n\tconst url = new URL(event.request.url);\n\n\t// don't try to handle e.g. data: URIs\n\tconst isHttp = url.protocol.startsWith('http');\n\tconst isDevServerRequest = url.hostname === self.location.hostname && url.port !== self.location.port;\n\tconst isStaticAsset = url.host === self.location.host && staticAssets.has(url.pathname);\n\tconst skipBecauseUncached = event.request.cache === 'only-if-cached' && !isStaticAsset;\n\n\tif (isHttp && !isDevServerRequest && !skipBecauseUncached) {\n\t\tevent.respondWith(\n\t\t\t(async () => {\n\t\t\t\t// always serve static files and bundler-generated assets from cache.\n\t\t\t\t// if your application has other URLs with data that will never change,\n\t\t\t\t// set this variable to true for them and they will only be fetched once.\n\t\t\t\tconst cachedAsset = isStaticAsset && await caches.match(event.request);\n\n\t\t\t\t// for pages, you might want to serve a shell `service-worker-index.html` file,\n\t\t\t\t// which Sapper has generated for you. It's not right for every\n\t\t\t\t// app, but if it's right for yours then uncomment this section\n\t\t\t\t/*\n\t\t\t\tif (!cachedAsset && url.origin === self.origin && routes.find(route => route.pattern.test(url.pathname))) {\n\t\t\t\t\treturn caches.match('/service-worker-index.html');\n\t\t\t\t}\n\t\t\t\t*/\n\n\t\t\t\treturn cachedAsset || fetchAndCache(event.request);\n\t\t\t})()\n\t\t);\n\t}\n});\n"],"names":[],"mappings":"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"}