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-relay-modern
2017-08-14 18:41:12 +02:00
..
components Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
lib Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
pages Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
schema Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
scripts Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
.babelrc Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
.env Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
next.config.js Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
package.json Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00
README.md Relay Modern Example (#1757) (#2773) 2017-08-14 18:41:12 +02:00

Deploy to now

Relay Modern Example

How to use

Download the example or clone the repo:

curl https://codeload.github.com/zeit/next.js/tar.gz/master | tar -xz --strip=2 next.js-master/examples/with-relay-modern
cd with-relay-modern

Install it:

npm install

Setup Graphcool project

npm run graphcool-init

After successful initialization, copy Graphcool Relay Endpoint URL from console and store it into .env file

RELAY_ENDPOINT=your relay endpoint here

Run Relay ahead-of-time compilation (should be re-run after any edits to components that query data with Relay)

npm run relay

Run the project

npm run dev

Deploy it to the cloud with now (download):

now

The idea behind the example

Relay Modern is a new version of Relay designed from the ground up to be easier to use, more extensible and, most of all, able to improve performance on mobile devices. Relay Modern accomplishes this with static queries and ahead-of-time code generation.

In this simple example, we integrate Relay Modern seamlessly with Next by wrapping our pages inside a higher-order component (HOC). Using the HOC pattern we're able to pass down a query result data created by Relay into our React component hierarchy defined inside each page of our Next application. The HOC takes options argument that allows to specify a query that will be executed on the server when a page is being loaded.

This example relies on graph.cool for its GraphQL backend.