mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
21d5aebd53
In this example, we can: - `QueryRenderer` SSR - caching the data - use the feature of `react-relay-network-modern` which is the powerful tool for `relay-modern` I copy the example `with-relay-modern`, but I just modified the code. Some detail are not modified. If you think this example is needed, I will fix those. Otherwise, close this **PR** to let me know this example is not needed.
60 lines
1.4 KiB
JavaScript
60 lines
1.4 KiB
JavaScript
import React from 'react'
|
|
import { QueryRenderer, fetchQuery } from 'react-relay'
|
|
import NextApp, { Container } from 'next/app'
|
|
|
|
import {
|
|
initEnvironment,
|
|
createEnvironment
|
|
} from '../lib/createEnvironment'
|
|
|
|
export default class App extends NextApp {
|
|
static getInitialProps = async ({ Component, router, ctx }) => {
|
|
const { variables } = Component.getInitialProps ? await Component.getInitialProps(ctx) : {}
|
|
|
|
try {
|
|
if (initEnvironment) {
|
|
const { environment, relaySSR } = initEnvironment()
|
|
|
|
await fetchQuery(environment, Component.query, variables)
|
|
|
|
return {
|
|
variables,
|
|
relayData: await relaySSR.getCache()
|
|
}
|
|
}
|
|
} catch (e) {
|
|
console.log(e)
|
|
}
|
|
|
|
return {
|
|
variables
|
|
}
|
|
};
|
|
|
|
render () {
|
|
const { Component, variables = {}, relayData } = this.props
|
|
const environment = createEnvironment(
|
|
relayData,
|
|
JSON.stringify({
|
|
queryID: Component.query ? Component.query().name : undefined,
|
|
variables
|
|
})
|
|
)
|
|
|
|
return (
|
|
<Container>
|
|
<QueryRenderer
|
|
environment={environment}
|
|
query={Component.query}
|
|
variables={variables}
|
|
render={({ error, props }) => {
|
|
if (error) return <div>{error.message}</div>
|
|
else if (props) return <Component {...props} />
|
|
return <div>Loading</div>
|
|
}}
|
|
/>
|
|
</Container>
|
|
)
|
|
}
|
|
}
|