'use strict'; /* */ var isJS = function (file) { return /\.js(\?[^.]+)?$/.test(file); }; var ref = require('chalk'); var red = ref.red; var yellow = ref.yellow; var prefix = "[vue-server-renderer-webpack-plugin]"; var warn = exports.warn = function (msg) { return console.error(red((prefix + " " + msg + "\n"))); }; var tip = exports.tip = function (msg) { return console.log(yellow((prefix + " " + msg + "\n"))); }; var hash = require('hash-sum'); var VueSSRClientPlugin = function VueSSRClientPlugin (options) { if ( options === void 0 ) options = {}; this.options = Object.assign({ filename: 'vue-ssr-client-manifest.json' }, options); }; VueSSRClientPlugin.prototype.apply = function apply (compiler) { var this$1 = this; compiler.plugin('emit', function (compilation, cb) { var stats = compilation.getStats().toJson(); var allFiles = stats.assets .map(function (a) { return a.name; }); var initialFiles = Object.keys(stats.entrypoints) .map(function (name) { return stats.entrypoints[name].assets; }) .reduce(function (assets, all) { return all.concat(assets); }, []) .filter(isJS); var asyncFiles = allFiles .filter(isJS) .filter(function (file) { return initialFiles.indexOf(file) < 0; }); var manifest = { publicPath: stats.publicPath, all: allFiles, initial: initialFiles, async: asyncFiles, modules: { /* [identifier: string]: Array */ } }; var assetModules = stats.modules.filter(function (m) { return m.assets.length; }); var fileToIndex = function (file) { return manifest.all.indexOf(file); }; stats.modules.forEach(function (m) { // ignore modules duplicated in multiple chunks if (m.chunks.length === 1) { var cid = m.chunks[0]; var chunk = stats.chunks.find(function (c) { return c.id === cid; }); var files = manifest.modules[hash(m.identifier)] = chunk.files.map(fileToIndex); // find all asset modules associated with the same chunk assetModules.forEach(function (m) { if (m.chunks.some(function (id) { return id === cid; })) { files.push.apply(files, m.assets.map(fileToIndex)); } }); } }); // const debug = (file, obj) => { // require('fs').writeFileSync(__dirname + '/' + file, JSON.stringify(obj, null, 2)) // } // debug('stats.json', stats) // debug('client-manifest.json', manifest) var json = JSON.stringify(manifest, null, 2); compilation.assets[this$1.options.filename] = { source: function () { return json; }, size: function () { return json.length; } }; cb(); }); }; module.exports = VueSSRClientPlugin;