You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

63 lines
3.0 KiB

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const expo_pwa_1 = require("expo-pwa");
const JsonWebpackPlugin_1 = __importDefault(require("./JsonWebpackPlugin"));
function maybeFetchPlugin(compiler, name) {
var _a, _b;
return (_b = (_a = compiler.options) === null || _a === void 0 ? void 0 : _a.plugins) === null || _b === void 0 ? void 0 : _b.map(({ constructor }) => constructor).find(constructor => constructor && constructor.name === name);
}
class PwaManifestWebpackPlugin extends JsonWebpackPlugin_1.default {
constructor(pwaOptions, manifest) {
super({
path: pwaOptions.path,
json: manifest,
pretty: true,
});
this.pwaOptions = pwaOptions;
this.rel = 'manifest';
}
apply(compiler) {
super.apply(compiler);
compiler.hooks.make.tapPromise(this.constructor.name, async (compilation) => {
// Hook into the html-webpack-plugin processing and add the html
const HtmlWebpackPlugin = maybeFetchPlugin(compiler, 'HtmlWebpackPlugin');
if (HtmlWebpackPlugin) {
if (typeof HtmlWebpackPlugin.getHooks === 'undefined') {
compilation.errors.push(new Error('PwaManifestWebpackPlugin - This PwaManifestWebpackPlugin version is not compatible with your current HtmlWebpackPlugin version.\n'));
return;
}
HtmlWebpackPlugin.getHooks(compilation).alterAssetTags.tapAsync(this.constructor.name, (data, htmlCallback) => {
// Skip if a custom injectFunction returns false or if
// the htmlWebpackPlugin optuons includes a `favicons: false` flag
let isInjectionAllowed;
if (typeof this.pwaOptions.inject === 'boolean') {
isInjectionAllowed = this.pwaOptions.inject;
}
else if (typeof this.pwaOptions.inject === 'function') {
isInjectionAllowed = this.pwaOptions.inject(data.plugin);
}
else {
isInjectionAllowed = data.plugin.options.pwaManifest !== false;
}
if (isInjectionAllowed === false) {
return htmlCallback(null, data);
}
data.assetTags.meta.push({
tagName: 'link',
voidTag: true,
attributes: {
rel: this.rel,
href: (0, expo_pwa_1.joinUrlPath)(this.pwaOptions.publicPath, this.pwaOptions.path),
},
});
htmlCallback(null, data);
});
}
});
}
}
exports.default = PwaManifestWebpackPlugin;
//# sourceMappingURL=PwaManifestWebpackPlugin.js.map