From 9d1fbbfadd614ff115dcf5d8209b009f7cde9fc1 Mon Sep 17 00:00:00 2001 From: Illia Kovalenko <23364749+illiakovalenko@users.noreply.github.com> Date: Thu, 25 Feb 2021 07:42:09 +0200 Subject: [PATCH] [Doc] [NextJS] Walkthrough: Using GraphQL in component SSR/SSG (#587) * [JSS] [NextJS] Walkthrough: Using GraphQL in component SSR/SSG * fix mistake * Grammar/readability improvements * Grammar/readability improvements * Improvements * Add changes * Remove GraphqlFragmentData part * Remove mistake * Review language * Readability and clarity on content * Fix typo * Typos * Clarify returning result data Co-authored-by: Anastasiya Flynn Co-authored-by: Anca Emcken Co-authored-by: Adam Brauer --- .../docs/nextjs/graphql/component/en.md | 50 +++++++++++++++++++ docs/src/app/components/Navigation/nextjs.js | 4 ++ 2 files changed, 54 insertions(+) create mode 100644 docs/data/routes/docs/nextjs/graphql/component/en.md diff --git a/docs/data/routes/docs/nextjs/graphql/component/en.md b/docs/data/routes/docs/nextjs/graphql/component/en.md new file mode 100644 index 0000000000..6d4a0f4ee0 --- /dev/null +++ b/docs/data/routes/docs/nextjs/graphql/component/en.md @@ -0,0 +1,50 @@ +--- +name: component +routeTemplate: ./data/component-templates/article.yml +title: Using GraphQL in component SSR/SSG +--- +# Walkthrough: Using Component-Level GraphQL in SSR/SSG + +The Next.js sample app provides support for [component-level data fetching](/docs/nextjs/data-fetching/component-level-data-fetching), which enables executing GraphQL queries at the component level. + +> NOTE: If you follow the Code First developer workflow, you can execute GraphQL component-level queries only in Connected Mode. They are not supported in [Disconnected Mode](/docs/techniques/working-disconnected/disconnected-overview). + +The Next.js sample app utilizes the [apollo-client](https://www.apollographql.com/docs/react/) library to facilitate fetching, caching, and managing local and remote data with GraphQL. The `GraphQLClientFactory` is responsible for initializing a new [ApolloClient](https://www.apollographql.com/docs/react/api/core/ApolloClient) instance. + +In the code, we want to have strong types connected to GraphQL types defined in the Sitecore GraphQL Edge endpoint. To achieve this we are using [GraphQL Introspection](/docs/nextjs/graphql/introspection/). + +The sample app provides a GraphiQL interface for exploring the schema and testing queries. By default, the interface can be accessed using `${SITECORE_API_HOST}/sitecore/api/graph/edge/ui?sc_apikey=${SITECORE_API_KEY}`. This interface is helpful if you need to determine what graphQL types can be used by your components. Note that `graphql-let` provides the same information about types in corresponding `.graphq.d.ts` files. + +This walkthrough utilizes the sample apps's [GraphQL-ConnectedDemo](https://github.com/Sitecore/jss/blob/master/samples/nextjs/src/components/graphql/GraphQL-ConnectedDemo.tsx) component. + +To use component-level data fetching with GraphQL, complete the following steps: + +1. Define `getStaticProps` and/or `getServerSideProps` in your component. You should perform the following steps inside these functions. +2. Create a new GraphQL client. `GraphQLClientFactory` is using the [apollo-client](https://www.apollographql.com/docs/react) library. +```ts +import GraphQLClientFactory from 'lib/GraphQLClientFactory'; +... +const graphQLClient = GraphQLClientFactory(); +``` +3. Import the needed GraphQL query. [graphql-let](https://github.com/piglovesyou/graphql-let) provides ability to import queries. +```ts +import { GraphQlConnectedDemo as GrapQLConnectedDemoDatasource } from './GraphQL-ConnectedDemo.graphql'; +``` +4. To execute the query, use `graphQLClient.query` and return the resulting `data`. +```ts +const result = await graphQLClient.query({ + query: ConnectedDemoQueryDocument, + variables: { + datasource: rendering.dataSource, + contextItem: layoutData?.sitecore?.route?.itemId, + }, +}); + +return result.data; +``` +5. In the `render` function access this data using `useComponentProps` hook. +```ts +const data = props.rendering.uid + ? useComponentProps(props.rendering.uid) + : undefined; +``` diff --git a/docs/src/app/components/Navigation/nextjs.js b/docs/src/app/components/Navigation/nextjs.js index 1e806112c2..222257ccb7 100644 --- a/docs/src/app/components/Navigation/nextjs.js +++ b/docs/src/app/components/Navigation/nextjs.js @@ -144,6 +144,10 @@ export default { url: 'introspection', displayName: 'Introspecting the GraphQL schema' }, + { + url: 'component', + displayName: 'Using GraphQL in component SSR/SSG' + }, ], }, {