* Add missing import for add cart functionality file * Added the Tab section to the Update Cart section * Removed unnecessary spaces
404 lines
11 KiB
Plaintext
404 lines
11 KiB
Plaintext
import Tabs from '@theme/Tabs';
|
||
import TabItem from '@theme/TabItem';
|
||
|
||
# How to Add Cart Functionality
|
||
|
||
This document guides you through how you can add cart-related functionalities to your storefront. That includes creating and updating a cart and managing items in the cart.
|
||
|
||
## Overview
|
||
|
||
Carts are necessary for ecommerce platforms to allow customers to buy products. Each customer, whether logged in or as a guest, should have a cart associated with them. The customer can then add products to the cart.
|
||
|
||
This document helps you understand how to add the cart functionality to your storefront. This is helpful if you’re creating the storefront from scratch, or you want to understand how the process generally works in Medusa’s starter storefronts.
|
||
|
||
:::note
|
||
|
||
This document does not cover implementing the checkout flow. You can refer to [this documentation instead to learn how to implement the checkout flow](../advanced/storefront/how-to-implement-checkout-flow.mdx).
|
||
|
||
:::
|
||
|
||
### Glossary
|
||
|
||
- **Line Item**: When products are added to the cart in Medusa, they are referred to as line items. Line items have, by default, the same properties and attributes as a product. However, you can customize line items specifically for a cart if necessary.
|
||
|
||
## Prerequisites
|
||
|
||
### Medusa Components
|
||
|
||
It's assumed that you already have a Medusa server installed and set up. If not, you can follow our [quickstart guide](../quickstart/quick-start.md) to get started.
|
||
|
||
It is also assumed you already have a storefront set up. It can be a custom storefront or one of Medusa’s storefronts. If you don’t have a storefront set up, you can install either the [Next.js](../starters/nextjs-medusa-starter.md) or [Gatsby](../starters/gatsby-medusa-starter.md) storefronts.
|
||
|
||
### JS Client
|
||
|
||
This guide includes code snippets to send requests to your Medusa server using Medusa’s JS Client and JavaScript’s Fetch API.
|
||
|
||
If you follow the JS Client code blocks, it’s assumed you already have [Medusa’s JS Client installed](../js-client/overview.md) and have [created an instance of the client](../js-client/overview.md#configuration).
|
||
|
||
## Create a Cart
|
||
|
||
You can create a cart with the following code snippet:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.create()
|
||
.then(({ cart }) => {
|
||
localStorage.setItem('cart_id', cart.id);
|
||
//assuming you have a state variable to store the cart
|
||
setCart(cart);
|
||
});
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts`, {
|
||
method: 'POST'
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => {
|
||
localStorage.setItem('cart_id', cart.id);
|
||
//assuming you have a state variable to store the cart
|
||
setCart(cart)
|
||
});
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This request does not require any parameters. It returns the created cart in the response.
|
||
|
||
The cart by default will have a random region assigned to it. You can specify the cart's region by passing in the request's body a `region_id` parameter:
|
||
|
||
Otherwise, you can assign it a specific region during creation:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.create({
|
||
region_id
|
||
})
|
||
.then(({ cart }) => {
|
||
localStorage.setItem('cart_id', cart.id);
|
||
//assuming you have a state variable to store the cart
|
||
setCart(cart);
|
||
});
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts`, {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
},
|
||
body: JSON.stringify({
|
||
region_id
|
||
})
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => {
|
||
localStorage.setItem('cart_id', cart.id);
|
||
//assuming you have a state variable to store the cart
|
||
setCart(cart)
|
||
});
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
Check out the [API Reference](https://docs.medusajs.com/api/store/#tag/Cart/operation/PostCart) for a full list of available request body parameters.
|
||
|
||
:::note
|
||
|
||
The region a cart is associated with determines the currency the cart uses, the tax, payment, and fulfillment providers, and other details and options. So, make sure you use the correct region for a cart.
|
||
|
||
:::
|
||
|
||
## Retrieve a Cart
|
||
|
||
Notice that in the previous code snippets, you set the cart’s ID in the local storage. This is helpful to persist the customer’s cart even when they leave the website and come back later.
|
||
|
||
You can retrieve the cart at any given point using its ID with the following code snippet:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
const id = localStorage.getItem('cart_id');
|
||
|
||
if (id) {
|
||
medusa.carts.retrieve(id)
|
||
.then(({ cart }) => setCart(cart));
|
||
}
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
const id = localStorage.getItem('cart_id');
|
||
|
||
if (id) {
|
||
fetch(`<SERVER_URL>/store/carts/${id}`)
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
}
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This request accepts the ID of the cart as a path parameter and returns the cart of that ID.
|
||
|
||
You can run this code snippet every time the storefront is opened. If a customer has a cart ID stored in their local storage, it’s loaded from the server.
|
||
|
||
:::tip
|
||
|
||
Make sure to remove the ID from the local storage after the customer places an order with this cart.
|
||
|
||
:::
|
||
|
||
## Update a Cart
|
||
|
||
A cart has different data associated with it including the region, email, address, customer, and more.
|
||
|
||
You can use the following snippet to update any of the cart’s data:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.update(cartId, {
|
||
region_id
|
||
})
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts/${cartId}`, {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
},
|
||
body: JSON.stringify({
|
||
region_id
|
||
})
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This request accepts the ID of the cart as a path parameter. In its body, you can pass any data you want to update in the cart such as the region.
|
||
|
||
It returns the updated cart.
|
||
|
||
Check out the full list of available request body parameters in the [API Reference](https://docs.medusajs.com/api/store/#tag/Cart/operation/PostCartsCart).
|
||
|
||
### Associate a Logged-In Customer with the Cart
|
||
|
||
A customer might add items to their cart, then creates an account or log in. In that case, you should ensure that the cart is associated with the logged-in customer moving forward.
|
||
|
||
You can do that using the same update operation:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.update(cartId, {
|
||
customer_id
|
||
})
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts/${cartId}`, {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
},
|
||
body: JSON.stringify({
|
||
customer_id
|
||
})
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This updates the `customer_id` associated with the cart to make sure it belongs to a specific customer.
|
||
|
||
### Associate Guest Customers with a Cart using Email
|
||
|
||
In case the customer doesn't want to use their own account, you must at least associate an email address with the cart before completing the cart and placing the order.
|
||
|
||
You can do that using the same update operation:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.update(cartId, {
|
||
email: 'user@example.com'
|
||
})
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts/${cartId}`, {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
},
|
||
body: JSON.stringify({
|
||
email: 'user@example.com'
|
||
})
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
## Add Line Item to the Cart
|
||
|
||
To create a line item of a product and add it to a cart, you can use the following code snippet:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.lineItems.create(cartId, {
|
||
variant_id,
|
||
quantity: 1
|
||
})
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts/${cartId}/line-items`, {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
},
|
||
body: JSON.stringify({
|
||
variant_id,
|
||
quantity: 1
|
||
})
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This request accepts the ID of the cart as a path parameter. In the body, it's required to send the ID of the product variant you want to add to the cart and its quantity.
|
||
|
||
It returns the updated cart.
|
||
|
||
This adds a new line item to the cart. Line items can be accessed using `cart.items` which is an array that holds all line items in the cart. You can learn more about what properties line items have in the [API reference](/api/store/#tag/Cart/operation/PostCartsCartLineItems).
|
||
|
||
:::note
|
||
|
||
If you’re using Sales Channels, make sure that the cart and the product belong to the same sales channel. You can update the cart’s sales channel by [updating the cart](#update-a-cart).
|
||
|
||
:::
|
||
|
||
## Update Line Item in the Cart
|
||
|
||
To update a line item's quantity in the cart, you can use the following code snippet:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.lineItems.update(cartId, lineItemId, {
|
||
quantity: 3
|
||
})
|
||
.then(({ cart }) => setCart(cart))
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts/${cartId}/line-items/${lineItemId}`, {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
},
|
||
body: JSON.stringify({
|
||
quantity: 3
|
||
})
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This request accepts the ID of the cart and the ID of the line item as path parameters. In the body, it accepts the quantity of the line item.
|
||
|
||
It returns the updated cart.
|
||
|
||
## Delete a Line Item from the Cart
|
||
|
||
To delete a line item from the cart, you can use the following code snippet:
|
||
|
||
<Tabs groupId="request-type">
|
||
<TabItem value="client" label="Medusa JS Client" default>
|
||
|
||
```jsx
|
||
medusa.carts.lineItems.delete(cartId, lineItemId)
|
||
.then(({ cart }) => setCart(cart))
|
||
```
|
||
|
||
</TabItem>
|
||
<TabItem value="fetch" label="Fetch API">
|
||
|
||
```jsx
|
||
fetch(`<SERVER_URL>/store/carts/${cartId}/line-items/${lineItemId}`, {
|
||
method: 'DELETE'
|
||
})
|
||
.then((response) => response.json())
|
||
.then(({ cart }) => setCart(cart));
|
||
```
|
||
|
||
</TabItem>
|
||
</Tabs>
|
||
|
||
This request accepts the ID of the cart and the ID of the line item as path parameters.
|
||
|
||
It returns the updated cart.
|
||
|
||
## What’s Next
|
||
|
||
- Learn [how to implement the checkout flow in your storefront](../advanced/storefront/how-to-implement-checkout-flow.mdx).
|
||
- Learn more about the [JS Client and how to use it](../js-client/overview.md).
|