Track the complete customer journey from first click to conversion with referral and Google Ads attribution data captured in your WordPress forms.
Form Attribution Tracking is a WordPress plugin that automatically captures and stores complete attribution data from Google Ads campaigns (and other traffic sources) directly in form submissions. This enables you to connect specific leads back to their originating campaigns, keywords, and ads in Google Ads for accurate conversion tracking and ROI measurement.
The plugin uses first-touch attribution, meaning it captures the visitor’s original traffic source on their first visit and maintains that data through their entire journey until they convert via a form submission.
Automatically captures 8 attribution fields for every form submission:
The Google Click ID (GCLID) field enables you to:
– Import conversions directly back into Google Ads
– Connect form submissions to specific ad clicks
– Measure true campaign ROI based on actual leads/sales
– Track the complete path from ad click to conversion
– Attribute conversions to the exact keyword and ad that drove them
Works seamlessly with:
– Gravity Forms
– Fluent Forms
– Formidable Forms
Modular architecture makes it easy to extend to other form plugins.
Visitor Arrives – When someone visits your site, the JavaScript tracking code immediately captures:
Attribution Stored – All data is packaged as JSON and stored in a first-party cookie with your configured expiration (default 30 days)
First-Touch Persistence – If the visitor returns multiple times before converting, the original attribution data is preserved (not overwritten)
Form Submission – When the visitor fills out a form, the tracking code automatically:
PHP Fallback – If JavaScript fails to populate fields, the PHP integration captures attribution server-side before form processing
To enable conversion imports in Google Ads:
This creates a closed feedback loop between your ad spend and actual business results.
Access settings via Form Attribution Tracking Settings:
Use the Manage Forms tab to:
– View all forms and their attribution tracking status
– Bulk-add attribution fields to all existing forms with one click
– See which forms already have tracking enabled
The Statistics tab provides:
– Total submissions tracked across all forms
– Breakdown of traffic sources (Google, Facebook, Direct, etc.)
– Recent form submissions with their attribution data
– Forms-with-tracking count
Once installed and configured, the plugin works automatically. Every form submission will include complete attribution data that you can:
The plugin exposes a global API for programmatic access:
`javascript
// Get full attribution data object
const attribution = window.FormAttributionTracking.getAttributionData();
// Returns: { utm_source, utm_medium, utm_campaign, utm_term, utm_content, gclid, landing_page, timestamp }
// Get just the traffic source (legacy method)
const source = window.FormAttributionTracking.getReferralSource();
// Manually trigger form field population
window.FormAttributionTracking.populateFormFields();
// Access configuration
const config = window.FormAttributionTracking.config;
`
Listen for when attribution data is populated:
`javascript
window.addEventListener(‘attributionDataPopulated’, function(event) {
console.log(‘Attribution captured:’, event.detail.attribution);
console.log(‘Fields populated:’, event.detail.fieldsCount);
});
`
Extend or customize the plugin:
`php
// Add custom form plugin integration
add_filter(‘attribution_tracking_integrations’, function($integrations) {
$integrations[‘CustomForms’] = new CustomFormsIntegration();
return $integrations;
});
// React to integration initialization
add_action(‘attribution_tracking_integration_initialized’, function($integration_name) {
error_log(“Attribution tracking initialized for: ” . $integration_name);
});
// Hook into debug logging
add_action(‘form_referral_source_debug_log’, function($message, $context, $source) {
error_log(“[$source] $message: ” . print_r($context, true));
}, 10, 3);
`
The plugin creates these hidden fields in your forms:
attribution_source – Traffic source identifierattribution_medium – Marketing mediumattribution_campaign – Campaign nameattribution_term – Keyword/search termattribution_content – Ad content variationattribution_gclid – Google Ads Click IDattribution_landing_page – First page visitedattribution_timestamp – ISO 8601 timestamp of first visitAll fields are automatically populated by JavaScript and have PHP fallbacks.
The plugin intelligently categorizes traffic sources:
If UTM parameters are present in the URL, they are captured exactly as provided.
The plugin recognizes and categorizes referrers from:
– Google (google.com, google.co.uk, etc.)
– Facebook (facebook.com, fb.com, m.facebook.com)
– Twitter/X (twitter.com, x.com, t.co)
– LinkedIn (linkedin.com, lnkd.in)
– YouTube (youtube.com, youtu.be)
– Instagram (instagram.com)
– TikTok (tiktok.com)
– Pinterest (pinterest.com, pin.it)
– Reddit (reddit.com)
– Bing (bing.com)
– Yahoo (yahoo.com)
– DuckDuckGo (duckduckgo.com)
For unlisted referrers, the clean hostname is stored (e.g., “example.com”)
When no referrer or UTM parameters are present, traffic is marked as “direct”
Create a new integration class:
`php
<?php
namespace FormAttributionTracking\Integrations;
use FormAttributionTracking\Abstracts\AbstractFormIntegration;
class CustomFormPluginIntegration extends AbstractFormIntegration
{
public function isAvailable(): bool {
return class_exists(‘CustomFormPlugin’);
}
public function getName(): string {
return 'Custom Form Plugin';
}
public function getVersion(): string {
return '1.0.0';
}
protected function registerHooks(): void {
// Hook into your form plugin's save/render events
add_action('custom_form_save', [$this, 'onFormSaved'], 10, 2);
}
public function addReferralSourceField(int $formId): bool {
// Implement logic to add hidden fields to forms
}
public function removeReferralSourceField(int $formId): bool {
// Implement logic to remove hidden fields
}
public function hasReferralSourceField(int $formId): bool {
// Check if form has attribution fields
}
public function getAllForms(): array {
// Return array of all forms
}
}
`
Register your integration:
`php
add_filter(‘attribution_tracking_integrations’, function($integrations) {
$integrations[‘CustomFormPlugin’] = new CustomFormPluginIntegration();
return $integrations;
});
`
The plugin uses a clean, modern PHP 8+ architecture:
`
src/
├── Contracts/
│ └── FormIntegrationInterface.php # Interface all integrations must implement
├── Abstracts/
│ └── AbstractFormIntegration.php # Base class with common functionality
├── Integrations/
│ ├── GravityFormsIntegration.php # Gravity Forms support
│ ├── FluentFormsIntegration.php # Fluent Forms support
│ └── FormidableFormsIntegration.php # Formidable Forms support
├── Views/
│ └── admin-page.php # Admin dashboard template
└── Plugin.php # Main plugin orchestration class
`
This plugin stores first-party cookies to maintain attribution data. Consider these compliance aspects:
For bug reports, feature requests, or contributions:
This plugin is licensed under the GPL v2 or later.