1
0
Fork 0
mirror of https://github.com/terribleplan/next.js.git synced 2024-01-19 02:48:18 +00:00
next.js/server/build/plugins/pages-plugin.js

43 lines
1.4 KiB
JavaScript
Raw Normal View History

export default class PagesPlugin {
apply (compiler) {
const isBundledPage = /^bundles[/\\]pages.*\.js$/
const matchRouteName = /^bundles[/\\]pages[/\\](.*)\.js$/
compiler.plugin('after-compile', (compilation, callback) => {
const pages = Object
.keys(compilation.namedChunks)
.map(key => compilation.namedChunks[key])
.filter(chunk => isBundledPage.test(chunk.name))
pages.forEach((chunk) => {
const page = compilation.assets[chunk.name]
const pageName = matchRouteName.exec(chunk.name)[1]
2017-04-05 06:45:39 +00:00
const routeName = `/${pageName.replace(/[/\\]?index$/, '')}`
const content = page.source()
const newContent = `
2017-04-05 06:45:39 +00:00
function loadPage () {
window.__NEXT_PAGE_LOADER__.registerPage('${routeName}', function(cb) {
var comp = ${content}
cb(null, comp.default)
})
2017-04-05 06:45:39 +00:00
}
if (window.__NEXT_PAGE_LOADER__) {
2017-04-05 06:45:39 +00:00
loadPage()
} else {
window.__NEXT_LOADED_PAGES__ = window.__NEXT_LOADED_PAGES__ || []
window.__NEXT_LOADED_PAGES__.push(loadPage)
2017-04-05 06:45:39 +00:00
}
`
2017-04-06 05:03:11 +00:00
// Replace the exisiting chunk with the new content
compilation.assets[chunk.name] = {
source: () => newContent,
size: () => newContent.length
}
})
callback()
})
}
}