@rejdeboerp/react-components
v3.12.14
Published
A Fork of the Official Commerce Layer React Components
Downloads
8
Maintainers
Readme
Commerce Layer React Components
A collection of reusable React components that makes it super fast and simple to build your own custom commerce UI, leveraging Commerce Layer API.
What is Commerce Layer?
Commerce Layer is a multi-market commerce API and order management system that lets you add global shopping capabilities to any website, mobile app, chatbot, wearable, voice, or IoT device, with ease. Compose your stack with the best-of-breed tools you already mastered and love. Make any experience shoppable, anywhere, through a blazing-fast, enterprise-grade, and secure API.
Getting started
To get started with Commerce Layer React Components you need to install them and then get the credentials that will allow you to perform the API calls they wrap.
Installation
Commerce Layer React Components are available as an npm package:
// npm
npm install @commercelayer/react-components
// yarn
yarn add @commercelayer/react-components
Authentication
All requests to Commerce Layer API must be authenticated with an OAuth2 bearer token. Hence, to use these components, you need to get a valid access token. Once you got it, you can pass it as prop — together with the endpoint of your Commerce Layer organization — to the CommerceLayer
component, as follow:
<CommerceLayer
accessToken="your-access-token"
endpoint="https://yourdomain.commercelayer.io">
{/* ... child components */}
</CommerceLayer>
This token will be used to authorize the API calls of all its child components. That's why the presence of (at least) one CommerceLayer
component is mandatory — it must wrap every other component you need to use.
Please note that — in case you need to fetch data with different tokens (i.e. from different organizations or using apps with different roles and permissions) — nothing prevents you from putting as many
CommerceLayer
components you want in the same page.
You can check our documentation for more information about the available authorization flows and leverage Commerce Layer JS Auth to easily interact with our authentication API.
Import
You can use ES6 named import with every single component you plan to use (in addition to CommerceLayer
one), as follow:
import { CommerceLayer, ...otherComponents } from '@commercelayer/react-components'
Check this summary table for the complete (and constantly updated) list of available components.
Usage
The code snippets below show how to put into action Commerce Layer React Components in some common use cases. Check the pages
folder of this repository for more detailed examples.
Under the hood, our React components are built on top of Commerce Layer JS SDK — feel free to use it if you want to develop your custom ones.
Prices
This example shows how to use Commerce Layer React Components to display the prices of some SKUs, identified by their SKU codes:
import {
CommerceLayer,
PricesContainer,
Price
} from '@commercelayer/react-components'
// your code [...]
<CommerceLayer accessToken="your-access-token" endpoint="https://yourdomain.commercelayer.io">
<PricesContainer>
<Price
skuCode="BABYONBU000000E63E7412MX"
className="your-custom-class"
compareClassName="your-custom-class"
/>
<Price
skuCode="CANVASAU000000FFFFFF1824"
className="your-custom-class"
compareClassName="your-custom-class"
/>
<Price
skuCode="LSLEEVMM000000E63E74LXXX"
className="your-custom-class"
compareClassName="your-custom-class"
/>
</PricesContainer>
</CommerceLayer>
// your code [...]
You can style the selling price and the full price as you like by passing the className
and compareClassName
props to the Price
component. You can choose not to show the full price by passing showCompare={false}
(default is true
).
If you need to paginate the list of prices, pass the perPage
prop to the PricesContainer
component (default is 10
) — to learn how pagination works, check our documentation.
Add to cart
This example shows how to use Commerce Layer React Components to implement the "add to cart" functionality on your page, showing the price of the chosen SKU, the possibility to select a variant and its quantity, the information about its availability, and the related button to perform the action:
import {
CommerceLayer,
OrderContainer,
OrderStorage,
ItemContainer,
PricesContainer,
Price,
VariantsContainer,
VariantSelector,
QuantitySelector,
AddToCartButton,
AvailabilityContainer,
AvailabilityTemplate
} from '@commercelayer/react-components'
// your code [...]
<CommerceLayer accessToken="your-access-token" endpoint="https://yourdomain.commercelayer.io">
<OrderStorage persistKey="your-persist-key">
<OrderContainer
attributes={{
cart_url: 'https://yourdomain.com/cart',
return_url: 'https://yourdomain.com/return',
privacy_url: 'https://yourdomain.com/privacy'
}}>
<ItemContainer>
<PricesContainer>
<Price skuCode="BABYONBU000000E63E746MXX" />
</PricesContainer>
<VariantsContainer>
<VariantSelector
placeholder="Select a size"
options={[
{
label: '6 months',
code: 'BABYONBU000000E63E746MXX',
lineItem: {
name: 'your-item-name',
imageUrl: 'https://img.yourdomain.com/your-item-image.png'
}
},
{
label: '12 months',
code: 'BABYONBU000000E63E7412MX',
lineItem: {
name: 'your-item-name',
imageUrl: 'https://img.yourdomain.com/your-item-image.png'
}
}
]}
/>
</VariantsContainer>
<QuantitySelector />
<AddToCartButton />
<AvailabilityContainer>
<AvailabilityTemplate />
</AvailabilityContainer>
</ItemContainer>
</OrderContainer>
</OrderStorage>
</CommerceLayer>
// your code [...]
For each variant you can define the custom name (i.e. its translation based on location) and image that will be shown on the corresponding line item, by passing the options
prop to the VariantSelector
component and properly setting the lineItem
key — all these content data are usually taken from your CMS, since Commerce Layer doesn't manage any kind of content. You can change the type of input by passing type="radio"
(default is select
).
When you add a product to your shopping cart:
- if there is an order stored in the Local Storage identified by a key that matches the
persistKey
property, a line item is created and it is associated with that order; - if no order in the Local Storage matches the
persistKey
property, a new order is created and stored.
A common best practice — especially for multi-country ecommerce — is to use as
persistKey
a key containing the country code, so that you have a different shopping cart for each country.
If you need to set some of the order object attributes at the moment of the order creation, pass to the optional prop attributes
to the OrderContainer
component.
Shopping cart
This example shows how to use Commerce Layer React Components to build a shopping cart UI, containing the items that are going to be purchased with all their information (image, name, quantity, price) and the option to possibly remove some of them:
import {
CommerceLayer,
OrderContainer,
OrderStorage,
LineItemsContainer,
LineItemsCount,
LineItem,
LineItemImage,
LineItemName,
LineItemQuantity,
LineItemAmount,
LineItemRemoveLink,
Errors
} from '@commercelayer/react-components'
// your code [...]
<CommerceLayer accessToken="your-access-token" endpoint="https://yourdomain.commercelayer.io">
<OrderStorage persistKey="your-persist-key">
<OrderContainer>
<LineItemsContainer>
<p className="your-custom-class">
Your shopping cart contains <LineItemsCount /> items
</p>
<LineItem>
<LineItemImage width={50} />
<LineItemName />
<LineItemQuantity max={10} />
<Errors resource="lineItem" field="quantity" />
<LineItemAmount />
<LineItemRemoveLink />
</LineItem>
</LineItemsContainer>
</OrderContainer>
</OrderStorage>
</CommerceLayer>
// your code [...]
The Errors
component lets you show the error (if present) returned by our API on a single attribute of a specific resource. You can customize the error message as you like by passing the messages
prop to the component.
Cart summary
This example shows how to use Commerce Layer React Components to show a sample order summary with all the order line items (including discounts, shipping costs, taxes, and gift cards — if present) and totals:
import {
CommerceLayer,
OrderContainer,
OrderStorage,
SubTotalAmount,
DiscountAmount,
ShippingAmount,
TaxesAmount,
GiftCardAmount,
TotalAmount,
CheckoutLink
} from '@commercelayer/react-components'
// your code [...]
<CommerceLayer accessToken="your-access-token" endpoint="https://yourdomain.commercelayer.io">
<OrderStorage persistKey="your-persist-key">
<OrderContainer>
<SubTotalAmount />
<DiscountAmount />
<ShippingAmount />
<TaxesAmount />
<GiftCardAmount />
<TotalAmount />
<CheckoutLink />
</OrderContainer>
</OrderStorage>
</CommerceLayer>
// your code [...]
You can change the amount format of each line of the summary by passing the format
prop to the desired component (default is formatted
).
The CheckoutLink
component lets you proceed to checkout and links to the checkout URL configured on Commerce Layer (Settings → Markets).
List of components
These are the currently available Commerce Layer React Components.
Please note that not every Commerce Layer React component can be nested into any other one.
For each component, the table below shows its props and the list of the permitted children (if any):
| Name | Props | Children |
| -------------------------- | -------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| AddToCartButton
| disabled
label
skuCode
lineItem
|
| AvailabilityContainer
| skuCode
| AvailabilityTemplate
|
| AvailabilityTemplate
| showShippingMethodName
timeFormat
|
| CheckoutLink
| label
|
| CommerceLayer
| accessToken
endpoint
| GiftCardContainer
OrderContainer
PricesContainer
|
| DiscountAmount
| className
format
id
name
style
|
| Errors
| field
messages
resource
|
| ExternalFunction
| url
| AddToCartButton
|
| GiftCard
| onSubmit
| Errors
GiftCardCurrencySelector
GiftCardInput
MetadataInput
SubmitButton
|
| GiftCardAmount
| className
format
id
name
style
|
| GiftCardContainer
| | GiftCard
Errors
|
| GiftCardCurrencySelector
| placeholder
required
value
|
| GiftCardInput
| name
placeholder
type
|
| ItemContainer
| lineItem
skuCode
| AddToCartButton
AvailabilityContainer
QuantitySelector
PricesContainer
SkuOptionContainer
VariantsContainer
|
| LineItem
| type
| Errors
LineItemAmount
LineItemImage
LineItemName
LineItemOptions
LineItemQuantity
LineItemRemoveLink
|
| LineItemAmount
| className
format
id
name
style
type
|
| LineItemImage
| width
|
| LineItemName
| |
| LineItemOption
| keyClassName
keyId
keyStyle
name
valueClassName
|
| LineItemOptions
| title
showName
skuOptionId
| LineItemOption
|
| LineItemQuantity
| disabled
max
|
| LineItemRemoveLink
| label
|
| LineItemsContainer
| filters
loader
| LineItem
LineItemsCount
|
| LineItemsCount
| className
id
name
style
|
| MetadataInput
| name
onChange
placeholder
type
|
| OrderContainer
| attributes
metadata
orderId
| CheckoutLink
DiscountAmount
GiftCardAmount
GiftCardContainer
ItemContainer
LineItemsContainer
ShippingAmount
SubTotalAmount
TaxesAmount
TotalAmount
|
| OrderStorage
| clearWhenPlaced
persistKey
| OrderContainer
|
| Price
| compareClassName
showCompare
skuCode
|
| PricesContainer
| filters
loader
perPage
skuCode
| Price
|
| QuantitySelector
| disabled
max
min
skuCode
value
|
| ShippingAmount
| className
format
id
name
style
|
| SkuOption
| id
| SkuOptionInput
|
| SkuOptionInput
| name
onChange
placeholder
type
|
| SkuOptionsContainer
| skuCode
| SkuOption
|
| SubmitButton
| label
|
| SubTotalAmount
| className
format
id
name
style
|
| TaxesAmount
| className
format
id
name
style
|
| TotalAmount
| className
format
id
name
style
|
| VariantsContainer
| filters
skuCode
| VariantSelector
|
| VariantSelector
| loader
name
options
placehoder
skuCode
type
|
For more detailed information on each components (i.e. prop types and default values, required props, etc.), have a look at the configuration file src/config/components.ts
.
License
This repository is published under the MIT license.