import { useCallback } from 'react' import { HookFetcher } from '../../commerce/utils/types' import { CommerceError } from '../../commerce/utils/errors' import useWishlistRemoveItem from '../../commerce/wishlist/use-remove-item' import type { RemoveItemBody } from '../api/wishlist' import useCustomer from '../use-customer' import useWishlist, { Wishlist } from './use-wishlist' const defaultOpts = { url: '/api/bigcommerce/wishlist', method: 'DELETE', } export type RemoveItemInput = { id: string | number } export const fetcher: HookFetcher = ( options, { itemId }, fetch ) => { return fetch({ ...defaultOpts, ...options, body: { itemId }, }) } export function extendHook(customFetcher: typeof fetcher) { const useRemoveItem = () => { const { data: customer } = useCustomer() const { mutate } = useWishlist() const fn = useWishlistRemoveItem( defaultOpts, customFetcher ) return useCallback( async function removeItem(input: RemoveItemInput) { if (!customer) { // A signed customer is required in order to have a wishlist throw new CommerceError({ message: 'Signed customer not found', }) } const data = await fn({ itemId: String(input.id) }) await mutate(data, false) return data }, [fn, mutate, customer] ) } useRemoveItem.extend = extendHook return useRemoveItem } export default extendHook(fetcher)