import type { GetAllProductPathsQuery, GetAllProductPathsQueryVariables, } from '../schema' import type { RecursivePartial, RecursiveRequired } from '../api/utils/types' import filterEdges from '../api/utils/filter-edges' import { VendureConfig, getConfig } from '../api' export const getAllProductPathsQuery = /* GraphQL */ ` query getAllProductPaths($first: Int = 100) { products(options: { take: $first }) { items { slug } } } ` export type ProductPath = NonNullable< NonNullable[0] > export type ProductPaths = ProductPath[] export type { GetAllProductPathsQueryVariables } export type GetAllProductPathsResult< T extends { products: any[] } = { products: ProductPaths } > = T async function getAllProductPaths(opts?: { variables?: GetAllProductPathsQueryVariables config?: VendureConfig }): Promise async function getAllProductPaths< T extends { products: any[] }, V = any >(opts: { query: string variables?: V config?: VendureConfig }): Promise> async function getAllProductPaths({ query = getAllProductPathsQuery, variables, config, }: { query?: string variables?: GetAllProductPathsQueryVariables config?: VendureConfig } = {}): Promise { config = getConfig(config) // 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< RecursivePartial >(query, { variables }) const products = data.products.items return { products: products.map(p => ({ node: { path: `/${p.slug}` } })), } } export default getAllProductPaths