mirror of
https://github.com/vercel/commerce.git
synced 2025-05-17 06:56:59 +00:00
59 lines
1.7 KiB
TypeScript
59 lines
1.7 KiB
TypeScript
import Cookies from 'js-cookie'
|
|
import type { MutationHook } from '@vercel/commerce/utils/types'
|
|
import { useCallback } from 'react'
|
|
import useUpdateItem, {
|
|
UseUpdateItem,
|
|
} from '@vercel/commerce/customer/address/use-update-item'
|
|
import { useCheckoutContext } from '@components/checkout/context'
|
|
import selectFulfillmentOptions from '../../api/mutations/select-fulfillment-options'
|
|
|
|
import { useCheckout } from '../../checkout'
|
|
import { UpdateAddressItemHook } from '../../types/customer/address'
|
|
import { OPENCOMMERCE_ANONYMOUS_CART_TOKEN_COOKIE } from '../../const'
|
|
|
|
export default useUpdateItem as UseUpdateItem<typeof handler>
|
|
|
|
export const handler: MutationHook<UpdateAddressItemHook> = {
|
|
fetchOptions: {
|
|
query: selectFulfillmentOptions,
|
|
},
|
|
async fetcher({ input: { item, itemId: cartId }, options, fetch }) {
|
|
const cartToken = Cookies.get(OPENCOMMERCE_ANONYMOUS_CART_TOKEN_COOKIE)
|
|
|
|
if (!cartId) return null
|
|
|
|
const data = await fetch({
|
|
...options,
|
|
variables: {
|
|
input: {
|
|
cartId,
|
|
cartToken,
|
|
fulfillmentMethodId: item.shippingMethodId,
|
|
},
|
|
},
|
|
})
|
|
|
|
return data
|
|
},
|
|
useHook: ({ fetch }) =>
|
|
function useHook() {
|
|
const { data: checkoutData } = useCheckout()
|
|
|
|
const { setAddressFields, addressFields } = useCheckoutContext()
|
|
return useCallback(
|
|
async function updateItem(input) {
|
|
const { id, ...rest } = input
|
|
await fetch({
|
|
input: { item: { ...rest }, itemId: id },
|
|
})
|
|
setAddressFields({
|
|
...addressFields,
|
|
shippingMethodId: rest.shippingMethodId,
|
|
})
|
|
return null
|
|
},
|
|
[setAddressFields]
|
|
)
|
|
},
|
|
}
|