import { useCallback } from 'react' import type { MutationHook } from '@commerce/utils/types' import { CommerceError } from '@commerce/utils/errors' import useRemoveItem, { RemoveItemInput, UseRemoveItem, } from '@commerce/wishlist/use-remove-item' import type { RemoveItemBody, Wishlist } from '../api/wishlist' import useCustomer from '../customer/use-customer' import useWishlist, { UseWishlistInput } from './use-wishlist' export default useRemoveItem as UseRemoveItem export const handler: MutationHook< Wishlist | null, { wishlist?: UseWishlistInput }, RemoveItemInput, RemoveItemBody > = { fetchOptions: { url: '/api/bigcommerce/wishlist', method: 'DELETE', }, useHook: ({ fetch }) => ({ wishlist } = {}) => { const { data: customer } = useCustomer() const { revalidate } = useWishlist(wishlist) return useCallback( async function removeItem(input) { if (!customer) { // A signed customer is required in order to have a wishlist throw new CommerceError({ message: 'Signed customer not found', }) } const data = await fetch({ input: { itemId: String(input.id) } }) await revalidate() return data }, [fetch, revalidate, customer] ) }, }