Address Autocomplete Provider Implementation
Overview
The WooCommerce Address Autocomplete system allows third-party services to provide address suggestions as customers type in their billing and shipping addresses during checkout. This guide explains how to create and register custom address providers to integrate with any address validation service.
Please note, this implementation will register the provider for both the shortcode and block-based checkouts.
Architecture
The address autocomplete system consists of three main components:
- Server-side Provider (PHP) - Handles provider registration and configuration
- Client-side Provider (JavaScript) - Implements the search and selection logic
- UI Components - Displays suggestions and handles user interactions (this is implemented by WooCommerce, plugins do not have to provide this)
Registering the server-side provider
Step 1: Create a WC_Address_Provider subclass
Create a PHP class that extends WC_Address_Provider
:
<?php
/**
* Custom Address Provider Implementation
*
* @package YourPlugin
*/
namespace YourPlugin\Providers;
use WC_Address_Provider;
/**
* Custom Address Provider
*/
class Custom_Address_Provider extends WC_Address_Provider {
/**
* Provider unique identifier.
*
* @var string
*/
public $id = 'custom-provider';
/**
* Provider display name.
*
* @var string
*/
public $name = 'Custom Address Provider';
/**
* Optional branding HTML to display with suggestions.
*
* @var string
*/
public $branding_html = '<div class="custom-branding">Powered by Custom Provider</div>';
/**
* Constructor
*/
public function __construct() {
// Initialize any API clients or configurations.
}
}
Step 2: Register the provider
Register your provider with WooCommerce using the woocommerce_address_providers
filter:
/**
* Register the custom address provider
*
* @param array $providers Existing providers.
* @return array Modified providers list.
*/
function register_custom_address_provider( $providers ) {
// Only register if the provider class exists
if ( class_exists( 'YourPlugin\Providers\Custom_Address_Provider' ) ) {
$providers[] = new \YourPlugin\Providers\Custom_Address_Provider();
}
return $providers;
}
add_filter( 'woocommerce_address_providers', 'register_custom_address_provider', 10, 1 );
Registering the client-side provider
Step 3: Implement JavaScript functions
Create a JavaScript file that implements the client-side provider logic.
Provider Object API
Parameters
- id
string
- Unique identifier that must match the server-side provider ID. - canSearch
function
- Function to determine if the provider supports searching in a given country.- Parameters:
- country
string
- Two-letter country code (e.g., 'US', 'GB').
- country
- Returns:
boolean
- Whether the provider supports this country.
- Parameters:
- search
function
- Asynchronous function to search for address suggestions.- Parameters:
- query
string
- The text entered by the user (minimum 3 characters). - country
string
- Two-letter country code of the selected country. - type
string
- Address type, either 'billing' or 'shipping'.
- query
- Returns:
Promise<Array>
- Promise resolving to an array of suggestion objects.
- Parameters:
- select
function
- Asynchronous function to retrieve complete address details.- Parameters:
- addressId
string
- The ID of the selected suggestion.
- addressId
- Returns:
Promise<Object|null>
- Promise resolving to an address object or null on error.
- Parameters:
Suggestion Object Format
The search
function must return suggestion objects with the following structure:
- id
string
- Unique identifier for this suggestion. - label
string
- Display text shown to the user. - matchedSubstrings
array
(optional) - Array of text ranges to highlight in the label.- offset
number
- Starting position of matched text. - length
number
- Length of matched text.
- offset
Address Object Format
The select
function must return address objects with these WooCommerce field names:
- address_1
string
- Primary address line. - address_2
string
- Secondary address line (optional, can be empty string). - city
string
- City or town name. - state
string
- State or province code. - postcode
string
- ZIP or postal code. - country
string
- Two-letter country code.
Example Implementation
/**
* Custom Address Provider Client Implementation
*/
// Define the provider
const customProvider = {
// Must match the PHP provider's ID.
id: 'custom-provider',
/**
* Check if provider can search in given country
*
* @param {string} country - Two-letter country code (e.g., 'US', 'GB')
* @return {boolean} Whether the provider supports this country
*/
canSearch: function ( country ) {
// Define supported countries.
const supportedCountries = [ 'US', 'CA', 'GB', 'AU' ];
return supportedCountries.includes( country );
},
/**
* Search for address suggestions
*
* @param {string} query - The search query entered by the user
* @param {string} country - The selected country code
* @param {string} type - Address type ('billing' or 'shipping')
* @return {Promise<Array>} Array of suggestion objects
*/
search: async function ( query, country, type ) {
// Return search results. Your function may call an endpoint to get this data.
const data = [
{
id: '1',
label: '123 Main Street, City, US',
matchedSubstrings: [ { offset: 0, length: 3 } ],
},
{
id: '2',
label: '456 Oak Avenue, Town, US',
matchedSubstrings: [ { offset: 0, length: 3 } ],
},
{
id: '3',
label: '789 Pine Road, Village, US',
matchedSubstrings: [ { offset: 0, length: 3 } ],
},
{
id: '4',
label: '101 Pine Road, Village, US',
matchedSubstrings: [ { offset: 0, length: 3 } ],
},
{
id: '5',
label: '101 Pine Road, Village, US',
matchedSubstrings: [ { offset: 0, length: 3 } ],
},
];
return data;
},
/**
* Get full address details for a selected suggestion
*
* @param {string} addressId - The ID of the selected suggestion
* @return {Promise<Object>} Address details object
*/
select: async function ( addressId ) {
// Return address components in correct format. Your function may call an endpoint to get this data.
return {
// Required fields
address_1: 'Test address 1',
city: 'Test City',
state: 'CA',
postcode: '92010',
country: 'US',
};
},
};
// Register the provider.
if (
window.wc &&
window.wc.addressAutocomplete &&
window.wc.addressAutocomplete.registerAddressAutocompleteProvider
) {
window.wc.addressAutocomplete.registerAddressAutocompleteProvider(
customProvider
);
}
Step 4: Enqueue the JavaScript
Enqueue your JavaScript file on checkout pages.
This JavaScript file should be enqueued even if the provider is not chosen as the preferred provider. This is because your provider could be used as a fallback if the preferred provider is unable to search for results.
/**
* Enqueue custom provider scripts
*/
function enqueue_custom_provider_scripts() {
// Only load on checkout pages
if ( is_checkout() ) {
// Check if address autocomplete is enabled
$is_enabled = get_option( 'woocommerce_address_autocomplete_enabled' ) === 'yes';
if ( $is_enabled ) {
wp_enqueue_script(
'custom-address-provider',
plugin_dir_url( __FILE__ ) . 'assets/js/custom-address-provider.js',
array( 'wc-address-autocomplete' ),
'1.0.0',
true
);
// Pass data to JavaScript
wp_localize_script(
'custom-address-provider',
'yourPlugin',
array(
'nonce' => wp_create_nonce( 'wp_rest' ),
'apiUrl' => rest_url( 'your-plugin/v1/' )
)
);
}
}
}
add_action( 'wp_enqueue_scripts', 'enqueue_custom_provider_scripts' );
REST API Implementation
The JavaScript provider communicates with your server via REST API endpoints. You'll need to create two endpoints:
-
Address Search Endpoint (
/wp-json/your-plugin/v1/address-search
)- Accepts: query string, country code, address type
- Returns: Array of suggestions with IDs and labels
-
Address Details Endpoint (
/wp-json/your-plugin/v1/address-details
)- Accepts: Address/place ID
- Returns: Complete address components
For implementation details, refer to the WordPress REST API Handbook.
Troubleshooting
Common Issues
-
Provider not appearing in checkout
- Verify the provider is registered on the server
- Check that JavaScript file is loading
- Ensure provider ID matches between PHP and JavaScript
-
Suggestions not showing
- Check browser console for JavaScript errors
- Verify API endpoints are accessible
- Check that country is supported by provider
- Ensure search query is at least 3 characters
-
Fields not populating on selection
- Verify
select
method returns correct field names - Check that address data matches WooCommerce field structure
- Verify