4
0
forked from crowetic/commerce
commerce/lib/bigcommerce/cart/use-remove-item.tsx
2020-10-07 15:27:22 -05:00

32 lines
794 B
TypeScript

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<Cart | null>,
{ itemId }: RemoveItemBody
) {
return fetch({
url: '/api/bigcommerce/cart',
method: 'DELETE',
body: { itemId },
})
}
export default function useRemoveItem(item?: any) {
const { mutate } = useCart()
const fn = useCartRemoveItem<Cart | null, RemoveItemBody>(fetcher)
const removeItem = async (input: RemoveItemInput) => {
const data = await fn({ itemId: input.id ?? item?.id })
await mutate(data, false)
return data
}
return removeItem
}