2013-06-26 14:11:33 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2014-02-14 13:02:37 +00:00
|
|
|
* WC_Report_Sales_By_Date
|
|
|
|
*
|
2014-08-31 07:19:13 +00:00
|
|
|
* @author WooThemes
|
|
|
|
* @category Admin
|
|
|
|
* @package WooCommerce/Admin/Reports
|
2014-02-14 13:02:37 +00:00
|
|
|
* @version 2.1.0
|
2013-06-26 14:11:33 +00:00
|
|
|
*/
|
|
|
|
class WC_Report_Sales_By_Date extends WC_Admin_Report {
|
|
|
|
|
2014-02-12 12:26:32 +00:00
|
|
|
public $chart_colours = array();
|
2015-02-13 21:25:59 +00:00
|
|
|
private $report_data;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get report data
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function get_report_data() {
|
|
|
|
if ( empty( $this->report_data ) ) {
|
|
|
|
$this->query_report_data();
|
|
|
|
}
|
|
|
|
return $this->report_data;
|
|
|
|
}
|
2014-08-31 07:19:13 +00:00
|
|
|
|
2013-06-26 14:11:33 +00:00
|
|
|
/**
|
2015-02-13 13:40:30 +00:00
|
|
|
* Get all data needed for this report and store in the class
|
2013-06-26 14:11:33 +00:00
|
|
|
*/
|
2015-02-13 13:40:30 +00:00
|
|
|
private function query_report_data() {
|
2015-02-13 21:25:59 +00:00
|
|
|
$this->report_data = new stdClass;
|
2013-06-26 14:11:33 +00:00
|
|
|
|
2015-02-13 21:25:59 +00:00
|
|
|
$this->report_data->orders = (array) $this->get_order_report_data( array(
|
2014-07-24 14:55:06 +00:00
|
|
|
'data' => array(
|
2015-02-13 13:40:30 +00:00
|
|
|
'_order_total' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_sales'
|
|
|
|
),
|
|
|
|
'_order_shipping' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_shipping'
|
|
|
|
),
|
|
|
|
'_order_tax' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_tax'
|
|
|
|
),
|
|
|
|
'_order_shipping_tax' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_shipping_tax'
|
|
|
|
),
|
|
|
|
'post_date' => array(
|
2014-07-24 14:55:06 +00:00
|
|
|
'type' => 'post_data',
|
2015-02-13 13:40:30 +00:00
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
|
|
|
),
|
2014-07-24 14:55:06 +00:00
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
|
|
|
'filter_range' => true,
|
2015-04-24 14:58:13 +00:00
|
|
|
'order_types' => wc_get_order_types( 'sales-reports' ),
|
|
|
|
'order_status' => array( 'completed', 'processing', 'on-hold', 'refunded' )
|
|
|
|
) );
|
|
|
|
|
|
|
|
$this->report_data->refunded_orders = (array) $this->get_order_report_data( array(
|
|
|
|
'data' => array(
|
|
|
|
'_order_total' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_sales'
|
|
|
|
),
|
|
|
|
'_order_shipping' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_shipping'
|
|
|
|
),
|
|
|
|
'_order_tax' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_tax'
|
|
|
|
),
|
|
|
|
'_order_shipping_tax' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'total_shipping_tax'
|
|
|
|
),
|
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
|
|
|
),
|
|
|
|
'ID' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => 'COUNT',
|
|
|
|
'name' => 'count',
|
|
|
|
'distinct' => true,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
|
|
|
'filter_range' => true,
|
|
|
|
'order_types' => wc_get_order_types( 'sales-reports' ),
|
|
|
|
'order_status' => array( 'refunded' )
|
2015-02-13 13:40:30 +00:00
|
|
|
) );
|
2014-08-31 07:19:13 +00:00
|
|
|
|
2015-02-13 21:25:59 +00:00
|
|
|
$this->report_data->order_counts = (array) $this->get_order_report_data( array(
|
2013-06-26 14:11:33 +00:00
|
|
|
'data' => array(
|
2015-02-13 13:40:30 +00:00
|
|
|
'ID' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => 'COUNT',
|
|
|
|
'name' => 'count',
|
|
|
|
'distinct' => true,
|
|
|
|
),
|
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
2013-06-26 14:11:33 +00:00
|
|
|
)
|
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
|
|
|
'filter_range' => true,
|
|
|
|
'order_types' => wc_get_order_types( 'order-count' ),
|
2015-04-24 14:58:13 +00:00
|
|
|
'order_status' => array( 'completed', 'processing', 'on-hold', 'refunded' )
|
2015-02-13 13:40:30 +00:00
|
|
|
) );
|
2014-08-31 07:19:13 +00:00
|
|
|
|
2015-02-13 21:25:59 +00:00
|
|
|
$this->report_data->coupons = (array) $this->get_order_report_data( array(
|
2013-06-28 16:33:37 +00:00
|
|
|
'data' => array(
|
2015-02-13 13:40:30 +00:00
|
|
|
'order_item_name' => array(
|
|
|
|
'type' => 'order_item',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'order_item_name'
|
|
|
|
),
|
2013-06-28 16:33:37 +00:00
|
|
|
'discount_amount' => array(
|
|
|
|
'type' => 'order_item_meta',
|
|
|
|
'order_item_type' => 'coupon',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'discount_amount'
|
2015-02-13 13:40:30 +00:00
|
|
|
),
|
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
|
|
|
),
|
2013-06-28 16:33:37 +00:00
|
|
|
),
|
|
|
|
'where' => array(
|
|
|
|
array(
|
2014-04-08 14:46:55 +00:00
|
|
|
'key' => 'order_items.order_item_type',
|
2013-06-28 16:33:37 +00:00
|
|
|
'value' => 'coupon',
|
|
|
|
'operator' => '='
|
|
|
|
)
|
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'group_by' => $this->group_by_query . ', order_item_name',
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
2014-10-14 15:39:57 +00:00
|
|
|
'filter_range' => true,
|
2015-02-13 13:40:30 +00:00
|
|
|
'order_types' => wc_get_order_types( 'order-count' ),
|
2015-04-24 14:58:13 +00:00
|
|
|
'order_status' => array( 'completed', 'processing', 'on-hold', 'refunded' )
|
2013-06-28 16:33:37 +00:00
|
|
|
) );
|
2015-01-06 13:27:44 +00:00
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
$this->report_data->refunds = (array) $this->get_order_report_data( array(
|
|
|
|
'data' => array(
|
|
|
|
'_refund_amount' => array(
|
|
|
|
'type' => 'meta',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'total_refund'
|
|
|
|
),
|
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
|
|
|
),
|
|
|
|
'_qty' => array(
|
|
|
|
'type' => 'order_item_meta',
|
|
|
|
'order_item_type' => 'line_item',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'order_item_count',
|
|
|
|
'join_type' => 'LEFT'
|
|
|
|
)
|
|
|
|
),
|
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
|
|
|
'filter_range' => true,
|
|
|
|
'order_status' => false,
|
|
|
|
'parent_order_status' => array( 'completed', 'processing', 'on-hold', 'refunded' ),
|
|
|
|
) );
|
|
|
|
|
|
|
|
foreach( $this->report_data->refunds as $key => $value ) {
|
|
|
|
$this->report_data->refunds[ $key ]->order_item_count = $this->report_data->refunds[ $key ]->order_item_count * -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// All items from orders - even those refunded
|
2015-02-13 21:25:59 +00:00
|
|
|
$this->report_data->order_items = (array) $this->get_order_report_data( array(
|
2015-01-06 13:27:44 +00:00
|
|
|
'data' => array(
|
2015-02-13 13:40:30 +00:00
|
|
|
'_qty' => array(
|
|
|
|
'type' => 'order_item_meta',
|
|
|
|
'order_item_type' => 'line_item',
|
|
|
|
'function' => 'SUM',
|
|
|
|
'name' => 'order_item_count'
|
2015-01-06 13:27:44 +00:00
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
2015-01-06 13:27:44 +00:00
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
),
|
|
|
|
'where' => array(
|
|
|
|
array(
|
|
|
|
'key' => 'order_items.order_item_type',
|
|
|
|
'value' => 'line_item',
|
|
|
|
'operator' => '='
|
|
|
|
)
|
|
|
|
),
|
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
|
|
|
'filter_range' => true,
|
|
|
|
'order_types' => wc_get_order_types( 'order-count' ),
|
2015-04-24 14:58:13 +00:00
|
|
|
'order_status' => array( 'completed', 'processing', 'on-hold', 'refunded' ),
|
2015-02-13 13:40:30 +00:00
|
|
|
) );
|
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// All items from FULLY refunded orders for the time period
|
2015-02-13 21:25:59 +00:00
|
|
|
$this->report_data->refunded_order_items = (array) $this->get_order_report_data( array(
|
2015-02-13 13:40:30 +00:00
|
|
|
'data' => array(
|
|
|
|
'_qty' => array(
|
|
|
|
'type' => 'order_item_meta',
|
|
|
|
'order_item_type' => 'line_item',
|
|
|
|
'function' => 'SUM',
|
2015-04-24 14:58:13 +00:00
|
|
|
'name' => 'order_item_count',
|
|
|
|
'join_type' => 'LEFT'
|
2015-01-06 13:27:44 +00:00
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
|
|
|
),
|
|
|
|
),
|
|
|
|
'where' => array(
|
|
|
|
array(
|
|
|
|
'key' => 'order_items.order_item_type',
|
|
|
|
'value' => 'line_item',
|
|
|
|
'operator' => '='
|
2015-01-06 13:27:44 +00:00
|
|
|
)
|
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
|
|
|
'filter_range' => true,
|
|
|
|
'order_types' => wc_get_order_types( 'order-count' ),
|
|
|
|
'order_status' => array( 'refunded' ),
|
2015-01-06 13:27:44 +00:00
|
|
|
) );
|
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// All partially refunded items
|
|
|
|
$this->report_data->partially_refunded_order_items = (array) $this->get_order_report_data( array(
|
2014-10-02 03:35:34 +00:00
|
|
|
'data' => array(
|
2015-02-13 13:40:30 +00:00
|
|
|
'post_date' => array(
|
|
|
|
'type' => 'post_data',
|
|
|
|
'function' => '',
|
|
|
|
'name' => 'post_date'
|
|
|
|
),
|
|
|
|
'_qty' => array(
|
|
|
|
'type' => 'order_item_meta',
|
|
|
|
'order_item_type' => 'line_item',
|
|
|
|
'function' => 'SUM',
|
2015-04-24 14:58:13 +00:00
|
|
|
'name' => 'order_item_count'
|
2014-10-02 03:35:34 +00:00
|
|
|
)
|
|
|
|
),
|
2015-02-13 13:40:30 +00:00
|
|
|
'group_by' => $this->group_by_query,
|
|
|
|
'order_by' => 'post_date ASC',
|
|
|
|
'query_type' => 'get_results',
|
2014-10-14 15:39:57 +00:00
|
|
|
'filter_range' => true,
|
|
|
|
'order_status' => false,
|
|
|
|
'parent_order_status' => array( 'completed', 'processing', 'on-hold' ),
|
|
|
|
) );
|
2015-01-06 13:27:44 +00:00
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// Combine partial and full refund item quantities
|
|
|
|
$this->report_data->refunded_order_items = array_merge( $this->report_data->refunded_order_items, $this->report_data->partially_refunded_order_items );
|
2015-02-13 13:40:30 +00:00
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// Totals from only refunded orders
|
|
|
|
$this->report_data->total_tax_refunded = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->refunded_orders, 'total_tax' ) ), 2 );
|
|
|
|
$this->report_data->total_shipping_refunded = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->refunded_orders, 'total_shipping' ) ), 2 );
|
|
|
|
$this->report_data->total_shipping_tax_refunded = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->refunded_orders, 'total_shipping_tax' ) ), 2 );
|
2015-02-13 13:40:30 +00:00
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// Totals from all orders - including those refunded. Subtract refunded amounts.
|
|
|
|
$this->report_data->total_tax = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->orders, 'total_tax' ) ) - $this->report_data->total_tax_refunded, 2 );
|
|
|
|
$this->report_data->total_shipping = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->orders, 'total_shipping' ) ) - $this->report_data->total_shipping_refunded, 2 );
|
|
|
|
$this->report_data->total_shipping_tax = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->orders, 'total_shipping_tax' ) ) - $this->report_data->total_shipping_tax_refunded, 2 );
|
2015-02-13 13:40:30 +00:00
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// Total the refunds and sales amounts. Sales subract refunds.
|
|
|
|
$this->report_data->total_refunds = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->refunds, 'total_refund' ) ), 2 );
|
|
|
|
$this->report_data->total_sales = wc_format_decimal( array_sum( wp_list_pluck( $this->report_data->orders, 'total_sales' ) ) - $this->report_data->total_refunds, 2 );
|
|
|
|
$this->report_data->net_sales = wc_format_decimal( $this->report_data->total_sales - $this->report_data->total_shipping - $this->report_data->total_tax - $this->report_data->total_shipping_tax, 2 );
|
|
|
|
|
|
|
|
// Calculate average based on net
|
|
|
|
$this->report_data->average_sales = wc_format_decimal( $this->report_data->net_sales / ( $this->chart_interval + 1 ), 2 );
|
|
|
|
|
|
|
|
// Total orders and discounts also includes those which have been refunded at some point
|
|
|
|
$this->report_data->total_orders = absint( array_sum( wp_list_pluck( $this->report_data->order_counts, 'count' ) ) );
|
|
|
|
$this->report_data->total_coupons = number_format( array_sum( wp_list_pluck( $this->report_data->coupons, 'discount_amount' ) ), 2 );
|
|
|
|
$this->report_data->total_refunded_orders = absint( array_sum( wp_list_pluck( $this->report_data->refunded_orders, 'count' ) ) );
|
2014-10-02 03:35:34 +00:00
|
|
|
|
2015-04-24 14:58:13 +00:00
|
|
|
// Item counts
|
|
|
|
$this->report_data->total_item_refunds = array_sum( wp_list_pluck( $this->report_data->refunded_order_items, 'order_item_count' ) );
|
|
|
|
$this->report_data->total_items = absint( array_sum( wp_list_pluck( $this->report_data->order_items, 'order_item_count' ) ) );
|
2015-02-13 13:40:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the legend for the main chart sidebar
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function get_chart_legend() {
|
2015-02-13 21:25:59 +00:00
|
|
|
$legend = array();
|
|
|
|
$data = $this->get_report_data();
|
2013-06-26 14:11:33 +00:00
|
|
|
|
|
|
|
switch ( $this->chart_groupby ) {
|
|
|
|
case 'day' :
|
2015-02-13 21:25:59 +00:00
|
|
|
$average_sales_title = sprintf( __( '%s average daily sales', 'woocommerce' ), '<strong>' . wc_price( $data->average_sales ) . '</strong>' );
|
2013-06-26 14:11:33 +00:00
|
|
|
break;
|
|
|
|
case 'month' :
|
2015-01-20 13:50:25 +00:00
|
|
|
default :
|
2015-02-13 21:25:59 +00:00
|
|
|
$average_sales_title = sprintf( __( '%s average monthly sales', 'woocommerce' ), '<strong>' . wc_price( $data->average_sales ) . '</strong>' );
|
2013-06-26 14:11:33 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$legend[] = array(
|
2015-02-13 21:25:59 +00:00
|
|
|
'title' => sprintf( __( '%s gross sales in this period', 'woocommerce' ), '<strong>' . wc_price( $data->total_sales ) . '</strong>' ),
|
2015-02-13 13:40:30 +00:00
|
|
|
'placeholder' => __( 'This is the sum of the order totals after any refunds and including shipping and taxes.', 'woocommerce' ),
|
2014-11-24 15:18:41 +00:00
|
|
|
'color' => $this->chart_colours['sales_amount'],
|
2014-10-02 03:35:34 +00:00
|
|
|
'highlight_series' => 6
|
2013-06-26 14:11:33 +00:00
|
|
|
);
|
2015-01-06 13:27:44 +00:00
|
|
|
$legend[] = array(
|
2015-02-13 21:25:59 +00:00
|
|
|
'title' => sprintf( __( '%s net sales in this period', 'woocommerce' ), '<strong>' . wc_price( $data->net_sales ) . '</strong>' ),
|
2015-02-18 17:19:10 +00:00
|
|
|
'placeholder' => __( 'This is the sum of the order totals after any refunds and excluding shipping and taxes.', 'woocommerce' ),
|
2015-01-06 13:27:44 +00:00
|
|
|
'color' => $this->chart_colours['net_sales_amount'],
|
|
|
|
'highlight_series' => 7
|
|
|
|
);
|
2015-04-24 14:58:13 +00:00
|
|
|
if ( $data->average_sales > 0 ) {
|
|
|
|
$legend[] = array(
|
|
|
|
'title' => $average_sales_title,
|
|
|
|
'color' => $this->chart_colours['average'],
|
|
|
|
'highlight_series' => 2
|
|
|
|
);
|
|
|
|
}
|
2013-06-26 14:11:33 +00:00
|
|
|
$legend[] = array(
|
2015-04-24 14:58:13 +00:00
|
|
|
'title' => sprintf( __( '%s orders placed', 'woocommerce' ), '<strong>' . $data->total_orders . '</strong>' ),
|
2013-07-18 08:20:49 +00:00
|
|
|
'color' => $this->chart_colours['order_count'],
|
|
|
|
'highlight_series' => 1
|
2013-06-26 14:11:33 +00:00
|
|
|
);
|
2015-02-13 13:40:30 +00:00
|
|
|
|
2013-06-26 14:11:33 +00:00
|
|
|
$legend[] = array(
|
2015-04-24 14:58:13 +00:00
|
|
|
'title' => sprintf( __( '%s items purchased', 'woocommerce' ), '<strong>' . $data->total_items . '</strong>' ),
|
2013-07-18 08:20:49 +00:00
|
|
|
'color' => $this->chart_colours['item_count'],
|
|
|
|
'highlight_series' => 0
|
2013-06-26 14:11:33 +00:00
|
|
|
);
|
2015-02-13 13:40:30 +00:00
|
|
|
|
2014-10-06 12:39:49 +00:00
|
|
|
$legend[] = array(
|
2015-02-13 21:25:59 +00:00
|
|
|
'title' => sprintf( __( '%s charged for shipping', 'woocommerce' ), '<strong>' . wc_price( $data->total_shipping ) . '</strong>' ),
|
2014-10-06 12:39:49 +00:00
|
|
|
'color' => $this->chart_colours['shipping_amount'],
|
|
|
|
'highlight_series' => 5
|
|
|
|
);
|
2015-01-06 13:27:44 +00:00
|
|
|
$legend[] = array(
|
2015-04-24 14:58:13 +00:00
|
|
|
'title' => sprintf( _n( '%s refunded %d order', '%s refunded %d orders', $this->report_data->total_refunded_orders, 'woocommerce' ), '<strong>' . wc_price( $data->total_refunds ) . '</strong>', $this->report_data->total_refunded_orders ) . ' (' . sprintf( _n( '%d item', '%d items', $this->report_data->total_item_refunds, 'woocommerce' ), $this->report_data->total_item_refunds ) . ')',
|
2015-01-06 13:27:44 +00:00
|
|
|
'color' => $this->chart_colours['refund_amount'],
|
|
|
|
'highlight_series' => 4
|
|
|
|
);
|
2013-06-28 16:33:37 +00:00
|
|
|
$legend[] = array(
|
2015-02-13 21:25:59 +00:00
|
|
|
'title' => sprintf( __( '%s worth of coupons used', 'woocommerce' ), '<strong>' . wc_price( $data->total_coupons ) . '</strong>' ),
|
2013-07-18 08:20:49 +00:00
|
|
|
'color' => $this->chart_colours['coupon_amount'],
|
|
|
|
'highlight_series' => 3
|
2013-06-28 16:33:37 +00:00
|
|
|
);
|
2013-06-26 14:11:33 +00:00
|
|
|
|
|
|
|
return $legend;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output the report
|
|
|
|
*/
|
|
|
|
public function output_report() {
|
|
|
|
$ranges = array(
|
|
|
|
'year' => __( 'Year', 'woocommerce' ),
|
|
|
|
'last_month' => __( 'Last Month', 'woocommerce' ),
|
|
|
|
'month' => __( 'This Month', 'woocommerce' ),
|
|
|
|
'7day' => __( 'Last 7 Days', 'woocommerce' )
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->chart_colours = array(
|
2015-01-06 13:27:44 +00:00
|
|
|
'sales_amount' => '#b1d4ea',
|
|
|
|
'net_sales_amount' => '#3498db',
|
|
|
|
'average' => '#95a5a6',
|
|
|
|
'order_count' => '#dbe1e3',
|
|
|
|
'item_count' => '#ecf0f1',
|
|
|
|
'shipping_amount' => '#5cc488',
|
|
|
|
'coupon_amount' => '#f1c40f',
|
|
|
|
'refund_amount' => '#e74c3c'
|
2013-06-26 14:11:33 +00:00
|
|
|
);
|
|
|
|
|
2014-09-16 09:33:47 +00:00
|
|
|
$current_range = ! empty( $_GET['range'] ) ? sanitize_text_field( $_GET['range'] ) : '7day';
|
2013-06-26 14:11:33 +00:00
|
|
|
|
2014-08-31 07:19:13 +00:00
|
|
|
if ( ! in_array( $current_range, array( 'custom', 'year', 'last_month', 'month', '7day' ) ) ) {
|
2013-07-30 10:12:42 +00:00
|
|
|
$current_range = '7day';
|
2014-08-31 07:19:13 +00:00
|
|
|
}
|
2013-06-26 14:11:33 +00:00
|
|
|
|
2013-07-30 10:12:42 +00:00
|
|
|
$this->calculate_current_range( $current_range );
|
2013-06-26 14:11:33 +00:00
|
|
|
|
2013-07-24 16:01:36 +00:00
|
|
|
include( WC()->plugin_path() . '/includes/admin/views/html-report-by-date.php');
|
2013-06-26 14:11:33 +00:00
|
|
|
}
|
|
|
|
|
2013-07-18 11:56:12 +00:00
|
|
|
/**
|
|
|
|
* Output an export link
|
|
|
|
*/
|
|
|
|
public function get_export_button() {
|
2014-09-16 09:33:47 +00:00
|
|
|
$current_range = ! empty( $_GET['range'] ) ? sanitize_text_field( $_GET['range'] ) : '7day';
|
2013-07-18 11:56:12 +00:00
|
|
|
?>
|
|
|
|
<a
|
|
|
|
href="#"
|
2014-09-16 09:33:47 +00:00
|
|
|
download="report-<?php echo esc_attr( $current_range ); ?>-<?php echo date_i18n( 'Y-m-d', current_time('timestamp') ); ?>.csv"
|
2013-07-18 11:56:12 +00:00
|
|
|
class="export_csv"
|
|
|
|
data-export="chart"
|
|
|
|
data-xaxes="<?php _e( 'Date', 'woocommerce' ); ?>"
|
|
|
|
data-exclude_series="2"
|
|
|
|
data-groupby="<?php echo $this->chart_groupby; ?>"
|
|
|
|
>
|
|
|
|
<?php _e( 'Export CSV', 'woocommerce' ); ?>
|
|
|
|
</a>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
|
2015-02-20 12:27:55 +00:00
|
|
|
/**
|
|
|
|
* Round our totals correctly
|
|
|
|
* @param string $amount
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
private function round_chart_totals( $amount ) {
|
|
|
|
if ( is_array( $amount ) ) {
|
2015-05-05 12:55:56 +00:00
|
|
|
return array( $amount[0], wc_format_decimal( $amount[1], wc_get_price_decimals() ) );
|
2015-02-20 12:27:55 +00:00
|
|
|
} else {
|
|
|
|
return wc_format_decimal( $amount, wc_get_price_decimals() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-26 14:11:33 +00:00
|
|
|
/**
|
|
|
|
* Get the main chart
|
2014-08-31 07:19:13 +00:00
|
|
|
*
|
2013-06-26 14:11:33 +00:00
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function get_main_chart() {
|
|
|
|
global $wp_locale;
|
|
|
|
|
|
|
|
// Prepare data for report
|
2015-02-13 21:25:59 +00:00
|
|
|
$order_counts = $this->prepare_chart_data( $this->report_data->order_counts, 'post_date', 'count', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$order_item_counts = $this->prepare_chart_data( $this->report_data->order_items, 'post_date', 'order_item_count', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$order_amounts = $this->prepare_chart_data( $this->report_data->orders, 'post_date', 'total_sales', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$coupon_amounts = $this->prepare_chart_data( $this->report_data->coupons, 'post_date', 'discount_amount', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$shipping_amounts = $this->prepare_chart_data( $this->report_data->orders, 'post_date', 'total_shipping', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$refund_amounts = $this->prepare_chart_data( $this->report_data->refunds, 'post_date', 'total_refund', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$shipping_tax_amounts = $this->prepare_chart_data( $this->report_data->orders, 'post_date', 'total_shipping_tax', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
|
|
|
$tax_amounts = $this->prepare_chart_data( $this->report_data->orders, 'post_date', 'total_tax', $this->chart_interval, $this->start_date, $this->chart_groupby );
|
2015-01-06 13:27:44 +00:00
|
|
|
|
2015-01-14 11:28:00 +00:00
|
|
|
$net_order_amounts = array();
|
|
|
|
|
2015-01-06 13:27:44 +00:00
|
|
|
foreach ( $order_amounts as $order_amount_key => $order_amount_value ) {
|
|
|
|
$net_order_amounts[ $order_amount_key ] = $order_amount_value;
|
|
|
|
$net_order_amounts[ $order_amount_key ][1] = $net_order_amounts[ $order_amount_key ][1] - $shipping_amounts[ $order_amount_key ][1] - $shipping_tax_amounts[ $order_amount_key ][1] - $tax_amounts[ $order_amount_key ][1];
|
|
|
|
}
|
2014-10-02 03:35:34 +00:00
|
|
|
|
2013-06-26 14:11:33 +00:00
|
|
|
// Encode in json format
|
|
|
|
$chart_data = json_encode( array(
|
|
|
|
'order_counts' => array_values( $order_counts ),
|
|
|
|
'order_item_counts' => array_values( $order_item_counts ),
|
2015-02-20 12:27:55 +00:00
|
|
|
'order_amounts' => array_map( array( $this, 'round_chart_totals' ), array_values( $order_amounts ) ),
|
|
|
|
'net_order_amounts' => array_map( array( $this, 'round_chart_totals' ), array_values( $net_order_amounts ) ),
|
|
|
|
'shipping_amounts' => array_map( array( $this, 'round_chart_totals' ), array_values( $shipping_amounts ) ),
|
|
|
|
'coupon_amounts' => array_map( array( $this, 'round_chart_totals' ), array_values( $coupon_amounts ) ),
|
|
|
|
'refund_amounts' => array_map( array( $this, 'round_chart_totals' ), array_values( $refund_amounts ) )
|
2013-06-26 14:11:33 +00:00
|
|
|
) );
|
|
|
|
?>
|
|
|
|
<div class="chart-container">
|
|
|
|
<div class="chart-placeholder main"></div>
|
|
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
2013-07-18 11:56:12 +00:00
|
|
|
|
|
|
|
var main_chart;
|
|
|
|
|
2013-06-26 14:11:33 +00:00
|
|
|
jQuery(function(){
|
|
|
|
var order_data = jQuery.parseJSON( '<?php echo $chart_data; ?>' );
|
2013-07-18 08:20:49 +00:00
|
|
|
var drawGraph = function( highlight ) {
|
|
|
|
var series = [
|
2013-06-26 14:11:33 +00:00
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Number of items sold', 'woocommerce' ) ) ?>",
|
|
|
|
data: order_data.order_item_counts,
|
|
|
|
color: '<?php echo $this->chart_colours['item_count']; ?>',
|
|
|
|
bars: { fillColor: '<?php echo $this->chart_colours['item_count']; ?>', fill: true, show: true, lineWidth: 0, barWidth: <?php echo $this->barwidth; ?> * 0.5, align: 'center' },
|
|
|
|
shadowSize: 0,
|
|
|
|
hoverable: false
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Number of orders', 'woocommerce' ) ) ?>",
|
|
|
|
data: order_data.order_counts,
|
|
|
|
color: '<?php echo $this->chart_colours['order_count']; ?>',
|
|
|
|
bars: { fillColor: '<?php echo $this->chart_colours['order_count']; ?>', fill: true, show: true, lineWidth: 0, barWidth: <?php echo $this->barwidth; ?> * 0.5, align: 'center' },
|
|
|
|
shadowSize: 0,
|
|
|
|
hoverable: false
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Average sales amount', 'woocommerce' ) ) ?>",
|
2015-02-13 21:25:59 +00:00
|
|
|
data: [ [ <?php echo min( array_keys( $order_amounts ) ); ?>, <?php echo $this->report_data->average_sales; ?> ], [ <?php echo max( array_keys( $order_amounts ) ); ?>, <?php echo $this->report_data->average_sales; ?> ] ],
|
2013-06-26 14:11:33 +00:00
|
|
|
yaxis: 2,
|
|
|
|
color: '<?php echo $this->chart_colours['average']; ?>',
|
|
|
|
points: { show: false },
|
2013-06-28 16:33:37 +00:00
|
|
|
lines: { show: true, lineWidth: 2, fill: false },
|
2013-06-26 14:11:33 +00:00
|
|
|
shadowSize: 0,
|
|
|
|
hoverable: false
|
|
|
|
},
|
2013-06-28 16:33:37 +00:00
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Coupon amount', 'woocommerce' ) ) ?>",
|
|
|
|
data: order_data.coupon_amounts,
|
|
|
|
yaxis: 2,
|
|
|
|
color: '<?php echo $this->chart_colours['coupon_amount']; ?>',
|
2015-01-06 13:27:44 +00:00
|
|
|
points: { show: true, radius: 5, lineWidth: 2, fillColor: '#fff', fill: true },
|
|
|
|
lines: { show: true, lineWidth: 2, fill: false },
|
2013-06-28 16:33:37 +00:00
|
|
|
shadowSize: 0,
|
2014-09-19 07:23:58 +00:00
|
|
|
<?php echo $this->get_currency_tooltip(); ?>
|
2013-06-28 16:33:37 +00:00
|
|
|
},
|
2014-10-02 03:35:34 +00:00
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Refund amount', 'woocommerce' ) ) ?>",
|
|
|
|
data: order_data.refund_amounts,
|
|
|
|
yaxis: 2,
|
|
|
|
color: '<?php echo $this->chart_colours['refund_amount']; ?>',
|
2015-01-06 13:27:44 +00:00
|
|
|
points: { show: true, radius: 5, lineWidth: 2, fillColor: '#fff', fill: true },
|
|
|
|
lines: { show: true, lineWidth: 2, fill: false },
|
2014-10-02 03:35:34 +00:00
|
|
|
shadowSize: 0,
|
|
|
|
prepend_tooltip: "<?php echo get_woocommerce_currency_symbol(); ?>"
|
|
|
|
},
|
2013-06-28 16:33:37 +00:00
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Shipping amount', 'woocommerce' ) ) ?>",
|
|
|
|
data: order_data.shipping_amounts,
|
|
|
|
yaxis: 2,
|
|
|
|
color: '<?php echo $this->chart_colours['shipping_amount']; ?>',
|
2015-01-06 13:27:44 +00:00
|
|
|
points: { show: true, radius: 5, lineWidth: 2, fillColor: '#fff', fill: true },
|
|
|
|
lines: { show: true, lineWidth: 2, fill: false },
|
2013-06-28 16:33:37 +00:00
|
|
|
shadowSize: 0,
|
2015-01-06 13:27:44 +00:00
|
|
|
prepend_tooltip: "<?php echo get_woocommerce_currency_symbol(); ?>"
|
2013-06-28 16:33:37 +00:00
|
|
|
},
|
2013-06-26 14:11:33 +00:00
|
|
|
{
|
2015-01-06 13:27:44 +00:00
|
|
|
label: "<?php echo esc_js( __( 'Gross Sales amount', 'woocommerce' ) ) ?>",
|
2013-06-26 14:11:33 +00:00
|
|
|
data: order_data.order_amounts,
|
|
|
|
yaxis: 2,
|
|
|
|
color: '<?php echo $this->chart_colours['sales_amount']; ?>',
|
2015-01-06 13:27:44 +00:00
|
|
|
points: { show: true, radius: 5, lineWidth: 2, fillColor: '#fff', fill: true },
|
|
|
|
lines: { show: true, lineWidth: 2, fill: false },
|
|
|
|
shadowSize: 0,
|
|
|
|
<?php echo $this->get_currency_tooltip(); ?>
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: "<?php echo esc_js( __( 'Net Sales amount', 'woocommerce' ) ) ?>",
|
|
|
|
data: order_data.net_order_amounts,
|
|
|
|
yaxis: 2,
|
|
|
|
color: '<?php echo $this->chart_colours['net_sales_amount']; ?>',
|
|
|
|
points: { show: true, radius: 6, lineWidth: 4, fillColor: '#fff', fill: true },
|
|
|
|
lines: { show: true, lineWidth: 5, fill: false },
|
2013-06-26 14:11:33 +00:00
|
|
|
shadowSize: 0,
|
2014-09-19 07:23:58 +00:00
|
|
|
<?php echo $this->get_currency_tooltip(); ?>
|
2013-06-26 14:11:33 +00:00
|
|
|
}
|
2013-07-18 08:20:49 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
if ( highlight !== 'undefined' && series[ highlight ] ) {
|
|
|
|
highlight_series = series[ highlight ];
|
|
|
|
|
|
|
|
highlight_series.color = '#9c5d90';
|
|
|
|
|
|
|
|
if ( highlight_series.bars )
|
|
|
|
highlight_series.bars.fillColor = '#9c5d90';
|
|
|
|
|
|
|
|
if ( highlight_series.lines ) {
|
|
|
|
highlight_series.lines.lineWidth = 5;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-18 11:56:12 +00:00
|
|
|
main_chart = jQuery.plot(
|
2013-07-18 08:20:49 +00:00
|
|
|
jQuery('.chart-placeholder.main'),
|
|
|
|
series,
|
|
|
|
{
|
|
|
|
legend: {
|
|
|
|
show: false
|
|
|
|
},
|
2014-08-31 07:19:13 +00:00
|
|
|
grid: {
|
|
|
|
color: '#aaa',
|
|
|
|
borderColor: 'transparent',
|
|
|
|
borderWidth: 0,
|
|
|
|
hoverable: true
|
|
|
|
},
|
|
|
|
xaxes: [ {
|
|
|
|
color: '#aaa',
|
|
|
|
position: "bottom",
|
|
|
|
tickColor: 'transparent',
|
2013-07-18 08:20:49 +00:00
|
|
|
mode: "time",
|
|
|
|
timeformat: "<?php if ( $this->chart_groupby == 'day' ) echo '%d %b'; else echo '%b'; ?>",
|
|
|
|
monthNames: <?php echo json_encode( array_values( $wp_locale->month_abbrev ) ) ?>,
|
|
|
|
tickLength: 1,
|
|
|
|
minTickSize: [1, "<?php echo $this->chart_groupby; ?>"],
|
|
|
|
font: {
|
2014-08-31 07:19:13 +00:00
|
|
|
color: "#aaa"
|
|
|
|
}
|
2013-07-18 08:20:49 +00:00
|
|
|
} ],
|
2014-08-31 07:19:13 +00:00
|
|
|
yaxes: [
|
|
|
|
{
|
|
|
|
min: 0,
|
|
|
|
minTickSize: 1,
|
|
|
|
tickDecimals: 0,
|
|
|
|
color: '#d4d9dc',
|
|
|
|
font: { color: "#aaa" }
|
|
|
|
},
|
|
|
|
{
|
|
|
|
position: "right",
|
|
|
|
min: 0,
|
|
|
|
tickDecimals: 2,
|
|
|
|
alignTicksWithAxis: 1,
|
|
|
|
color: 'transparent',
|
|
|
|
font: { color: "#aaa" }
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
);
|
2013-07-18 08:20:49 +00:00
|
|
|
|
|
|
|
jQuery('.chart-placeholder').resize();
|
|
|
|
}
|
|
|
|
|
|
|
|
drawGraph();
|
2013-06-26 14:11:33 +00:00
|
|
|
|
2013-07-18 08:20:49 +00:00
|
|
|
jQuery('.highlight_series').hover(
|
|
|
|
function() {
|
|
|
|
drawGraph( jQuery(this).data('series') );
|
|
|
|
},
|
|
|
|
function() {
|
|
|
|
drawGraph();
|
|
|
|
}
|
|
|
|
);
|
2013-06-26 14:11:33 +00:00
|
|
|
});
|
|
|
|
</script>
|
|
|
|
<?php
|
|
|
|
}
|
2014-08-31 07:19:13 +00:00
|
|
|
}
|