import { useCallback } from 'react' import { HookFetcher } from '@commerce/utils/types' import useCartRemoveItem from '@commerce/cart/use-remove-item' import { normalizeCart } from '../lib/normalize' import type { RemoveItemBody, Cart as BigcommerceCart } from '../api/cart' import useCart from './use-cart' const defaultOpts = { url: '/api/bigcommerce/cart', method: 'DELETE', } export type RemoveItemInput = { id: string } export const fetcher: HookFetcher = async ( options, { itemId }, fetch ) => { const data = await fetch({ ...defaultOpts, ...options, body: { itemId }, }) return normalizeCart(data) } export function extendHook(customFetcher: typeof fetcher) { const useRemoveItem = (item?: any) => { const { mutate } = useCart() const fn = useCartRemoveItem( defaultOpts, customFetcher ) return useCallback( async function removeItem(input: RemoveItemInput) { const data = await fn({ itemId: input.id ?? item?.id }) await mutate(data, false) return data }, [fn, mutate] ) } useRemoveItem.extend = extendHook return useRemoveItem } export default extendHook(fetcher)