Skip to main content

Checkout

The below process describes the key milestones in the checkout process flow in Reachu. There are also additional steps that may occur along the way; however, the purpose of this instruction is to deliver a base reference for the user to work with.

StepDescription
Checkout InitiationOnce the final customer is ready to initiate the order, an object with the cart data is needed for the checkout process. You can still update the cart at this time.
Shipping MethodsThe way orders will be sent. E.g. postal service, click & collect.
Payment MethodA payment provider. E.g., Stripe, Klarna.
PaymentThis object contains status and additional data about payment. Payments are processed by third parties.
Checkout CompletionOnce the payment succeeds, the checkout is finished.

Initiate the checkout

Retrieve an array of the products added to your channel.

async function createCheckout(CART_ID) => {
const sdk = getSDK();
const checkout = await sdk.shopCart.checkout.create({
cart_id: CART_ID,
});
return checkout;
};

Response:

{
"createdAt": "2023-06-20T08:18:04.973Z",
"updatedAt": "2023-06-20T08:18:04.973Z",
"id": "7a1c1397-9508-47f2-8b90-ef9143a0bab3",
"deletedAt": null,
"success_url": null,
"cancel_url": null,
"payment_method": null,
"email": null,
"status": "ACTIVE",
"checkout_url": null,
"origin_payment_id": null,
"total_price": "1744.65",
"total_tax": "436.16",
"total_line_items_price": 1745,
"cart": {
"cart_id": "b0efb6fc-ab58-4f99-8a3d-eb318c40fa82",
"customer_session_id": "549743",
"shippingCountry": "NO",
"line_items": [
{
"id": "21ad179e-579e-4dba-a1ad-e2339013b1ce",
"supplier": "iqplustest",
"product_available_shippings": [
{
"id": "e42e32d5-3b76-41ac-b95f-2e6655d2af76",
"name": "Standard",
"description": "Standard shipping",
"countryCode": "NO",
"price": {
"amount": 290.77,
"currencyCode": "NOK"
}
}
],
"product_id": 6182,
"product_title": "Lacoste T-Shirt",
"product_image": [
{
"id": 19513,
"url": "https://reachu-uploads-qa.s3.eu-central-1.amazonaws.com/product-images/6182-5ea12d76-79c4-4861-99d9-10867add85e4.jpeg",
"width": 762,
"height": 1100
},
{
"id": 19514,
"url": "https://reachu-uploads-qa.s3.eu-central-1.amazonaws.com/product-images/6182-826631da-f077-424a-8ff8-140d4829513b.jpeg",
"width": 762,
"height": 1016
}
],
"variant_id": 11693,
"variant_title": "M",
"variant": [
{
"option": "size",
"value": "M"
}
],
"quantity": 1,
"price_data": {
"unit_price": 1744.65,
"tax": 25,
"currency": "NOK"
},
"shipping": null
}
],
"total_amount": 1744.65,
"currency": "NOK",
"available_shipping_countries": ["NO"]
},
"billing_address": null,
"shipping_address": null,
"total_amount_shipping": 0,
"availablePaymentMethods": [
{
"name": "Stripe"
},
{
"name": "Klarna"
}
]
}

Payment Methods

When you initiate the checkout, you will get the available payment methods in the response as part of the checkout object. You can still get them separately by using the method below.

async function getPaymentMethods() => {
const sdk = getSDK();
const paymentMethods = await sdk.shopCart.paymentMethod.getAllByUser();
return paymentMethods;
};
{
"availablePaymentMethods": [
{
"name": "Stripe"
},
{
"name": "Klarna"
}
]
}

Interacting with a created checkout

Update the checkout

After creation, you can update the following information from the checkout:

  • billing_address
  • shipping_address
  • after payment redirect urls
    • return_url
    • success_url
    • cancel_url
async function updateCheckout(CHECKOUT_ID) => {
const sdk = getSDK();
const body = {
shipping_address: {
first_name: "John",
last_name: "Johnson",
email: "johnjohnson@example.com",
address1: "Address 1",
city: "Oslo",
country: "Norway",
zip: "0672"
}
};
const checkout = await sdk.checkout.update({
checkout_id: CHECKOUT_ID,
...body
});
return checkout;
};

Get the checkout

async function getCheckout(CHECKOUT_ID) => {
const sdk = getSDK();
const checkout = await sdk.checkout.getById({ checkout_id:CHECKOUT_ID });
return checkout;
};

Delete a checkout

async function getCheckout(CHECKOUT_ID) => {
const sdk = getSDK();
const checkout = await sdk.shopCart.checkout.delete(CHECKOUT_ID);
return checkout;
};