Our recommended structure for GraphQL queries in GatsbyJS projects
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/879ce/879ce79174f4e69b71c2fbf2a62ee71397c20321" alt="Two flowers that represent GraphQL and Gatsby side by side. Beneath them sits the text "Recommended GraphQL Queries Structure"."
Our recommendations for structuring backend GraphQL queries in a GatsbyJS project. Github repository included.
The following article discusses and demonstrates the principles behind our GraphQL methodology and lists out the folder structure that is suggested for GraphQL queries within a GatsbyJS project.
The concept is covered from the perspective of using the GraphQL to gather data from a Craft CMS as well as to push data to Algolia.
Break queries down into reusable components
The principle behind our GraphQL methodology is to breakdown queries into reusable components. Anything that falls under an entry, matrix or is used in multiple places is recommended.
An example of a reusable query and it implemented within another reusable query is demonstrated in the two images below.
data:image/s3,"s3://crabby-images/e7f1f/e7f1fe322432130e4e37100f76e3ccc8fb6042d6" alt="A screenshot of a query in VSCode that represents a reusable Image GraphQL query."
Example of a reusable query
data:image/s3,"s3://crabby-images/1cce2/1cce22480672543b5b00d0f1ef32d13036a5e0e8" alt="A screenshot of VSCode showing a reusable Image GraphQL query being used within a reusable Hero query."
Example of a reusable query in use
Recommended GraphQL folder structure
data:image/s3,"s3://crabby-images/77276/77276ff065b88c96cc829f0e680851890d70ec63" alt="A screenshot of VSCode showing our GraphQL folder structure."
The GraphQL folder is the base folder for the queries and is found at the root level of the project.
We recommend breaking it down into the following folders:
A | Algolia
We recommend that you use this folder to hold all the algolia queries, as they are often larger than the fragments that you use to represent search results.
B | Fields
We recommend that you use this folder to hold reusable queries for entries, matrices, super tables or neo blocks.
C | Fragments
We recommend that you use this folder to hold queries related to fragments that are used across your GraphQL queries.
Fragments are small portions of entries which hold the relevant information, such as uri, title or description, that needs to be demonstrated consistently across your website.
D | Globals
We recommend that you use this folder to hold elements that are used across your website. We use this for the Navigation Bar, Footer and Styleguide.
E | Media
We recommend that you use this folder to hold your media queries. We use this for colors, styles, videos, online videos and images.
F | Pages
We recommend that you use this folder to hold the queries related to entries that represent pages such as your home, about or contact page.
Any Questions ?
We are actively looking for feedback on how to improve this resource. Please send us a note to inquiries@delasign.com with any thoughts or feedback you may have.