Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Info

This page is under construction.

Option 1 - complex link

Option 1 is applicable whenever using code-level logic to generate link is possible, for example vendor’s own backend is sending out an order confirmation email and is capable of generating this link. Gives most control.

  1. There needs to be a mapping stored between particular store and our ‘queue ID’ on ecom side in order to be able to create correct link.  Queue id (in form of string) will be provided by us for each location you want to enable the pickup functionality at.

  2. Create schedule pickup link:

    1. Constructing the link:

  i.      URL: This documentation outlines two options for integrating Order Pickup functionality into e-commerce platforms, enabling a seamless transition from online ordering to curbside pickup. Depending on the level of customization and control available on the e-commerce platform, vendors can choose between a simple link method and a more complex, code-driven link generation approach.

Option 1: Simple Link Integration

Simple link integration is ideal for scenarios where adding code-level logic is not feasible, such as platforms like Shopify that offer limited customization capabilities.

Steps for Integration:

  1. Queue ID Mapping: Ensure there is a mapping stored on the e-commerce side between each store and our provided ‘queue ID’. This ID is essential for generating the correct pickup links.

  2. Creating the Schedule Pickup Link:

    • URL Schema: https://queue.{dataResidency}.ombori.com/{organization}/queues/{queueId}/book/curbside-pickup?orderId={orderId}&pickupDuration={numberOfDays}&note={note}

    • Query String Parameters:

      • orderId: Required. A string containing the order identifier.

        • Can beused as a unique identifier to retrieve an existing ticket using get position endpoint, helping avoid double bookings.

      • pickupDuration: Specifies how many days in the future a pickup can be booked. Used to calculate the maximum pickup date.

      • note: Optional. Additional information for operational use.

Option 2: Complex Link Integration

Complex link integration provides more control and is suitable for vendors who can incorporate code-level logic into their systems, such as generating links directly from their backend systems.

Steps for Integration:

  1. Queue ID Mapping: Similar to Option 1, ensure there is a correct mapping between each store and the provided ‘queue ID’.

  2. Constructing the Schedule Pickup Link:

    • Base URL: https://queue.{

...

    • dataResidency}.ombori.com/{organization}/queues/{queueId}/book/curbside-pickup?options={options}

  ii.      Query string parameters

options – JSON stringified configuration object, encoded Base64, that contains following fields:

...

orderId – string containing order identifier (required)

...

minDate – earliest pickup date in form of UTC timestamp (seconds, required)

...

maxDate – latest pickup date in form of UTC timestamp (seconds, required)

    • Query String Parameters:

      • options: A Base64-encoded JSON string containing:

        • orderId: Required. The order identifier.

        • minDate: Required. The earliest pickup date as a UTC timestamp.

        • maxDate: Required. The latest pickup date as a UTC timestamp.

        • phoneNumber: Optional. The customer’s phone number in E.164 format

...

        • .

        • note

...

        • : Required. Extra information (up to 500 characters) such as an order summary

...

JavaScript code example: https://codesandbox.io/s/boring-rubin-briq0?file=/src/index.js

Option 2 - simple link

Option 2 is applicable whenever adding code-level logic is not possible, for example when vendor is using an ecom platform (like Shopify) that gives you limited control over the contents of your email

...

There needs to be a mapping stored between particular store and our ‘queue ID’ on ecom side in order to be able to create correct link.  Queue id (in form of string) will be provided by us for each location you want to enable the pickup functionality at.

Create schedule pickup link:

...

        • .

Example of Complex Link Generation:

Here's how you might generate a complex link using JavaScript:

Code Block
// Creating curbside link link
const data = {
  earliestPickup: "2021-07-14T08:40:24.806Z", // earliest pickup date, as ISO string for example purposes
  latestPickup: "2022-07-14T08:40:24.806Z", // latest pickup date, as ISO string for example purposes
  orderId: `XYZ${Math.floor(Math.random() * 100)}`, // internal order identifier
  phoneNumber: "+46000000", // customer phone number
  note: "hello" // optional note to be presented for the staff
};
const curbsideServiceUrlBase = "https://queue.eu.ombori.com"; // base url for link generation, found in Console or provided by Ombori team, depends on data residency
const queueId = "7a37b7e8-4689-4982-8216-262c5e1f1989"; // queue id, found in console
const organization = "aneards"; // organization id, found in console

const { earliestPickup, latestPickup, orderId, phoneNumber, note } = data;

const minDate = Math.floor(new Date(earliestPickup).getTime() / 1000); // utc timestamp in seconds
const maxDate = Math.floor(new Date(latestPickup).getTime() / 1000); // utc timestamp in seconds

const linkOptions = { minDate, maxDate, orderId, phoneNumber, note };
const urlBase = `${curbsideServiceUrlBase}/${organization}/queues/${queueId}/book/curbside-

...

Query string parameters:

  1. orderId – string containing order identifier (required)

  2. pickupDuration - how many days in the future can pickup be booked at, used for getting maximum pickup date (maximum pickup date = today + pickupDuration)

  3. note

General notes:

...

pickup`;
const linkUrl = `${urlBase}?options=${btoa(JSON.stringify(linkOptions))}`;

const a = document.createElement("a");
const link = document.createTextNode(`Book your pickup: ${linkUrl}`);
a.appendChild(link);
a.href = linkUrl;
document.body.appendChild(a);

console.log(linkUrl);