Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mrvautin/react-shoppingcart
A React Context provider for quickly and easily building a shopping cart using Next.js or any other React framework.
https://github.com/mrvautin/react-shoppingcart
component nextjs reactjs shopping-cart
Last synced: 3 months ago
JSON representation
A React Context provider for quickly and easily building a shopping cart using Next.js or any other React framework.
- Host: GitHub
- URL: https://github.com/mrvautin/react-shoppingcart
- Owner: mrvautin
- License: apache-2.0
- Created: 2024-01-11T07:38:44.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-01-20T01:09:05.000Z (12 months ago)
- Last Synced: 2024-09-23T13:46:19.236Z (3 months ago)
- Topics: component, nextjs, reactjs, shopping-cart
- Language: TypeScript
- Homepage: https://codesandbox.io/p/sandbox/react-shoppingcart-9cs3mm
- Size: 433 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
react-shoppingcart
A React Context provider for quickly and easily building a shopping cart using Next.js or any other React framework.- Persistent local storage using React Context
- Works with Next, Gatsby, React
- Supports hooks to listen for events
- Written in Typescript
- Supports discount codes
- Supports shipping costs
- Supports product variants - Size, colour etc
- Supports cart metadata#### View [Demo](https://codesandbox.io/p/sandbox/react-shoppingcart-9cs3mm?file=%2Fsrc%2Findex.tsx).
## Install
`npm`:
```bash
npm install @mrvautin/react-shoppingcart --save
````yarn`:
```bash
yarn add @mrvautin/react-shoppingcart
```# Getting started
## Add the `Context`
Wrap your app in the `` (eg: Add to your `_app.tsx`):
``` js
import type { AppProps } from 'next/app';
import { CartProvider } from '@mrvautin/react-shoppingcart';export default function App({ Component, pageProps }: AppProps) {
return (
);
}
```| Prop | Required | Description |
| ------------------- | -------- | --------------------------------------------------------------------------------------------- |
| `cartId` | _No_ | `cartId` for your cart storage. If nothing is supplied, `react-shoppingcart` is used. |
| `onItemAdd` | _No_ | Triggered an item is added to your cart using `addItem`. |
| `onItemUpdate` | _No_ | Triggered when items are updated in your cart using `updateItemQuantity()`. |
| `onItemRemove` | _No_ | Triggered on items are removed from your cart using `removeItem()`. |
| `onDiscountAdd` | _No_ | Triggered when a discount is added using `addDiscount()`. |
| `onDiscountRemove` | _No_ | Triggered when a discount is removed using `removeDiscount()`. |
| `onShippingAdd` | _No_ | Triggered when a shipping is added using `addShipping()`. |
| `onShippingRemove` | _No_ | Triggered when a shipping is removed using `removeShipping()`. |
| `onEmptyCart` | _No_ | Triggered on `emptyCart()` is called. |
| `onMetadataUpdate` | _No_ | Triggered when `metadata` is changed in your cart using `setMetadata()` or `clearMetadata()`. |
| `currency ` | _No_ | Used to set the `currency` formatting of the discount. Defaults to `USD`. |
| `locale ` | _No_ | Used to set the `locale` formatting of the discount. Defaults to `en-US`. |### Listening to a hook
You may want to use hooks to check your backend server for things like:
- A `discount` code is valid and not expired
- The `price` of an item is correct
- The `cartTotal` matches your expected value in databaseAvailable Hooks are: `onItemAdd`, `onItemUpdate`, `onItemRemove`, `onDiscountAdd`, `onDiscountRemove`, `onShippingAdd`, `onShippingRemove`, `onEmptyCart` and `onMetadataUpdate`.
On the `` you can add any hooks you need to listen on:
``` js
import type { AppProps } from 'next/app';
import { CartProvider } from '@mrvautin/react-shoppingcart';export default function App({ Component, pageProps }: AppProps) {
return (
alert(cart)}>
{children}
);
}
```> Keeping in mind that any cart values can be altered by the user by changing their `localstorage`.
## Add to your `Component`
``` js
import { useCart } from '@mrvautin/react-shoppingcart';
...
const {
items,
addItem,
removeItem,
getItem,
updateItemQuantity,
addDiscount,
removeDiscount,
setMetadata,
clearMetadata,
metadata,
totalShippingAmount,
totalDiscountAmount,
totalItemsAmount,
discount,
cartDiscountText,
totalNumberItems
totalUniqueItems,
cartTotal,
cartNetTotal,
emptyCart,
} = useCart();
```# Usage
## addItem
The first argument is a product object to add to the cart. Minimum values required are:
| Prop | Required | Description |
| ------------------- | --------- | --------------------------------------------------------------------------------------------- |
| `id` | _Yes_ | `id` for the item being added to the cart |
| `name` | _Yes_ | `name` for the items. |
| `price ` | _Yes_ | `price` formatted in whole number. Eg: `$10.00` would be `1000`. |The second arguement is an option `quantity`. If not supplied, `1` is added by default.
``` js
const product = {
id: 'shoes1',
name: 'Running shoes',
price: 1000,
}
addItem(product)}
/>// Adding 5 items
addItem(product, 5)}
/>
```> Note: If the exact same item (eg: Same `id` and `itemVariants` - if supplied) is added twice, the quantity for the item is increased by `1`.
## removeItem
Used to remove an item from the cart.
``` js
const product = {
id: 'shoes1',
name: 'Running shoes',
price: 1000,
}
addItem(product)}
/>// Adding 5 items
addItem(product, 5)}
/>
```> Note: If using `itemVariants`, you will need to supply the same `id` amd `itemVariants`.
## getItem
Used to get an item which has been already added to the cart.
``` js
const product = {
id: 'shoes1',
name: 'Running shoes',
price: 1000,
}
getItem(product)}
/>
```> Note: If using `itemVariants`, you will need to supply the same `id` amd `itemVariants`.
## items
`items` is an array property which stores a list of `items` in the cart.
``` js
// You can loop the items
Cart
{items.map((item) => (
Name: {item.name} - Quantity: {item.quantity}
))}
```## itemVariants
``` js
const product = {
id: 'shoes1',
name: 'Running shoes',
price: 1000,
itemVariants: [
{
size: 'US11'
},
{
color: 'white'
}
],
}
addItem(product)}
>
```> Note this function allows for a single product ID to be used per product but multiple variations to it. For instance, you may have a single product with an ID of `shoes1` but it may have an `itemVariants` of `size` of `US11` in the example above. This allows the same product to be added to the cart multiple times despite having a different variant set.
## updateItemQuantity
Used to update the quantity of an item already in the cart.
``` js
const product = {
id: 'shoes1',
name: 'Running shoes',
price: 1000,
itemVariants: [
{
size: 'US11'
},
{
color: 'white'
}
],
}
updateItemQuantity(product, 'increase', 2)}
>
```## removeItem
Used to remove an item already in the cart.
``` js
const product = {
id: 'shoes1',
name: 'Running shoes',
price: 1000,
itemVariants: [
{
size: 'US11'
},
{
color: 'white'
}
],
}
removeItem(product)}
>
```> Note: If using `itemVariants` ensure the same `id` and `itemVariants` are supplied in the `removeItem()` call.
## discount
`discount` returns an object if a discount is applied else it returns an empty object `{}`.
## addDiscount
Used to add a `discount` to the cart. You will want to ensure this discount is allowed and valid on your backend. You can do this by listening on the `onDiscountAdd` event to validate and remove if required.
| Prop | Required | Description |
| ------------------- | --------- | ---------------------------------------------------------------------------------------------- |
| `id` | _Yes_ | `id` for the discount |
| `code` | _Yes_ | `code` for the discount being added. This would be what is advised to the customer and entered at checkout. |
| `type ` | _Yes_ | `type` of discount. Allowed values are: `amount` and `percent`. |
| `value ` | _Yes_ | `value` to be discounted in whole number. Eg: `1000` is `$10.00` discount or `10%` depending on type. |``` js
const discount = {
id: 'discount1',
code: 'AMOUNT_DISCOUNT',
type: 'amount',
value: 2000,
}
addDiscount(discount)}
>
```## removeDiscount
Used to remove a `discount` from the cart.
``` js
const discount = {
id: 'discount1',
code: 'AMOUNT_DISCOUNT',
type: 'amount',
value: 2000,
}
removeDiscount()}
>
```## shipping
`shipping` returns an object if shipping is applied else it returns an empty object `{}`.
## addShipping
Used to add `shipping` to the cart. You will want to ensure this shipping is allowed and valid on your backend. You can do this by listening on the `onShippingAdd` or `onShippingRemove` event to validate and remove if required.
| Prop | Required | Description |
| ------------------- | --------- | ---------------------------------------------------------------------------------------------- |
| `description` | _Yes_ | `description` for the discount being added. This would be what is advised to the customer and entered at checkout. |
| `costs` | _Yes_ | Shipping `costs` to be adding as a whole number. Eg: `1000` is `$10.00` |``` js
const shipping = {
description: 'Flat rate shipping',
costs: 1000,
}
addShipping(shipping)}
>
```## removeShipping
Used to remove `shipping` from the cart.
``` js
const shipping = {
description: 'Flat rate shipping',
costs: 1000,
}
removeShipping()}
>
```## emptyCart
Used to completely empty the cart including `items`, `discounts` and `metadata`.
``` js
emptyCart()}
>
```## setMetadata
Used to add `metadata` to the cart. This could be used to store an order ID, customer ID or notes about shipping etc.
``` js
const metadata = {
customerId: '1234',
notes: 'Leave on door step',
};
setMetadata(metadata)}
>
```## clearMetadata
Used to clear whetever `metadata` is currently set on the cart.
``` js
clearMetadata()}
>
```## metadata
Returns whatever `metadata` is currently set on the cart.
## totalNumberItems
Returns the total number of items in the cart. This adds the quantity of all items in the cart to give a total number of items being purchased.
## totalUniqueItems
Returns the total unique items in the cart. This ignores the quantity and simply counts all unique products in the cart.
## totalShippingAmount
This value is `0` by default. If shipping is added, the total shipping is caluculated and stored in this value.
## totalDiscountAmount
This value is `0` by default. If a discount is added, the total discount is caluculated and stored in this value. Eg: If the discount is a percent, this value will store the total discounted `$` based on the set `%`.
## cartDiscountText
This value stores a nice discount value which can be displayed on the cart. Eg: If the discount is set to $20.00 then the text will be: `$20.00 off`. Depending on the `currency` and `locale` set, this same text in `Euro` will be: `20,00 € off`.
## totalItemsAmount
This value stores the total amount of just the items. This is a total of the item price * the item quantity.
## cartNetTotal
This value stores the net total taking into account any discounts. Eg: This value is: `cartTotal` - `totalDiscountAmount` = `cartNetTotal`.
## cartTotal
Returns the total value in the cart including `totalDiscountAmount` and `totalShippingAmount`. Essentially it's `totalItemsAmount` - `totalDiscountAmount` + `totalShippingAmount` = `cartTotal`. The value is in whole number. Eg: `1000` is `$10.00`.
# Example
An example `Next.js` project is stored in `/example`. You can see the basics of using the component in this example project.
1. Enter directory: `cd example`
2. Install: `yarn install`
3. Start up Next.js: `yarn run dev`
4. Visit the example: `http://localhost:3000`# Tests
Running tests with:
`yarn run test`