Site Performance Tracker
This WordPress plugin sends Core Web Vitals data to Google Analytics. It is compatible with Web Vitals Report
Installation
This plugin can be installed as a Composer dependency:
composer require xwp/site-performance-tracker
or by downloading a plugin ZIP file from the releases page.
Usage
The plugin must be configured by setting the site_performance_tracker_vitals
theme feature with your Analytics IDs. Collected data will be available in Web Vitals Report in a few days.
To send Web Vitals metrics to Google Analytics in a format compatible with the Web Vitals Report, enable the following theme support and passing in the ID:
GA4 Analytics is supported, requires passing the ID using ga4_id
:
add_theme_support( 'site_performance_tracker_vitals', array(
'ga4_id' => 'G-XXXXXXXXXX',
) );
The following hooks can be added to a theme or a custom plugin to configure the plugin, alternatively you can configure the plugin through the settings screen, in case of duplication, plugin will take programmatically set settings. To confirm they were applied look for the webVitalsAnalyticsData
global variable in the page source.
Limit the number of events sent
The following filter can be used to limit the number of tracking events to a percentage of your traffic. For example, to limit the tracking events to 5% of requests, use the following logic:
add_filter( 'site_performance_tracker_chance', function() {
return 0.05;
} );
Disable the tracking
Programmatically disable the plugin.
add_filter( 'site_performance_tracker_disabled', '__return_true' );
Delay script loading
Programmatically delay web vitals tracking to minimise impact on interactivity. By default, an idle callback request is postponed by 5000ms, a value which can be adjusted via a filter:
add_filter( 'site_performance_tracker_web_vitals_delay', function() {
return 1000;
} );
Contribute
All contributions are welcome! Please create an issue for bugs and feature requests, and use pull requests for code contributions.
Project Setup
-
We use wp-env
for local development environment. See all the env:*
scripts in package.json
for supported commands and helpers.
-
webpack.config.js
configures how @wordpress/scripts
transforms JS and CSS assets during packaging.
-
We use the @wordpress/eslint-plugin/recommended-with-formatting
ruleset for JS linting since the Prettier integration is currently unreliable in @wordpress/scripts
.
Changelog
1.3.5 - Jul 28th, 2023
- Add tracking support for Google Tag Manager setup GA4 with window.dataLayer.
1.3.4 - Jul 15th, 2023
- Fix bug in INP reporting when some attributions were empty.
1.3.3 - Jun 26th, 2023
- Deprecated GA3 support.
- Used attribution build of web vitals.
1.3.2 - October 30th, 2023
- Improved admin interface for GA4.
- Bumped up build process to use Node 16.
1.3.1 - July 18th, 2023
- Updated GA4 Settings.
- Added WP-Rocket exclusion to web-vitals-analytics.
- Cleaned up/refactored settings code.
1.3 - February 24th, 2023
- Added INP metric.
- Support for smaller web vitals ratio.
1.2 - December 5, 2022
1.1.7 - July 5, 2022
1.1.6 - May 18, 2022
- Fix GA not tracking bug when using the UI.
1.1.5 - March 17, 2022
1.1.4 - March 10, 2022
- Improve performance by loading and executing the script in quiter periods.
- Make chunk hash a part of the output filename.
1.1.3 - March 9, 2022
- Fix UI to prefill configured data.
1.1.2 - March 4, 2022
- Fix duplicated page view when using gtag.
1.1.1 - March 3, 2022
- Fix duplicitous page views when using gtag.
- Fix PHP notices.
1.1.0 - January 6, 2022
- Introduces an UI in WordPress Admin for easier configuration. If any config parameters are set in the theme files, the UI will not allow changing those parameters.
1.0.0 - October 4, 2021
- Update docs to start the "Usage" section with the required configuration for the plugin to do anything.
- Switch to basic PHP includes for loading the PHP files instead of Composer autoload.
- Introduce helper methods for working with asset paths and URLs.
- Introduce VIP Go coding standards.
- Introduce PHP unit testing.
0.9.1 - July 9, 2021
0.9 - June 16, 2021
- Update web vitals JS library to 2.0.1
0.8 - May 28, 2021
- Remove Performance Observer functionality
- Code cleanup
0.7 - May 26, 2021
- Add support for Google Analytics 4.
0.6 - May 25, 2021
- Fix Google Analytics support.
- Code cleanup - remove unused metric and dimension.
0.5 - April 13, 2021
- Feature: Add support for sending data in the web vitals report format.
0.3.1 - March 11, 2020
- Feature: Add support to Analytics added through Google Tag Managere.
0.3.0 - March 11, 2020
- Feature: Track 'first-delay' of over 100ms.
0.2.0 - February 22, 2019
- Make autoload.php optional to support project-wide autoload.
- Add an action
xwp/performance_tracker/render_mark
as an alternative way for adding
performance marks in the front-end.
- Bugfix: Use proper JS escaping (as per WordPress VIP review).
0.1.1 - February 18, 2019
- The plugin is no longer using a singleton pattern. Instead it is just
a regular class that is being instantiated in the main plugin file.
- Namespace has been added.
- The PHP version check has been added (>= 5.3).
- The helper functions are extracted to a separate file and they are now
using static functions inside the class.
- The
$default_entry_types
array is no longer defined as static.
0.1.0 - February 15, 2019
Contribute
Please follow the contribution guide.
Credits
Created by XWP and contributors. Licensed under GNU General Public License v2.0 or later.