import type { GetAllProductsQuery, GetAllProductsQueryVariables, } from 'lib/bigcommerce/schema'; import type { RecursivePartial, RecursiveRequired } from '../utils/types'; import { productInfoFragment } from '../fragments/product'; import { BigcommerceConfig, getConfig, Images, ProductImageVariables, } from '..'; export const getAllProductsQuery = /* GraphQL */ ` query getAllProducts( $first: Int = 10 $imgSmallWidth: Int = 320 $imgSmallHeight: Int $imgMediumWidth: Int = 640 $imgMediumHeight: Int $imgLargeWidth: Int = 960 $imgLargeHeight: Int $imgXLWidth: Int = 1280 $imgXLHeight: Int ) { site { products(first: $first) { pageInfo { startCursor endCursor } edges { cursor node { ...productInfo } } } } } ${productInfoFragment} `; export interface GetAllProductsResult { products: T extends GetAllProductsQuery ? NonNullable : unknown; } export type ProductVariables = Images & Omit; async function getAllProducts(opts?: { query?: string; variables?: ProductVariables; config?: BigcommerceConfig; }): Promise>; async function getAllProducts(opts: { query: string; variables?: V; config?: BigcommerceConfig; }): Promise>; async function getAllProducts({ query = getAllProductsQuery, variables: vars, config = getConfig(), }: { query?: string; variables?: ProductVariables; config?: BigcommerceConfig; } = {}): Promise> { const variables: GetAllProductsQueryVariables = { ...config.imageVariables, ...vars, }; // RecursivePartial forces the method to check for every prop in the data, which is // required in case there's a custom `query` const data = await config.fetch>( query, { variables } ); const products = data.site?.products?.edges; return { products: (products as RecursiveRequired) ?? [], }; } export default getAllProducts;