mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
f2c2519159
The prepares for next-server. I also took this as an opportunity to get all build directory paths from a single location, as they were previously scattered across webpack/babel plugins and loaders.
51 lines
1.3 KiB
JavaScript
51 lines
1.3 KiB
JavaScript
import { ConcatSource } from 'webpack-sources'
|
|
import {
|
|
IS_BUNDLED_PAGE_REGEX,
|
|
ROUTE_NAME_REGEX
|
|
} from '../../lib/constants'
|
|
|
|
class PageChunkTemplatePlugin {
|
|
apply (chunkTemplate) {
|
|
chunkTemplate.plugin('render', function (modules, chunk) {
|
|
if (!IS_BUNDLED_PAGE_REGEX.test(chunk.name)) {
|
|
return modules
|
|
}
|
|
|
|
let routeName = ROUTE_NAME_REGEX.exec(chunk.name)[1]
|
|
|
|
// We need to convert \ into / when we are in windows
|
|
// to get the proper route name
|
|
// Here we need to do windows check because it's possible
|
|
// to have "\" in the filename in unix.
|
|
// Anyway if someone did that, he'll be having issues here.
|
|
// But that's something we cannot avoid.
|
|
if (/^win/.test(process.platform)) {
|
|
routeName = routeName.replace(/\\/g, '/')
|
|
}
|
|
|
|
routeName = `/${routeName.replace(/(^|\/)index$/, '')}`
|
|
|
|
const source = new ConcatSource()
|
|
|
|
source.add(`__NEXT_REGISTER_PAGE('${routeName}', function() {
|
|
var comp =
|
|
`)
|
|
source.add(modules)
|
|
source.add(`
|
|
return { page: comp.default }
|
|
})
|
|
`)
|
|
|
|
return source
|
|
})
|
|
}
|
|
}
|
|
|
|
export default class PagesPlugin {
|
|
apply (compiler) {
|
|
compiler.plugin('compilation', (compilation) => {
|
|
compilation.chunkTemplate.apply(new PageChunkTemplatePlugin())
|
|
})
|
|
}
|
|
}
|