commerce/packages/commercejs/checkout/use-submit-checkout.tsx
2022-01-13 20:58:26 -05:00

39 lines
1.0 KiB
TypeScript

import type { SubmitCheckoutHook } from '@commerce/types/checkout'
import type { MutationHook } from '@commerce/utils/types'
import { useCallback } from 'react'
import useSubmitCheckout, {
UseSubmitCheckout,
} from '@commerce/checkout/use-submit-checkout'
import { useCheckoutContext } from '@components/checkout/context'
export default useSubmitCheckout as UseSubmitCheckout<typeof handler>
export const handler: MutationHook<SubmitCheckoutHook> = {
fetchOptions: {
url: '/api/checkout',
method: 'POST',
},
async fetcher({ input: item, options, fetch }) {
const data = await fetch({
...options,
body: { item },
})
return data
},
useHook: ({ fetch }) =>
function useHook() {
const { cardFields, addressFields } = useCheckoutContext()
return useCallback(
async function onSubmitCheckout(input) {
const data = await fetch({
input: { card: cardFields, address: addressFields },
})
return data
},
[cardFields, addressFields]
)
},
}