v1.0 with SW PWA enabled
This commit is contained in:
70
frontend/node_modules/workbox-build/build/lib/module-registry.js
generated
vendored
Normal file
70
frontend/node_modules/workbox-build/build/lib/module-registry.js
generated
vendored
Normal file
@ -0,0 +1,70 @@
|
||||
"use strict";
|
||||
/*
|
||||
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.
|
||||
*/
|
||||
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||
};
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.ModuleRegistry = void 0;
|
||||
const common_tags_1 = require("common-tags");
|
||||
const upath_1 = __importDefault(require("upath"));
|
||||
/**
|
||||
* Class for keeping track of which Workbox modules are used by the generated
|
||||
* service worker script.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
class ModuleRegistry {
|
||||
/**
|
||||
* @private
|
||||
*/
|
||||
constructor() {
|
||||
this._modulesUsed = new Map();
|
||||
}
|
||||
/**
|
||||
* @return {Array<string>} A list of all of the import statements that are
|
||||
* needed for the modules being used.
|
||||
* @private
|
||||
*/
|
||||
getImportStatements() {
|
||||
const workboxModuleImports = [];
|
||||
for (const [localName, { moduleName, pkg }] of this._modulesUsed) {
|
||||
// By default require.resolve returns the resolved path of the 'main'
|
||||
// field, which might be deeper than the package root. To work around
|
||||
// this, we can find the package's root by resolving its package.json and
|
||||
// strip the '/package.json' from the resolved path.
|
||||
const pkgJsonPath = require.resolve(`${pkg}/package.json`);
|
||||
const pkgRoot = upath_1.default.dirname(pkgJsonPath);
|
||||
const importStatement = (0, common_tags_1.oneLine) `import {${moduleName} as ${localName}} from
|
||||
'${pkgRoot}/${moduleName}.mjs';`;
|
||||
workboxModuleImports.push(importStatement);
|
||||
}
|
||||
return workboxModuleImports;
|
||||
}
|
||||
/**
|
||||
* @param {string} pkg The workbox package that the module belongs to.
|
||||
* @param {string} moduleName The name of the module to import.
|
||||
* @return {string} The local variable name that corresponds to that module.
|
||||
* @private
|
||||
*/
|
||||
getLocalName(pkg, moduleName) {
|
||||
return `${pkg.replace(/-/g, '_')}_${moduleName}`;
|
||||
}
|
||||
/**
|
||||
* @param {string} pkg The workbox package that the module belongs to.
|
||||
* @param {string} moduleName The name of the module to import.
|
||||
* @return {string} The local variable name that corresponds to that module.
|
||||
* @private
|
||||
*/
|
||||
use(pkg, moduleName) {
|
||||
const localName = this.getLocalName(pkg, moduleName);
|
||||
this._modulesUsed.set(localName, { moduleName, pkg });
|
||||
return localName;
|
||||
}
|
||||
}
|
||||
exports.ModuleRegistry = ModuleRegistry;
|
||||
Reference in New Issue
Block a user