The Sitecore GraphQL API is an implementation of a GraphQL server on top of Sitecore. It is designed to be a generic GraphQL service platform, i.e. it's designed to host your API and present it via GraphQL queries. The API also supports real-time data using GraphQL subscriptions.
Last year we worked on building sites based on Sitecore JSS architecture. As usual, all of our pages had a datasource that are located in an item in the PageComponents folder:
data:image/s3,"s3://crabby-images/5226f/5226f3af4777d003fb02279afa7b4cfe1008094b" alt=""
For example, we want to have a component that renders all banners from the Banners folder. We use the Component GraphQL Query to define a structure of data that comes from the Layout Service. By default, GraphQL doesn’t support the Sitecore item queries, such as query:./*[@@name='Page Components']. But sometimes it would be great to have more flexibility than requesting an item only by item path or its ID. To make it possible, we decided to build a custom query. You can find the code below.
data:image/s3,"s3://crabby-images/123a5/123a531d3d1f607f8d17ad10c06d87be7200ec5f" alt=""
The complete code is available by the link.
Then we need to register our query:
data:image/s3,"s3://crabby-images/c0bd6/c0bd6ab08282c2779fa40a1aa68b68a432312802" alt=""
The config file is available here.
When the query is deployed to the website root, we can build the following query:
Also, using this extension, we can can rebuild the query mentioned in GraphQL Extensibility: SiteRelativeItem Query by building the query like below.
data:image/s3,"s3://crabby-images/78ce1/78ce11a9d0872c513670e35953350e6bd4589055" alt=""
The result will be the same as in the case of using the SiteRelativeItem Query.