1
0
Fork 0
mirror of https://github.com/terribleplan/next.js.git synced 2024-01-19 02:48:18 +00:00
next.js/examples/with-react-relay-network-modern/pages/_app.js

59 lines
1.4 KiB
JavaScript
Raw Normal View History

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>
)
}
}