@quasar/app
Version:
Quasar Framework local CLI
97 lines (77 loc) • 2.83 kB
JavaScript
/*
* Forked from vue-server-renderer/client-plugin.js v2.6.12 NPM package
*/
const hash = require('hash-sum')
const { sources, Compilation } = require('webpack')
const jsCssRE = /\.(js|css)(\?[^.]+)?$/
const swRE = /\s\w+$/
const hotUpdateRE = /\.hot-update\.js$/
const uniq = arr => [ ...new Set(arr) ]
function getClientManifest (compilation) {
const stats = compilation.getStats().toJson()
const allFiles = uniq(
stats.assets.map(a => a.name).filter(file => hotUpdateRE.test(file) === false)
)
const initialFiles = uniq(
Object.keys(stats.entrypoints)
.map(name => stats.entrypoints[name].assets.map(entry => entry.name))
.reduce((assets, all) => all.concat(assets), [])
.filter(file => jsCssRE.test(file) === true && hotUpdateRE.test(file) === false)
)
const asyncFiles = allFiles
.filter(file => jsCssRE.test(file))
.filter(file => initialFiles.includes(file) === false)
const manifest = {
publicPath: stats.publicPath,
all: allFiles,
initial: initialFiles,
async: asyncFiles,
modules: { /* [identifier: string]: Array<index: number> */ }
}
const assetModules = stats.modules.filter(m => m.assets.length)
const fileToIndex = file => manifest.all.indexOf(file)
stats.modules.forEach(m => {
// ignore modules duplicated in multiple chunks
if (m.chunks.length === 1) {
const cid = m.chunks[0]
const chunk = stats.chunks.find(c => c.id === cid)
if (!chunk || !chunk.files) {
return
}
const id = m.identifier.replace(swRE, '') // remove appended hash
const files = manifest.modules[hash(id)] = chunk.files.map(fileToIndex)
// find all asset modules associated with the same chunk
assetModules.forEach(m => {
if (m.chunks.some(id => id === cid)) {
files.push.apply(files, m.assets.map(fileToIndex))
}
})
}
})
return manifest
}
module.exports.getClientManifest = getClientManifest
module.exports.QuasarSSRClientPlugin = class QuasarSSRClientPlugin {
constructor (cfg = {}) {
this.cfg = cfg
}
apply (compiler) {
compiler.hooks.thisCompilation.tap('quasar-ssr-client-plugin', compilation => {
compilation.hooks.processAssets.tapAsync(
{ name: 'quasar-ssr-client-plugin', state: Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL },
(_, callback) => {
const manifest = getClientManifest(compilation)
const json = JSON.stringify(manifest, null, 2)
const content = new sources.RawSource(json)
if (compilation.getAsset(this.cfg.filename) !== void 0) {
compilation.updateAsset(this.cfg.filename, content)
}
else {
compilation.emitAsset(this.cfg.filename, content)
}
callback()
}
)
})
}
}