Appearance
Simple Shopping Cart
Adding a product to a cart and sending them to the checkout page can be a simple one line code that doesnt require any javascript.
Code Example
javascript
<a href="{https://sandbox.123checkout.io}/checkout/{public_cart_hash}?add_products={public_product_hash}">Buy Now</a>
Basic usage
Include and initialize
This will need to be put inside the HEAD tags on your website.
TIP
TIP: Make sure to replace https://sandbox.123checkout.io with Also make sure to replace ENV_https://sandbox.123checkout.io with for sandbox and for production.
TIP
TIP: Replace CartID_GOES_HERE with the cartID value provided from the merchant control panel. This can be found in Shopping - Carts and clicking the </> icon.
TIP
TIP: Replace all three "example.com/" placeholders with your respective urls.
html
<script src="https://sandbox.123checkout.io/cart/cart.js"></script>
<script>
var cart = new Cart({
// The fields below are required
cartID: '55e8cb7a-2d50-2235-a546-166e8bcp1569', // This is your card id from the control panel
checkout_url: 'ENV_https://sandbox.123checkout.io', // This is the environment you are wishing to hit, sandbox.<domain> or app.<domain>
cancel_url: 'http://example.com/cancel', // This is the url you wish to redirect your customers to when they cancel a checkout
success_url: 'http://example.com/success', // This is the url you wish to redirect your customers to when they complete a successful checkout
})
</script>
Add product buttons
There are two types of buttons you can use on your website. One will add the item to your cart and keep the user on your website, until they click a checkout button. The other will add the item to your cart as well as redirect the user to the hosted checkout page. This script is normally placed in the BODY tags of your website.
TIP
Replace ‘ProductID_GOES_HERE’ with the Product ID value provided from the merchant control panel. This can be found in Shopping - Products and clicking the </> icon of the respective product.
Add product and keep user on page:
html
<button onclick="cart.addProduct(‘ProductID_GOES_HERE’)"
>Add to Cart</button>
Add product and directly checkout:
html
<button onclick="cart.addProductCheckout(‘ProductID_GOES_HERE’)"
>Add to Cart</button>
NOTE: As is, with no quantity parameter, it defaults to 1.
Add checkout button
html
<button onclick="cart.checkout()">Checkout</button>
Advanced usage
Donation Example
The Donation function offers the user the flexibility to pay any amount desired. One situation where this could be helpful is a place to pay tips.
html
<html>
<head>
<script src="https://sandbox.123checkout.io/cart/cart.js"></script>
<script>
var cart = new Cart({
// The fields below are required
cartID: '55e8cb7a-2d50-2235-a546-166e8bcp1569', // This is your card id from the control panel
checkout_url: 'ENV_https://sandbox.123checkout.io', // This is the environment you are wishing to hit, sandbox.<domain> or app.<domain>
cancel_url: 'http://example.com/cancel', // This is the url you wish to redirect your customers to when they cancel a checkout
success_url: 'http://example.com/success', // This is the url you wish to redirect your customers to when they complete a successful checkout
})
function addDonation() {
var price = document.getElementById('price').value
cart.addProductCheckout('product_id', 1, price) // remember to replace product_id with the product id from the control panel
}
</script>
</head>
<body>
<input id="price" type="number" value="0" />
<button onclick="addDonation()">Add to Cart</button>
</body>
</html>
TIP
TIP: The number field processes the amount in cents. Example: 1299 = $12.99
Products
By adding : after the product hash, you can add a quantity and amount to the product. This helps for products that dont have fixed qty and/or fixed amount. Amount format contains a dot for decimals.
javascript
<a href="{https://sandbox.123checkout.io}/checkout/{public_cart_hash}?add_products={public_product_hash}:{quantity}:{amount}">Buy Now</a>
Hosted Shopping Cart
The purpose of the Cart API is to provide a javascript implementation that gives you an easy way to add products to your website and a simple checkout page.
Custom Fields
With this feature, you are able to pre populate any of your custom fields with any value passed in the link. You do this by simply adding a custom_field variable to the link string as follows:
html
<a href="https://{url goes here}/checkout/{cart id goes here}?custom_fields={custom field id}:{custom field value}">Checkout Now</a>
Methods/Options
onChange
onChange will trigger when products are added or removed from your cart. Two values will be returned:
- available_products - products that belong to the cart you have created in your control panel
- cart_products - products that the user has added to their cart totals - breakdown of subtotal, tax and total amounts
javascript
var cart = new Cart({
onChange: (data) => {
var available_products = data.available_products
var cart_products = data.cart_products
var totals = data.totals
}
})
onError
onError will trigger when the package comes across considerable errors.
javascript
var cart = new Cart({
onError: (err) => {
alert(err)
}
})
getProductByID
Will return back an object of the product information.
TIP
TIP: Remember to replace ‘ProductID_GOES_HERE’ with the Product ID value.
javascript
cart.getProductByID('ProductID_GOES_HERE')
getCartProducts
Will return back the current list of available products to purchase for a given cart.
javascript
cart.getCartProducts()
addProduct
Will add a specific product to a users cart.
TIP
TIP: For AddProduct and AddProductCheckout, qty and price are optional. However if qty is omitted it defaults to 1. If price is omitted it defaults to whatever is configured in your dashboard.
TIP
TIP: Remember to replace ‘ProductID_GOES_HERE’ with the Product ID value.
javascript
cart.addProduct('ProductID_GOES_HERE', qty, price)
addProductCheckout
Will add a specific product to a users cart and start the checkout.
TIP
TIP: Remember to replace ‘ProductID_GOES_HERE’ with the Product ID value.
javascript
cart.addProductCheckout('ProductID_GOES_HERE', qty, price)
removeProduct
Will remove a specific product from a users cart.
TIP
TIP: Remember to replace ‘ProductID_GOES_HERE’ with the Product ID value.
javascript
cart.removeProduct('ProductID_GOES_HERE')