Faceted and Textual Search with the GraphQL Storefront API
Faceted search is a method of helping shoppers navigate a store's product inventory by categorizing products into various categories, brands, product features, and more. Textual search is a method of retrieving products based on product fields, for example, product name and description. BigCommerce's GraphQL Storefront API lets merchants on headless storefronts use faceted and textual search powered by results from our back-end search engine. These built-in capabilities also allow Stencil developers to take advantage of our search engine.
The GraphQL Storefront API's faceted and textual search lets you create the following features:
- Load category pages with no selections, including both the facets and products relevant to the search results
- Load category pages with facet selections for specific facets
- Load featured products from specific categories
- Quickly search products by using search terms (textual search)
- Sort products alphabetically, from newest to oldest, and more
You can access these features by querying the SearchProducts
field. Note that you can query facets, filter by rating, or filter by "in-stock" only if the merchant is on a Pro or Enterprise plan. A merchant must enable product filtering (opens in a new tab) for facets to be returned. In addition, only facets that a merchant marks as visible in their Product Filtering settings will be returned.
This page walks you through how to filter and query products and facets to display on your storefront. See the GraphQL Storefront Playground for full schema documentation.
Filter products and facets
To use faceted and textual search, specify a filter in the argument for SearchProducts
. For faceted search, you can filter by price, rating, among other features and attributes of products. For textual search, use the searchTerm
field.
...
searchProducts(
filters: {
searchTerm: "Sample"
price:{
minPrice:11,
maxPrice:200
},
rating:{
minRating:3,
maxRating:5
},
categoryEntityId:24,
searchSubCategories:false,
categoryEntityIds:[23],
brandEntityIds:[35],
productAttributes:[
{
attribute:"Color",
values:["Black"]
}
],
isFreeShipping:true,
isFeatured:true,
isInStock:true
}
...
)
...
These filters affect both the products and facets that are returned. For example, filtering by rating returns only products within the specified rating range and only facets that have products within the rating range.
See the GraphQL Storefront playground for descriptions of each filter.
Get products
To get products, specify products
as a field in searchProducts
. Here is an example request that returns the first two products with a rating between three and five:
query {
site {
search {
searchProducts(
filters: {
rating:{
minRating:3,
maxRating:5
}
}
) {
products(first: 2) {
edges {
node {
entityId
name
prices {
price {
value
}
}
}
}
}
}
}
}
}
You can sort the products that are returned using the sort
field. Here is an example query that searches for products using a search term and sorts the returned products in alphabetical order:
query {
site {
search {
searchProducts(
filters: {
searchTerm: "Sample"
}
sort: A_TO_Z
) {
products(first: 2) {
edges {
node {
entityId
name
prices {
price {
value
}
}
}
}
}
}
}
}
}
The sort
affects only the list of products returned. A merchant's product filtering settings (opens in a new tab) determine how facets are sorted.
If you sort by price, the products sort by either their salePrice
or basePrice
if sortPrice
doesn't exist.
For a list of product fields that searchTerm
searches, see the Store Search Product Fields (opens in a new tab) article.
Get facets
To get facets, specify filters
as a field in searchProducts
. Here is an example request that returns the specified facets that have products with a rating between three and five:
query {
site {
search {
searchProducts(
filters: {
rating:{
minRating:3,
maxRating:5
}
}
) {
filters {
edges {
node {
__typename
name
isCollapsedByDefault
... on CategorySearchFilter {
name
displayProductCount
isCollapsedByDefault
categories {
edges {
node {
entityId
isSelected
productCount
subCategories {
edges {
node {
entityId
name
}
}
}
}
}
}
}
... on OtherSearchFilter {
name
displayProductCount
isCollapsedByDefault
freeShipping {
isSelected
productCount
}
isInStock {
isSelected
productCount
}
isFeatured {
isSelected
productCount
}
}
}
}
}
}
}
}
}
Note: The only facet query that works differently is ProductAttributeSearchFilter
. To query names and information inside this filter, you must also query for the name one level above that node. If you do not format the query this way, the nodes will return empty.
For a complete list of facets, see the GraphQL Storefront playground.
Put it all together: get products and facets
To get both products and facets, specify both products
and filters
fields in searchProducts
.
query {
site {
search {
searchProducts(
filters: {
searchTerm: "Sample"
rating:{
minRating:3,
maxRating:5
}
}
sort: A_TO_Z
) {
products(first: 2) {
edges {
node {
entityId
name
prices {
price {
value
}
}
}
}
}
filters {
edges {
node {
__typename
name
isCollapsedByDefault
... on CategorySearchFilter {
name
displayProductCount
isCollapsedByDefault
categories {
edges {
node {
entityId
isSelected
productCount
subCategories {
edges {
node {
entityId
name
}
}
}
}
}
}
}
... on OtherSearchFilter {
name
displayProductCount
isCollapsedByDefault
freeShipping {
isSelected
productCount
}
isInStock {
isSelected
productCount
}
isFeatured {
isSelected
productCount
}
}
}
}
}
}
}
}
}
If a merchant has not enabled product filtering, you will receive an empty array for the returned facets, though products will still be returned:
{
"data": {
"site": {
"search": {
"searchProducts": {
"products": {
"edges": [
{
"node": {
"entityId": 93,
"name": "[Sample] 1 L Le Parfait Jar",
"prices": {
"price": {
"value": 7
}
}
}
},
{
"node": {
"entityId": 80,
"name": "[Sample] Orbit Terrarium - Large",
"prices": {
"price": {
"value": 109
}
}
}
}
]
},
"filters": {
"edges": []
}
}
}
}
}
}