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.

46 lines
1.9 KiB

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const chalk_1 = __importDefault(require("chalk"));
const expo_pwa_1 = require("expo-pwa");
const ModifyJsonWebpackPlugin_1 = __importDefault(require("./ModifyJsonWebpackPlugin"));
function logNotice(type, message) {
console.log(chalk_1.default.magenta(`\u203A ${type}: ${chalk_1.default.gray(message)}`));
}
function logWarning(type, message) {
console.log(chalk_1.default.yellow(`\u203A ${type}: ${chalk_1.default.gray(message)}`));
}
class ChromeIconsWebpackPlugin extends ModifyJsonWebpackPlugin_1.default {
// Maybe we should support the ability to create all icons individually
constructor(options, icon) {
// TODO(Bacon): Validation
super();
this.options = options;
this.icon = icon;
}
async modifyAsync(compiler, compilation, data) {
// If the icons array is already defined, then skip icon generation.
if (Array.isArray(data.json.icons)) {
logNotice('Chrome Icons', `Using custom \`icons\` from PWA manifest`);
return data;
}
if (!this.icon) {
logWarning('Chrome Icons', `No template image found, skipping auto generation...`);
return data;
}
data.json.icons = [];
const iconAssets = await (0, expo_pwa_1.generateChromeIconAsync)(this.options, this.icon, {});
for (const asset of iconAssets) {
compilation.assets[asset.asset.path] = {
source: () => asset.asset.source,
size: () => asset.asset.source.length,
};
data.json.icons.push(asset.manifest);
}
return data;
}
}
exports.default = ChromeIconsWebpackPlugin;
//# sourceMappingURL=ChromeIconsWebpackPlugin.js.map