mirror of
https://github.com/vercel/commerce.git
synced 2025-06-13 19:31:20 +00:00
* Updated log * Updates to root * Updates to pnpm * successfully moved to pnpm * type issue * Local as the default provider * Upgrade dependencies * Revert to local * Upgrade React * Update node-fetch deps * Fix types * Ignore warnings * Fix missing dependency * Update pnpm-lock.yaml * Add missing @types/cookie * Upgrade dependencies * Fix missing dependencies * Update README.md Co-authored-by: Bel Curcio <curciobel@gmail.com>
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
import type { FC, ReactNode } from 'react'
|
|
import {
|
|
Provider,
|
|
CommerceProviderProps,
|
|
CoreCommerceProvider,
|
|
useCommerce as useCoreCommerce,
|
|
} from '@vercel/commerce'
|
|
import { spreeProvider } from './provider'
|
|
import type { SpreeProvider } from './provider'
|
|
import { SWRConfig } from 'swr'
|
|
import handleTokenErrors from './utils/handle-token-errors'
|
|
import useLogout from '@vercel/commerce/auth/use-logout'
|
|
|
|
export { spreeProvider }
|
|
export type { SpreeProvider }
|
|
|
|
export const WithTokenErrorsHandling: FC<{ children?: ReactNode }> = ({
|
|
children,
|
|
}) => {
|
|
const logout = useLogout()
|
|
|
|
return (
|
|
<SWRConfig
|
|
value={{
|
|
onError: (error, _key) => {
|
|
handleTokenErrors(error, () => void logout())
|
|
},
|
|
}}
|
|
>
|
|
{children}
|
|
</SWRConfig>
|
|
)
|
|
}
|
|
|
|
export const getCommerceProvider = <P extends Provider>(provider: P) => {
|
|
return function CommerceProvider({
|
|
children,
|
|
...props
|
|
}: CommerceProviderProps) {
|
|
return (
|
|
<CoreCommerceProvider provider={{ ...provider, ...props }}>
|
|
<WithTokenErrorsHandling>{children}</WithTokenErrorsHandling>
|
|
</CoreCommerceProvider>
|
|
)
|
|
}
|
|
}
|
|
|
|
export const CommerceProvider =
|
|
getCommerceProvider<SpreeProvider>(spreeProvider)
|
|
|
|
export const useCommerce = () => useCoreCommerce<SpreeProvider>()
|