forked from vercel/commerce
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.tsx
49 lines (43 loc) · 1.28 KB
/
index.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
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>()