mirror of
https://github.com/vercel/commerce.git
synced 2025-05-18 23:46:58 +00:00
50 lines
1.3 KiB
TypeScript
50 lines
1.3 KiB
TypeScript
import type { ComponentType, FunctionComponent } 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: FunctionComponent = ({ 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>()
|