2019-05-17 13:25:46 +02:00
|
|
|
import { Compiler, Plugin } from 'webpack'
|
2019-04-24 10:48:43 +02:00
|
|
|
import { extname } from 'path'
|
2019-04-21 23:25:17 +02:00
|
|
|
|
|
|
|
// Prevents outputting client pages when they are not needed
|
|
|
|
export class DropClientPage implements Plugin {
|
2019-04-24 10:48:43 +02:00
|
|
|
ampPages = new Set();
|
|
|
|
|
2019-04-21 23:25:17 +02:00
|
|
|
apply(compiler: Compiler) {
|
|
|
|
compiler.hooks.emit.tap('DropClientPage', compilation => {
|
|
|
|
Object.keys(compilation.assets).forEach(assetKey => {
|
|
|
|
const asset = compilation.assets[assetKey]
|
|
|
|
|
|
|
|
if (asset && asset._value && asset._value.includes('__NEXT_DROP_CLIENT_FILE__')) {
|
2019-05-14 18:49:41 +02:00
|
|
|
const cleanAssetKey = assetKey.replace(/\\/g, '/')
|
|
|
|
const page = '/' + cleanAssetKey.split('pages/')[1]
|
2019-04-24 10:48:43 +02:00
|
|
|
const pageNoExt = page.split(extname(page))[0]
|
|
|
|
|
|
|
|
this.ampPages.add(pageNoExt.replace(/\/index$/, '') || '/')
|
2019-04-21 23:25:17 +02:00
|
|
|
delete compilation.assets[assetKey]
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|