4
0
forked from crowetic/commerce
commerce/packages/commercejs/src/cart/use-remove-item.tsx
Catalin Pinte 90aa798891
Fix Commerce.js product normalizer (#877)
* Fix normalizer, since assets is optional now.

* Fix missing categories & options

* Update cart normalizer
2022-11-16 08:36:16 +02:00

39 lines
1.1 KiB
TypeScript

import { useCallback } from 'react'
import type { MutationHook } from '@vercel/commerce/utils/types'
import type { RemoveItemHook } from '@vercel/commerce/types/cart'
import useRemoveItem, {
UseRemoveItem,
} from '@vercel/commerce/cart/use-remove-item'
import type { CommercejsCart } from '../types'
import { normalizeCart } from '../utils/normalize-cart'
import useCart from './use-cart'
export default useRemoveItem as UseRemoveItem<typeof handler>
export const handler: MutationHook<RemoveItemHook> = {
fetchOptions: {
query: 'cart',
method: 'remove',
},
async fetcher({ input, options, fetch }) {
const cart = await fetch<CommercejsCart>({
query: options.query,
method: options.method,
variables: input.itemId,
})
return normalizeCart(cart)
},
useHook: ({ fetch }) =>
function useHook() {
const { mutate } = useCart()
return useCallback(
async function removeItem(input) {
const cart = await fetch({ input: { itemId: input.id } })
await mutate(cart, false)
return cart
},
[mutate]
)
},
}