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

Fix server rendering issue for normal apps.

This commit is contained in:
Arunoda Susiripala 2017-05-08 23:38:36 -07:00
parent 42f1d2efda
commit 147a5ce641
2 changed files with 8 additions and 7 deletions

View file

@ -133,6 +133,7 @@ export default class Link extends Component {
// "<page>/index.html" directly. // "<page>/index.html" directly.
const endsWithSlash = /\/$/.test(props.href) const endsWithSlash = /\/$/.test(props.href)
if ( if (
typeof __NEXT_DATA__ !== 'undefined' &&
__NEXT_DATA__.nextExport && __NEXT_DATA__.nextExport &&
!endsWithSlash !endsWithSlash
) { ) {

View file

@ -49,6 +49,13 @@ async function doRender (req, res, pathname, query, {
const dist = getConfig(dir).distDir const dist = getConfig(dir).distDir
// realPathname is pretty useful in the document.js
// In there, we include a proper valid resolved path.
// That helps us to server that JSON page directly from a static server.
// Basically, this is a requirment for next-export
const pageRealPath = await resolvePath(join(dir, dist, 'dist', 'pages', page))
const realPathname = pageRealPath.replace(join(dir, dist, 'dist', 'pages'), '')
let [Component, Document] = await Promise.all([ let [Component, Document] = await Promise.all([
requireModule(join(dir, dist, 'dist', 'pages', page)), requireModule(join(dir, dist, 'dist', 'pages', page)),
requireModule(join(dir, dist, 'dist', 'pages', '_document')) requireModule(join(dir, dist, 'dist', 'pages', '_document'))
@ -91,13 +98,6 @@ async function doRender (req, res, pathname, query, {
if (res.finished) return if (res.finished) return
// realPathname is pretty useful in the document.js
// In there, we include a proper valid resolved path.
// That helps us to server that JSON page directly from a static server.
// Basically, this is a requirment for next-export
const pageRealPath = await resolvePath(join(dir, 'pages', pathname))
const realPathname = pageRealPath.replace(join(dir, 'pages'), '')
const doc = createElement(Document, { const doc = createElement(Document, {
__NEXT_DATA__: { __NEXT_DATA__: {
props, props,