2013-07-10 11:05:45 +00:00
< ? php
/**
2014-02-14 13:02:37 +00:00
* WC_Report_Taxes_By_Date
*
* @ author WooThemes
* @ category Admin
* @ package WooCommerce / Admin / Reports
* @ version 2.1 . 0
2013-07-10 11:05:45 +00:00
*/
class WC_Report_Taxes_By_Date extends WC_Admin_Report {
/**
* Get the legend for the main chart sidebar
* @ return array
*/
public function get_chart_legend () {
$legend = array ();
return array ();
}
2013-07-18 11:56:12 +00:00
/**
* Output an export link
*/
public function get_export_button () {
$current_range = ! empty ( $_GET [ 'range' ] ) ? $_GET [ 'range' ] : 'last_month' ;
?>
< a
href = " # "
download = " report-<?php echo $current_range ; ?>-<?php echo date_i18n( 'Y-m-d', current_time('timestamp') ); ?>.csv "
class = " export_csv "
data - export = " table "
>
< ? php _e ( 'Export CSV' , 'woocommerce' ); ?>
</ a >
< ? php
}
2013-07-10 11:05:45 +00:00
/**
* Output the report
*/
public function output_report () {
$ranges = array (
'year' => __ ( 'Year' , 'woocommerce' ),
'last_month' => __ ( 'Last Month' , 'woocommerce' ),
'month' => __ ( 'This Month' , 'woocommerce' ),
);
$current_range = ! empty ( $_GET [ 'range' ] ) ? $_GET [ 'range' ] : 'last_month' ;
2013-07-30 10:12:42 +00:00
if ( ! in_array ( $current_range , array ( 'custom' , 'year' , 'last_month' , 'month' , '7day' ) ) )
$current_range = 'last_month' ;
2013-07-10 11:05:45 +00:00
2013-07-30 10:12:42 +00:00
$this -> calculate_current_range ( $current_range );
2013-07-10 11:05:45 +00:00
$hide_sidebar = true ;
2013-07-24 16:01:36 +00:00
include ( WC () -> plugin_path () . '/includes/admin/views/html-report-by-date.php' );
2013-07-10 11:05:45 +00:00
}
/**
* Get the main chart
* @ return string
*/
public function get_main_chart () {
$tax_rows = $this -> get_order_report_data ( array (
'data' => array (
'_order_tax' => array (
'type' => 'meta' ,
'function' => 'SUM' ,
'name' => 'tax_amount'
),
'_order_shipping_tax' => array (
'type' => 'meta' ,
'function' => 'SUM' ,
'name' => 'shipping_tax_amount'
),
'_order_total' => array (
'type' => 'meta' ,
'function' => 'SUM' ,
'name' => 'total_sales'
),
'_order_shipping' => array (
'type' => 'meta' ,
'function' => 'SUM' ,
'name' => 'total_shipping'
),
'ID' => array (
'type' => 'post_data' ,
'function' => 'COUNT' ,
'name' => 'total_orders' ,
'distinct' => true ,
),
'post_date' => array (
'type' => 'post_data' ,
'function' => '' ,
'name' => 'post_date'
),
),
'group_by' => $this -> group_by_query ,
'order_by' => 'post_date ASC' ,
'query_type' => 'get_results' ,
'filter_range' => true
) );
?>
< table class = " widefat " >
< thead >
< tr >
< th >< ? php _e ( 'Period' , 'woocommerce' ); ?> </th>
< th class = " total_row " >< ? php _e ( 'Number of orders' , 'woocommerce' ); ?> </th>
< th class = " total_row " >< ? php _e ( 'Total Sales' , 'woocommerce' ); ?> <a class="tips" data-tip="<?php _e("This is the sum of the 'Order Total' field within your orders.", 'woocommerce'); ?>" href="#">[?]</a></th>
< th class = " total_row " >< ? php _e ( 'Total Shipping' , 'woocommerce' ); ?> <a class="tips" data-tip="<?php _e("This is the sum of the 'Shipping Total' field within your orders.", 'woocommerce'); ?>" href="#">[?]</a></th>
< th class = " total_row " >< ? php _e ( 'Total Tax' , 'woocommerce' ); ?> <a class="tips" data-tip="<?php esc_attr_e( 'This is the total tax for the rate (shipping tax + product tax).', 'woocommerce' ); ?>" href="#">[?]</a></th>
< th class = " total_row " >< ? php _e ( 'Net profit' , 'woocommerce' ); ?> <a class="tips" data-tip="<?php _e("Total sales minus shipping and tax.", 'woocommerce'); ?>" href="#">[?]</a></th>
</ tr >
</ thead >
< ? php if ( $tax_rows ) :
2014-06-17 09:19:40 +00:00
$gross = array_sum ( wp_list_pluck ( ( array ) $tax_rows , 'total_sales' ) ) - array_sum ( wp_list_pluck ( ( array ) $tax_rows , 'total_shipping' ) );
$total_tax = array_sum ( wp_list_pluck ( ( array ) $tax_rows , 'tax_amount' ) ) + array_sum ( wp_list_pluck ( ( array ) $tax_rows , 'shipping_tax_amount' ) );
2013-07-10 11:05:45 +00:00
?>
< tfoot >
< tr >
< th scope = " row " >< ? php _e ( 'Totals' , 'woocommerce' ); ?> </th>
< th class = " total_row " >< ? php echo array_sum ( wp_list_pluck ( ( array ) $tax_rows , 'total_orders' ) ); ?> </th>
2013-11-25 13:34:21 +00:00
< th class = " total_row " >< ? php echo wc_price ( $gross ); ?> </th>
< th class = " total_row " >< ? php echo wc_price ( array_sum ( wp_list_pluck ( ( array ) $tax_rows , 'total_shipping' ) ) ); ?> </th>
< th class = " total_row " >< ? php echo wc_price ( $total_tax ); ?> </th>
< th class = " total_row " >< ? php echo wc_price ( $gross - $total_tax ); ?> </th>
2013-07-10 11:05:45 +00:00
</ tr >
</ tfoot >
< tbody >
< ? php
foreach ( $tax_rows as $tax_row ) {
$gross = $tax_row -> total_sales - $tax_row -> total_shipping ;
$total_tax = $tax_row -> tax_amount + $tax_row -> shipping_tax_amount ;
?>
< tr >
< th scope = " row " >< ? php
if ( $this -> chart_groupby == 'month' )
echo date_i18n ( 'F' , strtotime ( $tax_row -> post_date ) );
else
echo date_i18n ( get_option ( 'date_format' ), strtotime ( $tax_row -> post_date ) );
?> </th>
< td class = " total_row " >< ? php echo $tax_row -> total_orders ; ?> </td>
2013-11-25 13:34:21 +00:00
< td class = " total_row " >< ? php echo wc_price ( $gross ); ?> </td>
< td class = " total_row " >< ? php echo wc_price ( $tax_row -> total_shipping ); ?> </td>
< td class = " total_row " >< ? php echo wc_price ( $total_tax ); ?> </td>
< td class = " total_row " >< ? php echo wc_price ( $gross - $total_tax ); ?> </td>
2013-07-10 11:05:45 +00:00
</ tr >
< ? php
}
?>
</ tbody >
< ? php else : ?>
< tbody >
< tr >
< td >< ? php _e ( 'No taxes found in this period' , 'woocommerce' ); ?> </td>
</ tr >
</ tbody >
< ? php endif ; ?>
</ table >
< ? php
}
}