3 Ways to Add WooCommerce VAT Number Field

In this tutorial, I'll show you how to add a VAT number to your WooCommerce checkout with the help of WooCommerce User Registration Plugin

So, continue reading ahead and check out how to add a VAT number field to your WooCommerce user registration form

How to Add WooCommerce VAT Number Field

If you are conducting business in the EU or UK, then you might want to collect your customer's VAT to send a follow-up invoice or to verify their VAT status and grant them tax exemption. Below I’ll show you how to add this field on your checkout and registration pages.

Without further ado let's get started.

Method 1: Add a VAT Number Field Via AIO Checkout

Another method to add a VAT number field is by using the AIO Checkout plugin. The following are the steps to do so:

1. Install and Activate the AIO Checkout Plugin

First, we need to download the AIO Checkout plugin from the official AovUp store. 

Once you have downloaded it, navigate to the Plugins > Add New from your WordPress admin dashboard, and click the Upload button to upload the downloaded file to install and activate the plugin.

2. Navigate to the AIO Checkout

Once you have installed and activated the plugin, navigate to AIO Checkout from your WordPress dashboard.

3. Create a New Checkout Form

On the general settings page, you will see different options. We need to create a new checkout form and add a VAT number field to it. To do so, click the “Create New Checkout” button.

Once you click the button, a new checkout form will be created. It’ll be the default WooCommerce checkout form, but you can customize it according to your business needs to improve the customer experience.

You can also add custom fields like birthday fields, reCaptcha fields, and more.

4. Add a VAT Number Field 

Once the checkout form is created, click the black floating gear icon on the right side of your screen to open the fields panel. 

After clicking the gear icon, a pop-up will appear on the right side of your screen. You'll see different fields to add to the checkout form or create a new form with the fields you want. 

4.1. Add a VAT Number Field

Next, you need to add a text field to the form to allow customers to add their VAT number while checking out.

To do so, drag the ‘Text’ field from the fields panel to the form. You can drag and drop the field to adjust its order. I am adding it to the billing section above the company address field. 

5. Configure the VAT Number Field

After adding the text field, you need to change its label to ‘VAT Number’ to make it understandable to customers. To do so, click the black gear icon on the field. 

A popup will slide in from the right side of the screen from which you can add a label in the ‘Label’ field. You also have the option to make it a required field, change its appearance, and add conditional logic to it. I am leaving it to the default selected options. 

6. Select the Design of the Checkout Form

Once you have added the field, you next must select the design of the checkout form/page.  

Click the ‘Design’ tab at the top.

There are multiple templates available, you can choose any template you want. I have selected the ‘Multiple Columns Modern’ template. 

You can also create a template from scratch. 

7. Select the Thank You Page Design

Next, click the ‘Thank You Page’ tab at the top, and select the template for the thank you page. If you want, you can also create a custom thank you page

If you want to inherit the thank you page design from the global checkout, you can leave everything to default. But if you want to customize the thank you page or create one from scratch, ensure to select ‘No’ for the ‘Inherit from the Global checkout form’ option. 

Note: You won’t see the thank you page templates if you have set the ‘Inherit from the Global checkout form’ option to ‘Yes.’

8. Enable the Checkout

After selecting the thank you page design, we need to enable this checkout form. Click the ‘Settings’ tab.

8.1. Enable the Checkout Form

To enable the checkout form, toggle the ‘Enable’ button. Also, ensure you have enabled the ‘Set as Global Checkout’ option to make this form the global checkout. 

You can leave it disabled if you create this form for specific user roles or product. I am enabling it as a global checkout as I don’t want to set a user restriction

10.2. Give a Name to the Form

Now, we need to give a name to this form. It will only be displayed to the admin. It is helpful if you have created different checkout layouts for different user roles. 

Note: You can also explore the other available settings and set a custom checkout button text. But I'll move to the next step to keep this tutorial short and to the point. 

9. Save Changes

Once you have added a VAT number field and made the required adjustments, click the green ‘Save Changes’ button at the top right corner of your screen to save the settings. 

10. Final Results

Now let’s see the final results. 

I added a product to my cart and visited the checkout page and as you can see in the screenshot below, a VAT number field has been added to the form. 

Now, customers can enter their VAT number, and you can send them the invoice. 

Note: You can also use the WooCommerce Tax Exempt plugin to add a VAT number field and an EU VAT number checker via VIES at checkout.

Method 2: Using the WooCommerce User Registration Plugin

Note: You can skip this step if you have installed and activated the WooCommerce User Registration Plugin.

To install the WooCommerce User Registration Plugin, you must install the Woosuite Core plugin and activate your Woosuite license key. We have created a Quick Start Guide to walk you through the installation process. 

2. Navigate to WooCommerce User Registration Plugin’s User Field Setting

In WordPress Admin Dashboard: Navigate to Woosuite > WooCommerce User Registration > User Field Settings

Click on the ‘User Fields’ option.

3. Create VAT Number Field

Follow the given steps to create a new VAT Number Field. 

1. Click on the ‘Add New Field’ Button

2. Give a Name to the New Field 

In the ‘Label’ field, enter the name of your new field. You can name it ‘VAT Number.’

3. Select Field Type to Text

As this is going to be a Text field, we will select ‘Text’ from the given options. Users will write in this field, so this is a text field.

4. Select Status to Publish

By default, it would be set to ‘Unpublish.’ You need to select ‘Publish.’ If you don’t want to publish it, keep it as it is. You can come back and change it.

5. Mark the Field As Required (Optional)

Tick the ‘Required Field’ box to make the field required to be filled for users. They won’t be able to proceed further without filling in this field. 

In my case, I’m making it ‘Required’, but you can decide whether you want to make it or not. 

6. Show this Field on Order Page and Order Email

Tick the ‘Show in Admin Order Detail Page, and Order Email’ option to display the VAT Number field on the mentioned positions. 

7. Select the Field Width

You will get two options - ‘Half-Width,’ and ‘Full Width.’ You can select according to your design preferences. By default, it would be one ‘Full Width.’

8. Add the Placeholder Text

You can add placeholder text in this field, which is the text users will see in the background of the box. In the ‘Placeholder Text,’ you can add text like, ‘Enter Your VAT Number.’

Note: This only works in the default WooCommerce User Registration Form. If you are creating a custom User Registration Form, this will not work.

9. Click on the Save Field Button

Click on the ‘Save Field’ to save all the changes you have made till now. 

10. Click on the Save Changes Button

Again, click on the ‘Save Changes’ button to save all the settings. 

Also Read: How to Add an Upload Field In WooCommerce User Registration Form

Final Results

Now, we figured out how to add the WooCommerce VAT number Field. We made all the settings correctly. Make sure to cross-check all the settings before publishing or saving the settings. We will now check whether everything is working fine or not. Here are the final results we got with the help of the WooCommerce User Registration Plugin.

Method 3: Add a VAT Number Field Via Code

Another method to add a VAT number field is by using a custom code. You can use this method if you have experience with the code. 

I’ll also explain the code for your better understanding, but it might be confusing and difficult if you have zero experience with the code. 

The following is the step-by-step process to add a VAT number field at checkout via code. 

3.1. Copy the Code

The following is the code snippet to add a required VAT number field at checkout. This code also displays the VAT number on the order confirmation page and the email. 

Note: Do not change anything in the code unless you are very sure. 

// Add VAT Number field to WooCommerce checkout
add_filter('woocommerce_checkout_fields', 'aovup_add_vat_number_field');

function aovup_add_vat_number_field($fields) {
    $fields['billing']['vat_number'] = array(
        'label'         => __('VAT Number', 'woocommerce'),
        'placeholder'   => _x('Enter VAT Number', 'placeholder', 'woocommerce'),
        'required'      => false,
        'clear'         => true,
        'type'          => 'text',
    );

    return $fields;
}

// Validate VAT Number field
add_action('woocommerce_checkout_process', 'aovup_validate_vat_number_field');

function aovup_validate_vat_number_field() {
    $vat_number = isset($_POST['vat_number']) ? sanitize_text_field($_POST['vat_number']) : '';

    if (empty($vat_number) && apply_filters('require_vat_number', true)) {
        wc_add_notice(__('VAT number is required!'), 'error');
    }
}

// Save VAT Number to order data
add_action('woocommerce_checkout_create_order', 'aovup_save_vat_number_to_order_meta');

function aovup_save_vat_number_to_order_meta($order) {
    $vat_number = isset($_POST['vat_number']) ? sanitize_text_field($_POST['vat_number']) : '';

    if ($vat_number) {
        $order->update_meta_data('_vat_number', $vat_number);
    }
}

// Display VAT Number on order details in My Account
add_action('woocommerce_order_details_after_order_table', 'aovup_display_vat_number_on_order_details');

function aovup_display_vat_number_on_order_details($order) {
    $vat_number = $order->get_meta('_vat_number');

    if ($vat_number) {
        echo '<p><strong>' . __('VAT Number') . ':</strong> ' . esc_html($vat_number) . '</p>';
    }
}

// Add VAT Number to order emails
add_filter('woocommerce_email_order_meta_fields', 'aovup_add_vat_number_to_order_emails', 10, 3);

function aovup_add_vat_number_to_order_emails($fields, $sent_to_admin, $order) {
    $vat_number = $order->get_meta('_vat_number');

    if ($vat_number) {
        $fields['_vat_number'] = array(
            'label' => __('VAT Number'),
            'value' => $vat_number,
        );
    }

    return $fields;
}

3.2. Understand the Code

This code is a set of functions in PHP designed to integrate a Value Added Tax (VAT) Number field into the checkout process of a WooCommerce store in WordPress. The aovup_add_vat_number_field function adds a custom VAT Number field to the billing section of the checkout form. 

The aovup_validate_vat_number_field function ensures that the VAT Number is validated during the checkout process, displaying an error notice if it is empty or in the wrong format. The aovup_save_vat_number_to_order_meta function saves the entered VAT Number to the order as metadata. 

Two additional functions, aovup_display_vat_number_on_order_details, and aovup_add_vat_number_to_order_emails, are responsible for displaying the VAT Number on the order details in the user's account and in order confirmation emails, respectively. 

These functions retrieve the VAT Number from the order's metadata and display it appropriately. I hope it makes more sense now. 

3.3. Paste the Code to Your Store

Once you have copied the code, you can add it to your store. There are multiple ways to add code snippets to WordPress. Here’s the complete guide to help you. 

I have used the plugin to add the above code to my demo store. 

3.4. Final Results

Let’s test the final results. I added a product to my cart and visited the checkout page to test it. I could see the VAT number field at the very end of the billing section. 

If you shop as a customer from your store and place a test order, you will also the VAT number in the order confirmation email.

Conclusion

We finally checked out how to add a WooCommerce VAT number field. I hope you understood the steps properly and implemented them on your WooCommerce store. If you face any issues while adding the WooCommerce VAT number field, leave a comment or contact Woosuite customer support. Our dedicated customer support team typically replies within 48 hours. 

Brian
Brian

Welcome to the AovUp blog, where we discuss all things WooCommerce. I hope we can help you achieve something today...

Leave a Reply

Your email address will not be published. Required fields are marked *

We – and our partners – use cookies to deliver our services and to show you ads. By using our website, you agree to the use of cookies as described in our Cookie Policy