woocommerce/includes/tracks/class-wc-site-tracking.php

101 lines
2.2 KiB
PHP
Raw Normal View History

2019-02-01 01:26:38 +00:00
<?php
/**
* Nosara Tracks for WooCommerce
*
* @package WooCommerce\Tracks
*/
defined( 'ABSPATH' ) || exit;
/**
* This class adds actions to track usage of WooCommerce.
*/
class WC_Site_Tracking {
/**
* Send a Tracks event when a product is updated.
*
* @param int $product_id Product id.
* @param array $post WordPress post.
*/
public static function tracks_product_updated( $product_id, $post ) {
if ( 'product' !== $post->post_type ) {
return;
}
$properties = array(
'product_id' => $product_id,
);
WC_Tracks::record_event( 'product_edit', $properties );
2019-02-01 01:26:38 +00:00
}
/**
* Check if tracking is enabled.
*
* @return bool
*/
public static function is_tracking_enabled() {
/**
* Don't track users who haven't opted-in to tracking or if a filter
* has been applied to turn it off.
*/
if ( 'yes' !== get_option( 'woocommerce_allow_tracking' ) ||
! apply_filters( 'woocommerce_apply_user_tracking', true ) ) {
return false;
}
if ( ! class_exists( 'WC_Tracks' ) ) {
return false;
}
return true;
}
2019-02-01 01:26:38 +00:00
/**
* Add scripts required to record events from javascript.
*/
public static function enqueue_scripts() {
// Add w.js to the page.
wp_enqueue_script( 'woo-tracks', 'https://stats.wp.com/w.js', array(), gmdate( 'YW' ), true );
// Expose tracking via a function in the wcTracks global namespace.
wc_enqueue_js(
"
window.wcTracks = window.wcTracks || {};
window.wcTracks.recordEvent = function( name, properties ) {
var eventName = '" . WC_Tracks::PREFIX . "' + name;
var eventProperties = properties || {};
eventProperties.url = '" . home_url() . "'
window._tkq = window._tkq || [];
window._tkq.push( [ 'recordEvent', eventName, eventProperties ] );
}
"
);
}
2019-02-01 01:26:38 +00:00
/**
* Init tracking.
*/
public static function init() {
2019-02-01 01:26:38 +00:00
2019-02-01 01:26:38 +00:00
if ( ! self::is_tracking_enabled() ) {
2019-02-01 01:26:38 +00:00
// Define window.wcTracks.recordEvent in case there is an attempt to use it when tracking is turned off.
wc_enqueue_js(
'
window.wcTracks = window.wcTracks || {};
window.wcTracks.recordEvent = function() {};
'
);
2019-02-01 01:26:38 +00:00
return;
}
2019-02-01 01:26:38 +00:00
self::enqueue_scripts();
2019-02-01 01:26:38 +00:00
add_action( 'edit_post', array( 'WC_Site_Tracking', 'tracks_product_updated' ), 10, 2 );
}
}