namespace Automattic\WooCommerce\Blocks\Domain\Services;
use Automattic\WooCommerce\Blocks\Package;
use Automattic\WooCommerce\Blocks\Assets\Api as AssetApi;
* Service class to integrate Blocks with the Google Analytics extension,
* Instance of the asset API.
* @param AssetApi $asset_api Instance of the asset API.
public function __construct( AssetApi $asset_api ) {
$this->asset_api = $asset_api;
// Require Google Analytics Integration to be activated.
if ( ! class_exists( 'WC_Google_Analytics_Integration', false ) ) {
add_action( 'init', array( $this, 'register_assets' ) );
add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ) );
add_filter( 'script_loader_tag', array( $this, 'async_script_loader_tags' ), 10, 3 );
public function register_assets() {
$this->asset_api->register_script( 'wc-blocks-google-analytics', 'assets/client/blocks/wc-blocks-google-analytics.js', [ 'google-tag-manager' ] );
* Enqueue the Google Tag Manager script if prerequisites are met.
public function enqueue_scripts() {
$settings = $this->get_google_analytics_settings();
$prefix = strstr( strtoupper( $settings['ga_id'] ), '-', true );
// Require tracking to be enabled with a valid GA ID.
if ( ! in_array( $prefix, [ 'G', 'GT' ], true ) ) {
* Filter to disable Google Analytics tracking.
* @internal Matches filter name in GA extension.
* @param boolean $disable_tracking If true, tracking will be disabled.
if ( apply_filters( 'woocommerce_ga_disable_tracking', ! wc_string_to_bool( $settings['ga_event_tracking_enabled'] ) ) ) {
if ( ! wp_script_is( 'google-tag-manager', 'registered' ) ) {
// Using an array with strategies as the final argument to wp_register_script was introduced in WP 6.3.
// WC requires at least 6.3 at the point of adding this, so it's safe to leave in without version checks.
// phpcs:ignore WordPress.WP.EnqueuedResourceParameters.MissingVersion
'https://www.googletagmanager.com/gtag/js?id=' . $settings['ga_id'],
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('config', '" . esc_js( $settings['ga_id'] ) . "', { 'send_page_view': false });"
wp_enqueue_script( 'wc-blocks-google-analytics' );
* Get settings from the GA integration extension.
private function get_google_analytics_settings() {
get_option( 'woocommerce_google_analytics_settings' ),
'ga_event_tracking_enabled' => 'no',
* Add async to script tags with defined handles.
* @param string $tag HTML for the script tag.
* @param string $handle Handle of script.
* @param string $src Src of script.
public function async_script_loader_tags( $tag, $handle, $src ) {
if ( ! in_array( $handle, array( 'google-tag-manager' ), true ) ) {
// If script was output manually in wp_head, abort.
if ( did_action( 'woocommerce_gtag_snippet' ) ) {
return str_replace( '<script src', '<script async src', $tag );