Prerequisites
Before connecting Zonal, ensure you have:- Zonal Aztec POS with iOrder API access
- iOrder Brand Token from your Zonal account manager
- iOrder User Device Identifier
- Admin access to your storekit dashboard
Contact your Zonal account manager to request iOrder API credentials. You’ll need the Brand Token and User Device Identifier to connect.
Setting Up the Connection
Step 1: Enter Zonal Credentials
- Go to Store Settings > Integrations in your storekit dashboard
- Find Zonal and click Connect
- Enter your iOrder credentials:
- Brand Token - Your iOrder brand authentication token
- User Device Identifier - Your unique device identifier
- Bundle Identifier (optional) - Custom bundle ID if provided
- Click Connect
authCheck endpoint before saving.
Step 2: Select Your Venue
After authentication:- storekit fetches available venues from your Zonal account
- Select the venue (site) that matches this storekit store
- The venue’s Site ID is saved for all future API calls
Step 3: Sync Your Menu
Once connected, import your menu from Zonal:- Go to Menu in your dashboard
- Click Sync Menu
- storekit fetches menus from all sales areas
- Categories and products are imported with full modifier structure
Menu Sync
What Gets Synced
| Data | Synced |
|---|---|
| Categories | Yes (from display groups) |
| Products | Yes |
| Prices | Yes (including portion prices) |
| Descriptions | Yes (from display records) |
| Images | Yes (uploaded to CDN) |
| Modifiers (Choice Groups) | Yes |
| Nested Modifiers | Yes |
| Size/Portion Variants | Yes (as modifier group) |
| Courses | Yes (optional, as modifier) |
| Allergens | Alcohol flag only |
| Calories | Yes |
| Availability | Yes (out of stock status) |
Sync Types
Full Sync: Imports the complete menu structure including categories, products, modifiers, and images. Use after significant menu changes. Lightweight Sync: Updates only prices and availability without re-importing the full structure. Much faster - ideal for frequent price changes or stock updates.Sync Options
| Setting | Description |
|---|---|
| Enable Coursing | Import course options as a modifier group on applicable products |
| Enable Category Merge | Combine categories with the same name from different sales areas |
| Subscreens as Categories | Treat Zonal subscreens as separate top-level categories |
| Import Choices With No Price | Include modifier options that have no supplement price |
Sales Area Restrictions
Zonal menus are organised by sales areas. During sync, storekit:- Fetches menus from all sales areas
- Merges identical menus across areas
- Creates category-level area restrictions
Portions (Sizes)
When a product has multiple portions in Zonal, storekit creates a “Size” modifier group:- Base product price is set to £0
- Each portion becomes a modifier with its price
- Customers must select a size to add the item
Order Injection
When a customer places an order, storekit sends it to Zonal via theplacePaidOrder method.
Order Flow
- Basket validation - storekit calls
checkBasketto validate items - Payment processed - Customer pays via storekit
- Order dispatched - Order sent to Zonal with basket ID
- Confirmation - Zonal returns receipt ID, order marked accepted
Service Types
| Fulfillment | Zonal Service ID | Notes |
|---|---|---|
| Dine-in | 1 | Includes table number |
| Pickup | 2 | Includes timeslot and collection code |
| Delivery | 5 | Includes delivery address and timeslot |
Pre-Order Dispatch
For pre-orders, storekit calculates the optimal dispatch time:- Same-day orders: Dispatched immediately
- Future orders: Dispatched at 6am on the order day
What Zonal Receives
Each order includes:- Customer name, email, phone
- All items with ingredient IDs, display record IDs, and portion type
- Modifiers as choice lines with nested structure
- Course assignments (if configured)
- Removal modifiers (for default items removed)
- Discount lines (percentage or fixed amount)
- Tip amount
- Delivery address (for delivery orders)
- Timeslot (for pickup/delivery)
- Collection code (8 characters)
- Custom order notes (via order note product)
Order Notes
To include order notes on tickets, configure an Order Note Product ID in integration settings. storekit creates a line item with the formatted notes attached.Basket Validation & Discounts
Zonal integration validates orders at checkout using thecheckBasket API.
How It Works
- Customer proceeds to checkout
- storekit sends basket to Zonal with all items and modifiers
- Zonal validates availability and calculates any discounts
- Discount amount is returned and applied to the order total
- Basket ID is stored and used when placing the order
Discount Configuration
| Setting | Description |
|---|---|
| Discount Percentage ID | Zonal discount ID for percentage discounts |
| Discount Currency ID | Zonal discount ID for fixed amount discounts |
Basket validation catches unavailable items before payment. If an item is sold out, the customer is notified immediately.
Auto-Snooze on Errors
IfcheckBasket returns a sold-out error (code -216), storekit automatically:
- Identifies the unavailable item
- Snoozes it for 6 hours
- Clears the menu cache
- Returns the item info to the customer
Floor Plan Sync
Sync your table layout from Zonal for dine-in ordering:- Go to Store Settings > Tables
- Click Sync from Zonal
- Areas (sales areas) and tables are imported
What Gets Synced
- Sales areas as venue areas
- Table groups within areas
- Individual tables with numbers and names
- Table capacity
Integration Settings
| Setting | Description |
|---|---|
| Payment Method ID | Zonal payment method for online orders |
| Order Note Product ID | Product ID used for order notes on tickets |
| Order Note Template | Custom template for formatting order notes |
| Discount Percentage ID | Discount ID for percentage discounts |
| Discount Currency ID | Discount ID for fixed amount discounts |
| Enable Coursing | Allow course selection on applicable products |
| Enable Category Merge | Merge categories with same name |
| Import Choices With No Price | Include modifiers without supplement prices |
Testing Your Integration
Pre-Launch Checklist
-
Menu sync
- Categories imported from all sales areas
- Products have correct prices (including portion variants)
- Modifiers appear correctly
- Nested modifiers work
- Images display
-
Order flow
- Basket validates successfully
- Order appears in Zonal POS
- Items, modifiers, and courses are correct
- Collection code/timeslot appears
-
Discounts (if configured)
- Apply a discount code
- Verify amount matches Zonal calculation
-
Floor plan (if using dine-in)
- Tables synced correctly
- Orders route to correct tables
Troubleshooting
Connection Failed
- Verify Brand Token and User Device Identifier are correct
- Check credentials haven’t expired
- Contact Zonal support to confirm iOrder API access
Menu Not Syncing
- Ensure menus are published in Zonal
- Check products are assigned to display groups
- Verify sales areas are configured
- Check for sync errors in the dashboard
Orders Failing
- “Missing basket ID”: Basket validation may have failed - check item availability
- Error -238: Basket expired - storekit will retry with fresh basket
- Error -216: Item sold out - item is auto-snoozed
Modifiers Not Appearing
- Check choice groups are configured on products
- Verify modifiers have supplement prices (or enable “Import Choices With No Price”)
- Re-sync menu after Zonal changes
Wrong Prices
- Check portion configuration in Zonal
- Verify the correct portion is set as default
- For multi-portion products, check size modifier prices
Supported Features
Menu Sync
Menu Sync
Orders
Orders
| Feature | Supported |
|---|---|
| Order injection | ✓ |
| Pre-orders | ✓ |
| Order buffering | ✗ |
| Basket validation | ✓ |
| Auto-snooze sold out items | ✓ |
| Discounts | ✓ |
| Tips | ✗ |
| Service charge | ✗ |
| Custom order notes | ✓ |
| Delivery details | ✓ |
Pay at Table
Pay at Table
| Feature | Supported |
|---|---|
| Live bill sync | ✗ |
| Apply payments to bill | ✗ |
| Split payments | ✗ |
| Track POS terminal payments | ✗ |
| Add to existing bill | ✗ |
Venue Setup
Venue Setup
| Feature | Supported |
|---|---|
| Floor plan sync | ✓ |
| Real-time stock updates | ✗ |
| Multi-site support | ✓ |