4
0
forked from crowetic/commerce

40 lines
919 B
TypeScript
Raw Normal View History

2021-02-04 13:23:44 +02:00
import * as React from 'react'
2021-02-08 09:15:20 +02:00
import { ReactNode } from 'react'
2021-02-04 13:23:44 +02:00
import {
2021-02-09 15:02:22 +02:00
CommerceConfig,
2021-02-04 13:23:44 +02:00
CommerceProvider as CoreCommerceProvider,
useCommerce as useCoreCommerce,
} from '@commerce'
2021-02-09 15:02:22 +02:00
import { shopifyProvider, ShopifyProvider } from './provider'
import { SHOPIFY_CHECKOUT_ID_COOKIE } from './const'
export { shopifyProvider }
export type { ShopifyProvider }
export const shopifyConfig: CommerceConfig = {
locale: 'en-us',
cartCookie: SHOPIFY_CHECKOUT_ID_COOKIE,
}
export type ShopifyConfig = Partial<CommerceConfig>
2021-02-04 13:23:44 +02:00
export type ShopifyProps = {
children?: ReactNode
locale: string
} & ShopifyConfig
export function CommerceProvider({ children, ...config }: ShopifyProps) {
return (
2021-02-09 15:02:22 +02:00
<CoreCommerceProvider
provider={shopifyProvider}
config={{ ...shopifyConfig, ...config }}
>
2021-02-04 13:23:44 +02:00
{children}
</CoreCommerceProvider>
)
}
export const useCommerce = () => useCoreCommerce()