Documentation
Products
Products are the core items you sell - like meals and drinks - and are displayed to customers on your online ordering storefront.
Each product can have:
- Variants - sizes or types (Small, Large, Chicken, Beef)
- Customisations - extra choices or add-ons (Dips, Add Cheese, Pineapple)
- Allergens - so customers can see allergen information
- Attributes - options labels (Vegan, Halal)
Products can be Simple (one version with one price) or Variable (multiple versions, each with its own price and options).
How Products Connect to Other Features
Products interact with several parts of the application:
| Object | How it relates to Products |
| ------------------ | ----------------------------------------------------------------------------------- |
| **Categories** | Used to group and display products (e.g. _Drinks_, _Pizzas_) |
| **Variants** | Define different versions of a product with unique pricing and SKUs |
| **Customisations** | Linked options that can be added (e.g. _Extra Cheese_) |
| **Allergens** | Attached to help inform customers of ingredients |
| **Deals** | Products may be included in promotional rules |
| **Menus** | Products are shown on location-specific menus |
| **Cart & Orders** | Customers add products (and their variants/customisations) to the cart and checkout |
Simple vs Variable Products
When creating a product, you’ll choose between two **types**:
🟢 Simple Product
Use this when there’s only **one version** of the product with a single price.
- ✅ One price
- ✅ One set of customisations
- ✅ Easier to manage
**Example:**
_Can of Coke – £1.50_
---
### 🟣 Variable Product
Use this when the product has **multiple versions**, like sizes or styles, each with its own price.
- 🔄 Each variant can have different:
- Price
- Cost
- SKU
- Barcode
- Customisations
- 📊 Great for tracking stock or price differences per size
**Example:**
_Pizza_
- Small – £6.99
- Medium – £8.99
- Large – £10.99
### 💡 Which One Should I Choose?
| Use When… | Product Type |
| -------------------------------- | ------------ |
| Just one option | Simple |
| You sell different sizes/types | Variable |
| Each version needs its own price | Variable |
## What are Product Variants?
**Variants** let you offer multiple versions of the same product — each with its own **name**, **price**, **cost**, **SKU**, and **barcode**.
### Examples
| Product | Variant 1 | Variant 2 | Variant 3 |
| ---------------- | ------------- | -------------- | -------------- |
| Margherita Pizza | Small (£6.99) | Medium (£8.99) | Large (£10.99) |
| Chicken Wings | 6 Pieces | 12 Pieces | 18 Pieces |
| Soft Drink | Can (330ml) | Bottle (500ml) | Large Bottle |
### Notes
- You only use variants if your product has **different sizes, prices, or packaging**.
- Each variant can have its own **customisations** (e.g. Large Pizza → Add Extra Cheese).
- Variants are only available if the product is set to **Type: Variable**.
## What are Product Customisations?
**Customisations** allow your customers to personalise a product by choosing from extra options — like sauces, sides, or toppings.
They can be:
- **Optional** (e.g. _Add Cheese_, _Choose Sauce_)
- **Required** (e.g. _Pick a spice level_)
- **Single or multiple choice**
### Examples
| Customisation Name | Options | Selection Type |
| ------------------ | ------------------------ | -------------- |
| Sauce | Garlic, BBQ, Sweet Chili | Single choice |
| Extras | Cheese, Jalapeños, Bacon | Multi-select |
| Spice Level | Mild, Medium, Hot | Required |
### Where They Apply
Customisations can be linked at:
- **Product Level**: Applies to all variants (e.g. “Add Dip”)
- **Variant Level**: Unique choices and prices a specific variant (e.g. only _Large Pizza_ has “Large Pizza Toppings”)
Customers will see these options when they click on the product in your online menu.
## What are Allergens?
Allergens help inform customers about ingredients that could cause allergic reactions. This is especially important for compliance with food safety regulations and customer trust.
### How It Works
- You assign allergens **to each product** based on its ingredients.
- These allergens are then displayed to customers when they view the product online.
- Customers can **filter or check allergen information** while browsing your menu.
- Allergens can be disabled under Business Settings / Features.
### Common Examples
| Allergen Name | Used When Product Contains… |
| ------------- | ----------------------------- |
| Gluten | Bread, dough, flour |
| Milk | Cheese, butter, cream |
| Nuts | Pesto, desserts, nut toppings |
| Eggs | Mayo, cakes, egg wash |
| Soy | Soy sauce, tofu |
| Fish | Anchovies, fish sauce |
## Field-by-Field Guide
### 🧱 Basic Information
| Field | Required | Description |
| --------------- | ---------- | ------------------------------------------------------------------------------------- |
| **Name** | ✅ Yes | The product name shown to customers (e.g. _Beef Burger_) |
| **Category** | ✅ Yes | Helps organise products into menus like _Burgers_, _Drinks_, _Sides_ |
| **Tax Group** | ⚠ Optional | Select the applicable tax group (e.g. VAT, Zero-rated). Helps with receipts/reporting |
| **Description** | Optional | Extra info like ingredients, spice level, or portion size |
### 💰 Pricing & Details
|Field|Required|Description|
|---|---|---|
|**Type**|✅ Yes|Choose **Simple** or **Variable** (see above section)|
|**Price**|✅ Yes for Simple|The selling price (e.g. £9.95)|
|**Cost**|Optional|Your internal cost. Used for profit reports (not shown to customers)|
|**SKU**|Optional|Internal stock code|
|**Barcode**|Optional|Can be scanned at point-of-sale (POS)|
|**Weight**|Optional|Used for weight-based delivery or tracking|
|**Weight Unit**|Optional|g, kg, oz, lb, etc.|
### 🟢 Status Toggles
| Toggle | Description |
| ------------ | -------------------------------------------------------------------------- |
| **Active** | If off, product is hidden from customers |
| **Featured** | If on, product appear in highlighted sections (e.g. homepage or top picks) |
### 🖼️ Product Image
Upload an image to visually represent the product. You can drag and drop or click to browse.
> 📝 **Best practices:**
>
> - Use square images (1:1)
> - Keep file size under 1MB for performance
> - Show the finished product clearly
## 🛠️ Step-by-Step: Create a Product
### ✅ Step 1: Go to Products
- From the left-hand menu, click **“Products”**
- Click the **“Create”** button in the top-right
---
### 🧱 Step 2: Fill Basic Information
- **Name** – e.g. _Chicken Burger_
- **Category** – Choose a group like _Burgers_ or _Mains_
- **Tax Group** – Select VAT or tax-free option
- (Optional) Add a **description** like _Grilled chicken breast in a brioche bun_
---
### 🔀 Step 3: Choose Type – Simple or Variable
- **Simple** – One fixed price
- **Variable** – Add different sizes, styles, etc.
---
### 💰 Step 4: Set Pricing and Details
#### For Simple Products:
- Add **Price** and (optional) **Cost**
- Optionally fill in **SKU**, **Barcode**, and **Weight**
#### For Variable Products:
- Click **Add Variant**
- For each variant:
- Fill **Name**, **Price**, and other details
- Assign variant-specific **customisations** if needed
---
### 🧂 Step 5: Add Customisations (Optional)
- Scroll to **Base Customisations**
- Select customisation groups (like _Add Dip_, _Choose Sauce_)
- These apply to all variants (if applicable)
---
### ⚠️ Step 6: Add Allergens
- Tick any relevant allergens (e.g. _Milk_, _Eggs_, _Gluten_)
- This helps customers with dietary needs
---
### 🖼️ Step 7: Upload Product Image
- Click or drag to upload a photo of the product
- Recommended: square image, <1MB
---
### ✅ Step 8: Set Status
- **Active** – Must be ON for product to show on menu
- **Featured** – Optional; highlights it in some views
---
### 💾 Step 9: Save
- Click **“Create”** to save the product
- You’ll be taken to the product’s detail view to review or edit
## 🧩 Managing Product Variants
If your product is set to **Type: Variable**, you’ll see the **Variants** section when creating or editing a product.
Each variant is like a “sub-product” with its own price, details, and customisations.
### ➕ Adding a Variant
1. **Click “Add Variant”**
2. Fill in the variant-specific fields:
|Field|Required|Description|
|---|---|---|
|**Name**|✅ Yes|What the customer sees (e.g. _Small_, _Medium_, _Large_)|
|**Price**|✅ Yes|Selling price for this variant|
|**Cost**|Optional|Internal cost for this variant|
|**SKU**|Optional|Optional product code|
|**Barcode**|Optional|Barcode for scanning (e.g. POS)|
|**Weight** + **Unit**|Optional|If you charge based on weight, or for label printing|
### 🎛 Variant-Specific Customisations
You can assign customisations that **only apply to this variant**.
For example:
- Large Pizza → Stuffed Crust (only on large size)
- Spicy Wings → Choose Dip
These are selected from existing customisation groups.
### ✏️ Editing or Deleting a Variant
- **Edit**: Click the pencil icon next to the variant.
- **Delete**: Click the trash icon — the variant will be removed after saving.
> 📝 Tip: You must have **at least one variant** if the product is variable.