This course is no longer maintained and may be out-of-date. While it remains available for reference, its content may not reflect the latest updates, best practices, or supported features.
Set up GraphQL PPX
In our previous step we successfully configured Apollo. Next, we need to setup GraphQL PPX to start making GraphQL queries.
graphql-ppx automatically generate types for our GraphQL queries based on GraphQL schema and provides building blocks for GraphQL clients.
GraphQL PPX Installation
Let's install graphql-ppx:
npm install @reasonml-community/graphql-ppx
Next, let's add ppx-flags and update bs-dependencies in your bsconfig.json:
{...- "bs-dependencies": ["@rescript/react", "rescript-apollo-client"],+ "bs-dependencies": ["@rescript/react", "rescript-apollo-client", "@reasonml-community/graphql-ppx"],+ "ppx-flags": ["@reasonml-community/graphql-ppx/ppx"]}
Next, let's add Apollo Client configuration for graphql-ppx
{..."ppx-flags": ["@reasonml-community/graphql-ppx/ppx"],+ "graphql": {+ "apolloMode": true,+ "extendMutation": "ApolloClient.GraphQL_PPX.ExtendMutation",+ "extendQuery": "ApolloClient.GraphQL_PPX.ExtendQuery",+ "extendSubscription": "ApolloClient.GraphQL_PPX.ExtendSubscription",+ "templateTagReturnType": "ApolloClient.GraphQL_PPX.templateTagReturnType",+ "templateTagImport": "gql",+ "templateTagLocation": "@apollo/client"+ }}
Get GraphQL Schema
graphql-ppx
needs your graphql schema to be available in the form of a graphql_schema.json
file.
We can get it by running the command
npx get-graphql-schema ENDPOINT_URL -j > graphql_schema.json
In our case, ENDPOINT_URL is https://hasura.io/learn/graphql
.
Since our graphql endpoint is authenticated we also need pass Authorization header
npx get-graphql-schema https://hasura.io/learn/graphql --header "Authorization=Bearer tokenId" -j > graphql_schema.json
You can find tokenId in Request Headers
section of https://hasura.io/learn/graphql/graphiql
, after logging in.
graphql_schema.json
generated by above command should be placed in the root folder of the project.
Now we are ready to start making GraphQL queries.
Build apps and APIs 10x faster
Built-in authorization and caching
8x more performant than hand-rolled APIs
data:image/s3,"s3://crabby-images/d807b/d807b10f22067a93d38cb31c49e9b6df16526408" alt="Promo"
data:image/s3,"s3://crabby-images/868ff/868ffb1210a1adc758a09817d07c9681a5c10cc9" alt="footer illustration"