import { useMemo } from 'react' import { SWRHook } from '@commerce/utils/types' import useCart, { UseCart } from '@commerce/cart/use-cart' import epClient from '../utils/ep-client' import normalizeCart from '../utils/normalize-cart' export default useCart as UseCart export const handler: SWRHook = { fetchOptions: { query: '', }, async fetcher({fetch}) { const {data:cartData} = await epClient.Cart().Get(); const {data:cartItems} = await epClient.Cart().Items(); return normalizeCart(cartData, cartItems); }, useHook: ({ useData }) => (input) => { const response = useData({ swrOptions: { revalidateOnFocus: false, ...input?.swrOptions }, }) console.log("checking data..", epClient.Cart()); return useMemo( () => Object.create(response, { isEmpty: { get() { return (response.data?.lineItems.length ?? 0) <= 0 }, enumerable: true, }, }), [response] ) }, }