feat: updating with master / add getCommerceProvider

This commit is contained in:
Reza Babaei
2021-09-04 18:11:08 +03:00
parent c71c3d1ae6
commit ec918b2aa3
3 changed files with 5 additions and 35 deletions

View File

@@ -1,4 +1,4 @@
# Available providers: local, bigcommerce, shopify, swell, saleor # Available providers: local, bigcommerce, shopify, swell, saleor, woocommerce
COMMERCE_PROVIDER= COMMERCE_PROVIDER=
BIGCOMMERCE_STOREFRONT_API_URL= BIGCOMMERCE_STOREFRONT_API_URL=

View File

@@ -6,4 +6,4 @@ export const WOOCOMMERCE_CUSTOMER_TOKEN_COOKIE = 'woocommerce_customerToken'
export const WOOCOMMERCE_COOKIE_EXPIRE = 30 export const WOOCOMMERCE_COOKIE_EXPIRE = 30
export const API_URL = process.env.NEXT_PUBLIC_WOOCOMMERCE_SHOP_API_URL export const API_URL = process.env.NEXT_PUBLIC_WOOCOMMERCE_SHOP_API_URL ?? '/'

View File

@@ -1,39 +1,9 @@
import * as React from 'react' import { getCommerceProvider, useCommerce as useCoreCommerce } from '@commerce'
import { ReactNode } from 'react' import { wooCommerceProvider, WooCommerceProvider } from './provider'
import {
CommerceConfig,
CommerceProvider as CoreCommerceProvider,
useCommerce as useCoreCommerce,
} from '@commerce'
import { wooCommerceProvider } from './provider'
import type { WooCommerceProvider } from './provider'
import { WOOCOMMERCE_CHECKOUT_ID_COOKIE } from './const'
export { wooCommerceProvider } export { wooCommerceProvider }
export type { WooCommerceProvider } export type { WooCommerceProvider }
export const wooCommerceConfig: CommerceConfig = { export const CommerceProvider = getCommerceProvider(wooCommerceProvider)
locale: 'en-us',
cartCookie: WOOCOMMERCE_CHECKOUT_ID_COOKIE,
}
export type WooCommerceConfig = Partial<CommerceConfig>
export type ShopifyProps = {
children?: ReactNode
} & WooCommerceConfig
export function CommerceProvider({ children, ...config }: ShopifyProps) {
return (
<CoreCommerceProvider
provider={wooCommerceProvider}
config={{ ...wooCommerceConfig, ...config }}
>
{children}
</CoreCommerceProvider>
)
}
export const useCommerce = () => useCoreCommerce<WooCommerceProvider>() export const useCommerce = () => useCoreCommerce<WooCommerceProvider>()