import type { Fetcher } from '@lib/commerce' import { default as useCartRemoveItem } from '@lib/commerce/cart/use-remove-item' import type { RemoveItemBody } from '../api/cart' import { Cart, useCart } from '.' export type RemoveItemInput = { id: string } export function fetcher( fetch: Fetcher, { itemId }: RemoveItemBody ) { return fetch({ url: '/api/bigcommerce/cart', method: 'DELETE', body: { itemId }, }) } export default function useRemoveItem(item?: any) { const { mutate } = useCart() const fn = useCartRemoveItem(fetcher) const removeItem = async (input: RemoveItemInput) => { const data = await fn({ itemId: input.id ?? item?.id }) await mutate(data, false) return data } return removeItem }