import { FetcherError } from '@commerce/utils/errors' import type { Fetcher } from '@commerce/utils/types' import { normalizeCart } from './lib/normalize' import { handler as useCart } from './cart/use-cart' import { handler as useWishlist } from './wishlist/use-wishlist' import { handler as useCustomer } from './customer/use-customer' import { handler as useSearch } from './product/use-search' async function getText(res: Response) { try { return (await res.text()) || res.statusText } catch (error) { return res.statusText } } async function getError(res: Response) { if (res.headers.get('Content-Type')?.includes('application/json')) { const data = await res.json() return new FetcherError({ errors: data.errors, status: res.status }) } return new FetcherError({ message: await getText(res), status: res.status }) } const fetcher: Fetcher = async ({ url, method = 'GET', variables, body: bodyObj, }) => { const hasBody = Boolean(variables || bodyObj) const body = hasBody ? JSON.stringify(variables ? { variables } : bodyObj) : undefined const headers = hasBody ? { 'Content-Type': 'application/json' } : undefined const res = await fetch(url!, { method, body, headers }) if (res.ok) { const { data } = await res.json() return data } throw await getError(res) } export const bigcommerceProvider = { locale: 'en-us', cartCookie: 'bc_cartId', fetcher, cartNormalizer: normalizeCart, cart: { useCart }, wishlist: { useWishlist }, customer: { useCustomer }, products: { useSearch }, } export type BigcommerceProvider = typeof bigcommerceProvider