1.Introduction

This is the manual for the integration between Woocommerce and Moneybird.

This integration ensures that orders from Woocommerce webshop are automatically processed to invoices in Moneybird. Because the orders go directly into the online retailer's accounting system, this saves time on financial administration.

Please pay special attention to the following
  1. This integration is a financial integration. It is not a logistics integration. It is not suitable for updating customers in Moneybird, printing packing slips, or synchronizing products/inventory.
  2. This integration does not replace the work of an accountant. It saves time because you no longer have to retype documents. The accountant is still needed for advice, expertise, and control.
  3. We do our utmost to keep the manuals up to date. No rights can be derived from the content of this manual. We appreciate customer feedback to further improve the manuals.
  4. Tip: Other customers using this integration found the tips in the FAQ for Woocommerce and in the FAQ for Moneybird.
Read more Introduction .... Read less Introduction ....

Install integration
Installing the integration starts with signing up for a trial period, via our integrations page. After registering, you'll receive an email containing an installation URL and login details. Use this installation URL to start the integration setup. Installation is complete when both dots for the connection are green and the settings in the Configuration tab have been entered and saved.
There is a 30-day trial period. If you want to install another integration, you can do so in the same way. Make sure you are logged out of the integration dashboard and preferably start the new installation in an incognito browser.

Cancel integration
At the end of the trial or subscription period, the integration will not be automatically renewed. You will receive an offer for a one-year subscription or renewal by email at the end of this period. You can confirm the renewal by using the payment link in that email. Do you want to terminate the integration in the meantime? This can be done via the dashboard, tab Profile>>Cancel integration.
Are you switching to another web shop/accounting system and do you want to re-establish a connection? In this faq we explain how to do this.
When uninstalling the integration, we recommend revoking the consumerkey and consumersecret in WooCommerce.

2.How the integration works

A order from the Woocommerce webshop is processed to a Moneybird invoice.

New orders from your online store are retrieved at least once per hour. If webhooks are enabled in the Woocommerce webshop, orders are retrieved in real time. In addition, any previously retrieved orders that have not yet been sent to your accounting system are checked every night. For more details see the FAQ.

Read more How the integration works .... Read less How the integration works ....

Pre-check orders
At the start of processing a order we perform a number of checks on the Woocommerce order:
  • It is checked whether the total of the Woocommerce order is equal to the sum of the amounts in the order lines plus the shipping amount.
  • If the order is an ICP order, the VAT number is checked.
  • It is checked whether a corresponding VAT code exists in Moneybird for the VAT in each line.
  • It is checked whether the order has not already been processed.

Processing orders
Processing a Woocommerce order to Moneybird happens in two steps:

  1. It is checked if the customer already exists in Moneybird. If not, the customer is created. Matching is based on the email address.
  2. The Moneybird invoice is created and processed.

Post-check
After the order has been forwarded and a success message from Moneybird has been received, the order is marked as completed. The Woocommerce order appears in the Report tab on the dashboard. If Moneybird returns an error while processing the order, the order appears in the Errors tab on the dashboard. Via the yellow button More info more information about the problem can be found. Via the red button Report problem can the order with all necessary information easily be submitted to us after you have tried to resolve the problem yourself. If the problem is solved, in some cases the orders can be processed again with the blue Process button.
Data
Information about the data that is processed can be found in the section Day-to-day: To Moneybird later in the manual.

3.Required: WooCommerce keys

The connection with the WooCommerce webstore is established using a consumer key and a consumer secret. You create these in the webstore. You can use the consumer secret for the webhook.
Read more Required WooCommerce ....
Read less Required WooCommerce ....
If you want to integration with WooCommerce, you need to create a WooCommerce consumer key and consumer secret in your webstore. Go to the WooCommerce settings and click on the Advanced tab. Next, go to the REST API tab and click on "Add key" to add new keys.
Plaatje WooCommerce Sleutels
Provide a clear description for the key so you know later why you generated it. Choose Read permissions, as you will be reading orders from WooCommerce. Then click on Generate API.
Plaatje WooCommerce Sleutels
The consumer key and consumer secret will be generated and displayed. Copy and save them. You need them for the installation and they cannot be viewed again later.
Plaatje WooCommerce Sleutels
WEBHOOKS OPTIONAL Only necessary if you want to push orders immediately.

The last paragraph of this chapter "WooCommerce Keys" is only necessary if you want to push real-time orders in addition to the regular batch. If you skip this subsection, your orders from WooCommerce will still be transferred regularly and automatically at the batch level after installing the connection in the next chapter.

To create the webhook, click on the "Webhooks" tab within the "Advanced" main tab and then on the "Add webhook" button.
Plaatje WooCommerce Webhook

In the screen that has now opened, fill in the requested information. Provide a clear description for the name of the webhook. The Status must be "active". In the third field, enter when the webhook is activated. We recommend choosing "Order updated" (Dutch "Order gewijzigd") here.
Plaatje WooCommerce Webhook

At “Delivery URL" enter: https://interface.cloudinvoice.company/api/v1/servlet/woocommerce/webhook.php?licensekey=UWLICENTIESLEUTEL
where "UWLICENTIESLEUTEL" is of course your own specific webwinkelfacturen.nl license key that you received in your email confirmation of the connection (a 32-character letter/number combination). For the secret, enter the WooCommerce consumer secret as generated at the beginning of this paragraph. Finally, you must save the configuration (save webhook).

Indien je later ooit de Webhooks zou willen de-activeren, ga je binnen "Advanced” tab naar subtab "Webhooks" en kiest voor die specifieke webhook "delete permanently”.

4.Installation

After installation, check using this FAQ, whether the integration works.

Installing the integration starts with signing up for a trial period, via our integrations page. After registering, you'll receive an email with an installation URL and login details. Use this installation URL to start the integration installation.

Activating the integration consists of three steps:
1. Establishing the connection with the WooCommerce webshop. In this step you authorize the integration to read data from your webshop.
2. Establishing the connection with Moneybird. This authorizes the integration to write transactions to your Moneybird administration and read information.
3. The configuration itself.

Read more Installation .... Read less Installation ....

Before the integration can be used, the terms and conditions must first be accepted. These terms are based on the general ICT Terms (industry association) and the general GDPR guidelines. We also require a name, email address, and the country of the webshop.

Connection Woocommerce
The connection with the Woocommerce webshop is established using the Clientkey and Clientsecret that you created in a previous section. Click the red Connect button next to Woocommerce and enter the Clientkey and Clientsecret in the popup window. If the connection is established correctly the indicator will turn green. If the connection is not established then this is the FAQ for troubleshooting.

Moneybird connection
The connection with Moneybird runs via OAuth. Make sure you are logged out of Moneybird before starting the connection. Now click the red Connect button. A login screen for your Moneybird account will automatically appear. If you log in, you will get a screen asking if you allow the connection. If you confirm this, the connection with Moneybird will be established.

Processing status
You can specify which statuses orders should be processed to Moneybird. You can select multiple statuses. The integration will never forward orders twice. The integration is protected against this.

Administration and invoice layout
To use the integration, you must specify to which administration the invoices should be sent. You also need to specify an invoice layout for the Moneybird invoices. If you do not do this, the invoices unfortunately cannot be created in Moneybird.

Configure VAT rates and general ledger accounts
When setting up the VAT rates and general ledger accounts, a link is established between the VAT rates in webshop and the VAT codes and revenue accounts in Moneybird. You can always make adjustments by clicking the blue 'Modify' button and making a selection via the drop-down boxes.
NB: ledger numbers are shown in the image below. This is for illustration purposes only. For Moneybird integrations, a name is shown here.

In Woocommerce you can work with standard VAT rates or with the VAT rates from the webshop. We recommend that you work with standard VAT rates. This takes a little more time to set up, but it prevents orders from not being processed to Moneybird.

Option 1:
With standard VAT rates you work with a list of VAT rates per EU country. You can adjust the VAT percentage for orders and configure the VAT settings for Moneybird per EU country. For example, if you deliver to Germany you can indicate in the settings that 19% and/or 7% VAT is used and that it should be booked to a separate code in Moneybird.

Option 2:
With VAT rates from the shop the integration retrieves the VAT rates from the webshop. Countries that are not present in the webshop VAT settings will therefore not appear in the list. Woocommerce works with VAT percentages and VAT classes. This combination is loaded and validated by the integration. An order with 21% VAT and VAT class reduced will often not be processed because in Woocommerce the VAT class standard usually belongs to 21%.

We often see this go wrong, which is why we recommend the first option, namely standard VAT rates. Intra-Community (ICP) and international deliveries
The Intra-Community supplies / ICP option is intended for business-to-business deliveries within the EU. These sales are invoiced with 0% VAT. A VAT number from the customer is required. The International option applies to deliveries outside the EU. For these sales, the integration expects 0% VAT; otherwise, the sales cannot be processed. Separate VAT codes and general ledger accounts can be configured for both ICP and international deliveries.

Once the VAT settings have been configured and saved, you will always see the selected VAT rates. If you want to start over, you can use the grey 'Remove VAT settings' button. Your current settings will then be deleted and you can begin again.

Configure payment methods
You can create a link here between the payment methods in the webshop and a fixed debtor in your Moneybird administration. Orders with a payment method from the list will then always be posted to this debtor. In that case, no new debtors will be created.
Note: It is not possible to set fixed debtors for ICP orders. For an ICP order, a valid VAT number must be transmitted. Therefore, a debtor will always be created in Moneybird for an ICP order.

Categories
It is possible to process revenue based on product categories. You can configure the general ledger accounts here. We recommend a maximum of 40 categories, and there is a technical maximum of 99 categories. When accounts are configured at the category level, they take precedence. The revenue accounts set under the VAT rates will no longer apply.

5.Day-to-day: From WooCommerce

Process schedule: New orders from your online store are retrieved at least once per hour. If webhooks are enabled, orders are retrieved in real time. In addition, any previously retrieved orders that have not yet been sent to your accounting system are checked every night.

Once an order has been processed, it cannot be processed again. Any order changed in the webshop after it has been processed will not be updated in Moneybird.

Processing status: For each order the status of the order is checked. You previously indicated when you want orders to be processed to your accounting system. This choice can be viewed — and changed — in the Configuration tab of the dashboard at status for processing sales.
Orders that are picked up and have a status other than one of the selected options will automatically be transferred the following night if they have one of the selected options in WooCommerce.

VAT numbers For business orders within the EU, outside the Netherlands, a VAT number is mandatory. The integration checks this. There are numerous plugins that allow VAT numbers to be added to WooCommerce orders and it is impossible for the integration to support every plugin. There is a fixed list of field names from which the integration reads the VAT number. This list can be found in the FAQ.

VAT calculation In WooCommerce, VAT percentages are listed by default with both 2 decimals and 4 decimals. The integration uses the 4-decimal values to calculate the VAT percentage as accurately as possible. Therefore, make sure the VAT in the order lines is available with 4 decimals.*

* Technical: This concerns the fields [total], [total_tax], [subtotal], [subtotal_tax] and [taxes] per order line in [line_items].

  • The fields [total] and [total_tax] contain the line amount excluding VAT and the VAT amount after discount, in two decimals
  • The fields [subtotal] and [subtotal_tax] contain the line amount excluding VAT and the VAT amount before discount, in two decimals.
  • The [taxes] field contains the same amounts but with four decimals. The integration uses the values in [taxes] for the VAT calculation.

Refunds If you want the integration to process refunds in addition to the orders, you can enable this at status for processing sales in the dashboard. See here for more information: FAQ.

Please note: The integration looks back 30 days to retrieve refunds. Refunds that come in later cannot be processed by the integration. The integration only processes a refund if it has previously processed the order to which the refund relates. Finally, the integration only processes full refunds . Partial refunds are not processed. For more information see the FAQ

Please pay special attention to the following The integration will not read or pass many fields from a Woocommerce order to Moneybird. In particular, the note_attribute fields and the custom fields are not included. This is because different webshops use these fields differently. Because our integrations must work for all webshops, we cannot configure this for individual merchants.

Pay special attention to fields that come from plugins. There is a good chance that the integration does not process these fields. For example, with discount plugins the amounts may not be correctly included in the order, preventing the order from being processed.


Field-level specification orders
Specification Woocommerce order. +-
Name field Values from Woocommerce order
Order-identifier [id]
Order number A fixed prefix followed by field [number]. The prefix configuration can be requested via webcare@webwinkelfacturen.nl
Invoice number Determined from the [meta_data]. The following fields are examined in turn. The first one present is returned.
  • key-veld [_wcpdf_formatted_invoice_number]
  • key-veld [_wcpdf_invoice_number]
  • key-veld [formatted_invoice_number]
  • key-veld [invoice_number]
Booking date [date_created]
Order date [date_created]
Status order [status]
Payment status If the status of the order is completed or processed or if [date_paid] has been entered then paid
Payment reference [id]
Note [customer_note]
Is it a Bol.com order? The answer is yes if there is a field [customer_user_agent] with the value effectconnect and the field [billing][email] is a bol.com email address
Is it a Fonq order? The answer is yes if it is not a Bol.com order and there is a field [customer_user_agent] with the value effectconnect
Is it another order coming through an external party? The answer is yes if the key is part of a fixed set of keys. This list can be expanded upon request.
Affiliate number The affiliate number is determined as follows:
  • If the meta-data contains a key bol_order_id is present, then this is the affiliate number
  • For Bol.com orders the shipping lines are checked. From the line with [method_title] a text such as shipment for bol.com will the affiliate number from the field [method_title] be extracted.
  • For Fonq orders the shipping lines are checked. From the line with [method_title] a text such as shipment for fonq will the affiliate number from the field [method_title] be extracted.
  • For the remaining orders the affiliate number is located in the [meta_data] fields under key _external_order_number.
Valuta If the currency option is set for the customer then [currency]
Payment method field [gateway] in [transactions]
Order total incl. VAT and discounts [total_price]
Total VAT order incl. discounts Value in [total_tax], or, if that value is 0, the value from [current_total_tax]. When using [current_total_tax], there's an additional check. The VAT lines in the order must add up to the value in [current_total_tax].
Order total excl. VAT and discounts Difference between the two lines above
Delivery country The delivery country will be the [shipping][country] field if it is filled in. Otherwise, the [billing][country] field will be used.
ICP indication The integration determines as follows whether it concerns an ICP order:
  • If the merchant has configured a margin, it is never an ICP order
  • If the field [total_tax] has value 0
  • And the delivery country is not the same as the country of the Woocommerce webshop
  • And the delivery country is an EU country
  • And there is no VAT on the order lines
  • Then it is an ICP delivery, otherwise it is not an ICP delivery
International indication The integration determines as follows whether it concerns an international order:
  • If the merchant has configured a margin, it is never an international order
  • If the field [total_tax] has value 0
  • And the delivery country is not the same as the country of the Woocommerce webshop
  • And the delivery country is not an EU country
  • And there is no VAT on the order lines
  • Then it is an international delivery outside the EU, otherwise it is not an international delivery outside the EU
Do the order lines have VAT? To determine whether VAT is applied to order lines, the [subtotal_tax] and [total_tax] fields are examined per line, and the [shipping_tax] fields are examined in the order itself. If any of these fields have a value other than 0, VAT is applied to the order lines. If all fields have a value of 0, there is no VAT on the order lines.
Specification Woocommerce order lines. +-
To read the order lines, the integration retrieves the [line_items] field. Multiple order lines can be included in the order, and the integration reads these lines one by one.
Name field Values from Woocommerce order line
Productid [product_id]
Category In the case of processing categories, the category ID and name
Amount [quantity]. Note: if the quantity is 0, parsing stops.
SKU If the SKU is filled, then [sku]. Otherwise [product_id].
Description [name] plus the values ​​in field [meta] in the order line with key / key label or key
VAT percentage The VAT percentage is determined as follows:
  • If the order is an ICP or international order, then the VAT percentage is 0%
  • If the value in the [total] field is not 0, then the [taxes][total] fields are added together
  • If the value [total] is 0 and the value in the field [subtotal] is not 0, the fields in [taxes][subtotal] are added together.
  • The VAT percentage is the summed amount in the [taxes] fields divided by [total] or [subtotal]
Amounts excl. VAT Amount in field [total]
Amounts incl. VAT Amount in field [total] plus the amount in field [total_tax]
Discount in order line An order line has two totals: [total] and [subtotal]. The [total] amount is the line amount including the discount, and the [subtotal] amount is the amount excluding the discount. Discounts are therefore processed directly in the order line and not added as separate lines.
VAT code and accounts Moneybird These are determined based on the settings, the VAT percentage and the delivery country. It also takes into account whether the order is an ICP or international order. If processing is done based on categories, the revenue account is determined using the revenue account configured for the respective category in the dashboard
Specification Woocommerce shipping costs. +-
To read the shipping costs, the integration uses the field [shipping_lines]. There can be multiple shipping lines. For the name and VAT percentage only the first line is used, while the amounts from all shipping lines are summed. In most cases there will be only one shipping cost line.
Name field Values from Woocommerce order line
Description [method_title] from the last shipping cost line
VAT amount shipping costs Each line in the [shipping_lines] field can contain multiple VAT lines in the [taxes] field. These are summed and the total is the VAT amount for shipping costs.
Shipping costs excl VAT [shipping_total] in the order
Shipping costs incl VAT Shipping costs excl. VAT plus the VAT amount for the shipping costs.
VAT percentage VAT amount for shipping costs divided by the shipping cost amount excl. VAT
VAT code and accounts Moneybird These are determined based on the settings, the VAT percentage and the delivery country. It also takes into account whether it is an ICP or international order.
Specification Woocommerce surcharges +-
The surcharges are stored in the [fee_lines] field. Each surcharge becomes a separate line in the order.
Name field Values from Woocommerce order line
Description [name]
VAT amount If it is an international or ICP order then 0, otherwise the amount in the [total_tax] field.
Amount excl VAT [total] in the order
Amount incl VAT Amount excl. VAT plus VAT amount
VAT percentage VAT amount of the surcharge divided by the amount excl. VAT
VAT code and accounts Moneybird These are determined based on the settings, the VAT percentage and the delivery country. It also takes into account whether it is an ICP or international order.
Specification Woocommerce customer details +-
Name field Values from Woocommerce customer
The billing address is in field[billing] and the shipping address in field [shipping]. The content of these fields is always the same, so we do not describe them separately.
Address If present based on [billing_address] in the Woocommerce order
  • First name - [first_name]
  • Last name - [last_name]
  • Company name - [company]
  • Addressline1 - [address_1]
  • Addressline2 - [address_2]
  • Zipcode - [postcode]
  • Phone nr - [phone]
  • City - [city]
  • Iso-countrycode - [country]
  • Country - [country]
VAT number The VAT number may be present in the [meta_data] of the order. There is a fixed list of keys that are searched. If the VAT number is not found, the integration continues searching in the [vat_number] and VIES data fields in the order. A VAT number is always validated.

6.Day-to-day: To Moneybird

Create transactions
At the end of this section, it is detailed at field level how we create a Moneybird invoice.

Information for processing payments is also described in this section.

Shipping status: It is possible to set the shipping status of the Moneybird invoice to sent. For this, it is necessary that the Moneybird debtor has shipping method manual. It is possible to request from us that a Moneybird invoice always or never receives the status sent.


Automatically send invoice: Even if the integration has the status sent, that does not mean that Moneybird automatically sends the invoice. After all, in Moneybird, the invoice can be sent manually or by email. If you want the invoice to be sent automatically by email, please contact us. We can then set that up for you.


Payment status: It is possible to set the payment status of the Moneybird invoice to paid. For this, it is necessary that the Moneybird has the status sent. In addition, the order must be paid. It is possible to request from us that a Moneybird invoice always or never receives the status paid. With Mollie payments, the Mollie transaction ID can also be processed to Moneybird. Via this transaction ID, Moneybird automatically reconciles the invoices.
Please note: Sometimes a payment for a order arrives after the integration has processed the order. In that case, the status of the invoice in Moneybird is not adjusted. Therefore, no payment request is forwarded. The only remedy is to contact us with the request to hard-set that all orders always receive the paid status.


Workflows: The integration does nothing with the Moneybird workflows. It is therefore not possible to include a workflow with the invoice.


Creating new debtors
When processing customer information, it is first checked whether the customer has been processed before. If so, this Moneybird debtor is used as the debtor for the Moneybird transaction. If the customer is not yet known, they are added to Moneybird. Matching is based on email address. Please note: The integration only creates debtors. The integration does not modify debtors.


Field-level specification Moneybird

Field-level specification of the Moneybird invoice. +-
Moneybird factuur
Name Example Note
sales_invoice
Date 2023-01-11T19:46:56+01:00 order date
Reference 1698 Order number, with a negative order Credit order number.
Invoice number INV1234 Only on request and equal to the order number, on request invoice number on request. It is better if Moneybird determines the invoice number itself.
contact_id 89387832984u987229 Id Moneybird debtor.
Prices incl. VAT true If the prices in the webshop are incl. VAT, otherwise false.
Invoice profile As set on the dashboard
details_attributes
amount 1 Amount
description A4 - poster Description
tax_rate_id 230205097768912088 VAT code
price 33.00 Unit price incl. VAT, if the prices in the webshop are incl. VAT, otherwise unit price excl. VAT
ledger_account_id 230205097213166793 ID of the revenue category as set on the dashboard.
prices_are_incl_tax 1
document_style_id 389430293784902308 On request, 1 default project-id (cost center) can be filled in per integration.
Detailed specification at field level Moneybird payment. +-
Name Example
Payment date [date]
Amount The amount from the payment
Transaction-identifier In case of a Mollie payment, Moneybird can automatically reconcile the invoice.
Account (Ledger account) Is provided if it has been set.
Field-level specification of the Moneybird customer. +-
Name Example Note
company name [company]
first name [firstname]
last name [lastname] If the first name & last name are not provided, the last name becomes -> NN.
address [address]
zipcode [zipcode]
city [city]
country [isocode]
mobile [telnr]
email [email]
Chamber of commerce [CoC]
VATnumber [vatnr]
delivery method Manual
customerId Empty, unless [customerid] or [referenceid] is provided.

7.Support

We believe it is important that you as online retailer have direct access to information about the integration whenever you want. That is why every customer has a personal dashboard.
Read more Support .... Read less Support ....

Persoonlijk

Explanation tabs dashboard

On the Dashboard >> Report you can see which orders from your Woocommerce webshop, and when, have been transferred to Moneybird.

At Dashboard >> Errors you can see which orders have not been processed. Via the blue Process button you can (re)submit the order. Via the red Report problem button you can create a ticket with us.

At Dashboard >> Open the orders are listed that have not yet been processed because they do not yet have the correct status in the webshop. Every night jobs run to review the status again and still process the order.

At Dashboard >> Configuration the settings of your integration are listed. You can adjust the settings there.

At Dashboard >> Profile invoices are available for download. You can also specify an additional email address here for sending emails and stop the integration.

What if orders are missing in Moneybird

If orders are missing in Moneybird we recommend following the steps below:
  1. Log in to the dashboard: https://uwkoppeling.webwinkelfacturen.nl. The username and password are included in the registration email.
  2. Go to the Errors tab and check if order is there. You may need to adjust the search period if the order is from a previous month. If you find order in this overview:
    1. Check the error code and verify whether you can resolve it yourself.
    2. If yes resolve the issue and click the blue Process button to resubmit the order.
    3. If not use the red Report problem button to create a ticket with us.
    4. Note if there are multiple errors, please create only 1 or 2 tickets. We will automatically see the other issues.
  3. Go to the Report tab and see if order is listed there. If so, you'll often see an identifier for Moneybird (in the purple section of the overview) that you can use to search for order.
  4. Go to the Open tab and check if order is there.
  5. If you cannot resolve the issue, you can always create a ticket via the green Ask us button.

Other questions

You can send any other questions or comments to webcare@webwinkelfacturen.nl. For a quick response, please always include the license key and as much information as possible. If you encounter any problems during installation, please let us know where you're experiencing the issue. And if there's an error message, please include that as well. If you think orders are missing, please provide the number and date. This way, we can perform a more targeted search and tell you what's wrong.

We have an extensive FAQ-section on the website. Pay particular attention to these sections: https://faq.webwinkelfacturen.nl/category/38/woocommerce.html and https://faq.webwinkelfacturen.nl/category/30/moneybird.html.

Would you prefer us to perform the installation of the integration for you? That is possible. Send an email to webcare@webwinkelfacturen.nl with the request. We charge €39.50 excl. VAT for an installation. For installations we require access to the webshop and the accounting system.

We can perform migrations for orders that took place in the past. The request procedure and method are described in this faq. For migrations we charge €67.50 excl. VAT per 1000 orders.