59 lines
1.7 KiB
PHP
59 lines
1.7 KiB
PHP
<?php
|
|
/**
|
|
* WooCommerce Orders Tracking
|
|
*
|
|
* @package WooCommerce\Tracks
|
|
*/
|
|
|
|
defined( 'ABSPATH' ) || exit;
|
|
|
|
/**
|
|
* This class adds actions to track usage of WooCommerce Orders.
|
|
*/
|
|
class WC_Orders_Tracking {
|
|
/**
|
|
* Init tracking.
|
|
*/
|
|
public function init() {
|
|
add_action( 'woocommerce_order_status_changed', array( $this, 'track_order_status_change' ), 10, 3 );
|
|
add_action( 'load-edit.php', array( $this, 'track_orders_view' ), 10 );
|
|
}
|
|
|
|
/**
|
|
* Send a Tracks event when the Orders page is viewed.
|
|
*/
|
|
public function track_orders_view() {
|
|
if ( isset( $_GET['post_type'] ) && 'shop_order' === wp_unslash( $_GET['post_type'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.NoNonceVerification, WordPress.Security.ValidatedSanitizedInput.InputNotSanitized
|
|
|
|
// phpcs:disable WordPress.Security.NonceVerification.NoNonceVerification, WordPress.Security.ValidatedSanitizedInput
|
|
$properties = array(
|
|
'status' => isset( $_GET['post_status'] ) ? sanitize_text_field( $_GET['post_status'] ) : 'all',
|
|
);
|
|
// phpcs:enable
|
|
|
|
WC_Tracks::record_event( 'orders_view', $properties );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Send a Tracks event when an order status is changed.
|
|
*
|
|
* @param int $id Order id.
|
|
* @param string $previous_status the old WooCommerce order status.
|
|
* @param string $next_status the new WooCommerce order status.
|
|
*/
|
|
public function track_order_status_change( $id, $previous_status, $next_status ) {
|
|
$order = wc_get_order( $id );
|
|
$date = $order->get_date_created();
|
|
|
|
$properties = array(
|
|
'order_id' => $id,
|
|
'next_status' => $next_status,
|
|
'previous_status' => $previous_status,
|
|
'date_created' => $date->date( 'Y-m-d' ),
|
|
);
|
|
|
|
WC_Tracks::record_event( 'orders_edit_status_change', $properties );
|
|
}
|
|
}
|