Switching from EvoLink to Horizon ERP API Sync is now possible with EvolutionX App Store and the Horizon API. This method allows the end user to view all orders (including those placed on ERP), invoices and account balances. You can also use quote prices to override general live pricing.
- A migration from EvoLink may be required and you should work with Horizon and EvolutionX to cary this out. Details of the migration steps are below. 
- Customers who run more than one EvolutionX store should consult with Horizon Support before using this integration method. 
Setup Of Horizon API Sync
This process will setup and start the Horizon API Sync to EvolutionX as described above. Contact Horizon and EvolutionX for support on the following steps.
Prepare for Go Live Steps
These steps should be done ahead of the golive call.
- Ask Horizon staff to start the process of preparing Horizon for the API Sync. - They will run through some checks with you for data stored in Horizon 
 
- Evaluate your data for compatibility with the API Sync by discussing these with EvolutionX Customer Success Staff: - They will run through some check with you for data stored in EvolutionX 
 
- EvolutionX Store Customers who are migrating from another ERP to Horizon should ask to have their data checked for compatibility with the sync. It would be common to require that existing data is exported from the EvolutionX store and matched with Horizon references. After migration of customer data to the Horizon ERP check the following (if any are missing, use EvolutionX exports from EvolutionX and sent them to Horizon so the EvolutionX Store can be updates): - Important! - Existing EvolutionX Accounts must have the Horizon Account Codes — Use Accounts Only Export to fix. Check that the account codes are unique and not duplicated across multiple accounts. 
- Existing EvolutionX Account Addresses must have the Horizon Address Code — Use Accounts Addresses Export to fix. Check address code unique and not duplicated across multiple addresses. 
 
- Customers who run more than one EvolutionX store should consult with Horizon Software before using this integration method. 
- Account Managers - Set up EvolutionX with Account Managers and use the Horizon Account Manager name as the EvolutionX Account Manager Name. The name set in EvolutionX must match the Horizon account manager name. 
 
- In EvolutionX, run a report "Users with settings all accounts" (no parameters needed) 
- Set or Find the Guest Account Number (Horizon ID) to allow orders for 'non-account customers'. 
- Request the API URL, Username and Password from Horizon for the Horizon App 
- Request the API URL, Username and Password from Horizon for live pricing 
- Set or Find "Discount Product SKU, Discount Product Name and Shipping Fee SKU". If unsure on these field, speak to a member of the EvolutionX team. These SKUs will not be added when using the Reorder button. 
- Choose the email address for notifications sent on any errors EvolutionX receives when sending an order to Horizon. 
Go Live Steps
The go-live will comprise of two steps. First, Horizon will run a sync to recognise and back fill data points from Horizon into EvolutionX. These new data points will be used to synchronise the records going forward.
- In EvolutionX, take an Export of the following: - Customer Accounts: - Accounts Only, 
- Addresses, 
- Cost Centres, 
- Users into Existing Accounts 
 
 
- Prepare the EvolutionX store data. Stores running EvoLink Sync, for example, will follows these steps. - Customer Accounts — Clear all Seller References values 
- Customer Addresses — Clear all Seller Reference values. 
- Customer Users — Clear all Seller Reference values 
- Cost Center — Check for duplicates. 
 
- Confirm that Account codes and address codes are in place and unique. 
Step 1: Horizon Initial Sync
- Create an EvolutionX API Key and name it "Horizon API Sync" or similar. Use it in the this step and do not use it for anything else. This key is a secret and should not be stored. 
- Use this key to set up Horizon exports and run the initial sync up. During this period orders and live pricing will continue to function. 
- When sync is complete, work with the Horizon and EvolutionX team to run some checks on accounts, users, addresses and cost centres. 
- Validate new price (contract) lists have been created and the items within these are correct. Work with the EvolutionX team to remove unwanted price lists. 
Step 2: Set EvolutionX to use new pricing and order features
- Set Horizon System Keys using the notes below. - Find the old API Key used by EvoLink and disable it in the EvolutionX Admin. This will ensure that EvoLink can't be accidentally enabled again. Skip this step if you do not have a legacy sync using EvoLink. 
- Set Live Pricing in EvolutionX (if used). - Note: When setting Global Account, use the Horizon ID number rather than the Horizon account reference 
- Install the Horizon ERP App Store in EvolutionX — This enables the Checkout Integration, New Order processing, and Live Order History and Live invoice History features - Install and configure the "Horizon ERP" app in the EvolutionX App Store (if not enabled for your store, ask our customer success team to enable it). 
- Set Guest Account Number (Horizon ID) for orders of non Horizon customers 
- Request the API URL, Username and DB Password from Horizon 
- Set "Discount Product SKU, Discount Product Name and Shipping Fee SKU". If unsure on these field, speak to a member of the EvolutionX team. These SKUs will not be added when using the Reorder button. 
- Set the email address for notifications sent on any errors EvolutionX receives when sending an order to Horizon. 
- Horizon customers can enable the option of using quote prices on products on the storefront, when one is available. 
 
Supplier Vendor Code
In some cases, different suppliers may use the same SKU for entirely different products. To avoid confusion and ensure accuracy, the Horizon trader ID for the supplier can be entered into the suppliers vendor code field in EvolutionX. This ensures that the correct product pricing is shown to the customer and the correct item is added to the order when it is sent to Horizon, even when SKUs overlap across suppliers.
⚠️ Note: This is optional. However, if a supplier vendor code is configured in the EvolutionX admin screen, it must match the supplier ID in Horizon.
- Tests and Checks 
- Test a single customer sync using the Horizon "Run Customers Now" button. with a trader filter applied. Review the record created in EvolutionX. 
- Check the trouble shooting guide if the customer record is not correctly created. 
- Update roles to enable Account Balances and Invoice History for users who should see these new screens from the Horizon Integration and check an example user to see if there are any issues reading: - Live Order history 
- Live A/R Customer Balances 
- Live Invoice History 
 
- Live pricing — if enabled during the setup, check that it is working as expected 
- Check example orders processed to see that they are arriving as expected. 
- Update roles to enable Account Balances and Invoice History for users who should see these new screens from the Horizon Integration. 
Setting Field Limits
Horizon ERP has some character limits that should be enforced in the Checkout of EvolutionX to ensure that customers stay within those limits as they enter values. Ask Our Customer Success Team to set these limits following this article and setting field limits as follows:
// Account options
var user_name = 0;
var user_phone = 0;
// Delivery Details
var address_name = 0;
var address_line_one = 40;
var address_line_two = 40;
var address_line_three = 40;
var address_county = 40;
var address_city = 40;
var address_postcode = 0;
var address_delivery_note = 0;
var address_company_name = 60;
// Review and pay
var order_note = 0;
var po_number = 60;
var alternative_po_number = 60;
// Billing Details
var billing_address_line_one = 40;
var billing_address_line_two = 40;
var billing_address_line_three = 40;
var billing_address_city = 40;
var billing_address_county = 40;
var billing_address_postcode = 0;
var billing_address_company_name = 60;
For an overview of what is included in the sync, see this article here




