<?php

if (!defined('ABSPATH')) {
    exit;
}
class WC_API_Reports extends WC_API_Resource
{
    protected $base = '/reports';
    private $report;
    public function register_routes($routes)
    {
        $routes[$this->base] = array(array(array($this, 'get_reports'), WC_API_Server::READABLE));
        $routes[$this->base . '/sales'] = array(array(array($this, 'get_sales_report'), WC_API_Server::READABLE));
        $routes[$this->base . '/sales/top_sellers'] = array(array(array($this, 'get_top_sellers_report'), WC_API_Server::READABLE));
        return $routes;
    }
    public function get_reports()
    {
        return array('reports' => array('sales', 'sales/top_sellers'));
    }
    public function get_sales_report($fields = null, $filter = array())
    {
        $check = $this->validate_request();
        if (is_wp_error($check)) {
            return $check;
        }
        $this->setup_report($filter);
        $users_query = new WP_User_Query(array('fields' => array('user_registered'), 'role' => 'customer'));
        $customers = $users_query->get_results();
        foreach ($customers as $key => $customer) {
            if (strtotime($customer->user_registered) < $this->report->start_date || strtotime($customer->user_registered) > $this->report->end_date) {
                unset($customers[$key]);
            }
        }
        $total_customers = count($customers);
        $report_data = $this->report->get_report_data();
        $period_totals = array();
        for ($i = 0; $i <= $this->report->chart_interval; $i++) {
            switch ($this->report->chart_groupby) {
                case 'day':
                    $time = date('Y-m-d', strtotime("+{$i} DAY", $this->report->start_date));
                    break;
                default:
                    $time = date('Y-m', strtotime("+{$i} MONTH", $this->report->start_date));
                    break;
            }
            $customer_count = 0;
            foreach ($customers as $customer) {
                if (date('day' == $this->report->chart_groupby ? 'Y-m-d' : 'Y-m', strtotime($customer->user_registered)) == $time) {
                    $customer_count++;
                }
            }
            $period_totals[$time] = array('sales' => wc_format_decimal(0.0, 2), 'orders' => 0, 'items' => 0, 'tax' => wc_format_decimal(0.0, 2), 'shipping' => wc_format_decimal(0.0, 2), 'discount' => wc_format_decimal(0.0, 2), 'customers' => $customer_count);
        }
        foreach ($report_data->orders as $order) {
            $time = 'day' === $this->report->chart_groupby ? date('Y-m-d', strtotime($order->post_date)) : date('Y-m', strtotime($order->post_date));
            if (!isset($period_totals[$time])) {
                continue;
            }
            $period_totals[$time]['sales'] = wc_format_decimal($order->total_sales, 2);
            $period_totals[$time]['tax'] = wc_format_decimal($order->total_tax + $order->total_shipping_tax, 2);
            $period_totals[$time]['shipping'] = wc_format_decimal($order->total_shipping, 2);
        }
        foreach ($report_data->order_counts as $order) {
            $time = 'day' === $this->report->chart_groupby ? date('Y-m-d', strtotime($order->post_date)) : date('Y-m', strtotime($order->post_date));
            if (!isset($period_totals[$time])) {
                continue;
            }
            $period_totals[$time]['orders'] = (int) $order->count;
        }
        foreach ($report_data->order_items as $order_item) {
            $time = 'day' === $this->report->chart_groupby ? date('Y-m-d', strtotime($order_item->post_date)) : date('Y-m', strtotime($order_item->post_date));
            if (!isset($period_totals[$time])) {
                continue;
            }
            $period_totals[$time]['items'] = (int) $order_item->order_item_count;
        }
        foreach ($report_data->coupons as $discount) {
            $time = 'day' === $this->report->chart_groupby ? date('Y-m-d', strtotime($discount->post_date)) : date('Y-m', strtotime($discount->post_date));
            if (!isset($period_totals[$time])) {
                continue;
            }
            $period_totals[$time]['discount'] = wc_format_decimal($discount->discount_amount, 2);
        }
        $sales_data = array('total_sales' => $report_data->total_sales, 'net_sales' => $report_data->net_sales, 'average_sales' => $report_data->average_sales, 'total_orders' => $report_data->total_orders, 'total_items' => $report_data->total_items, 'total_tax' => wc_format_decimal($report_data->total_tax + $report_data->total_shipping_tax, 2), 'total_shipping' => $report_data->total_shipping, 'total_refunds' => $report_data->total_refunds, 'total_discount' => $report_data->total_coupons, 'totals_grouped_by' => $this->report->chart_groupby, 'totals' => $period_totals, 'total_customers' => $total_customers);
        return array('sales' => apply_filters('woocommerce_api_report_response', $sales_data, $this->report, $fields, $this->server));
    }
    public function get_top_sellers_report($fields = null, $filter = array())
    {
        $check = $this->validate_request();
        if (is_wp_error($check)) {
            return $check;
        }
        $this->setup_report($filter);
        $top_sellers = $this->report->get_order_report_data(array('data' => array('_product_id' => array('type' => 'order_item_meta', 'order_item_type' => 'line_item', 'function' => '', 'name' => 'product_id'), '_qty' => array('type' => 'order_item_meta', 'order_item_type' => 'line_item', 'function' => 'SUM', 'name' => 'order_item_qty')), 'order_by' => 'order_item_qty DESC', 'group_by' => 'product_id', 'limit' => isset($filter['limit']) ? absint($filter['limit']) : 12, 'query_type' => 'get_results', 'filter_range' => true));
        $top_sellers_data = array();
        foreach ($top_sellers as $top_seller) {
            $product = wc_get_product($top_seller->product_id);
            if ($product) {
                $top_sellers_data[] = array('title' => $product->get_name(), 'product_id' => $top_seller->product_id, 'quantity' => $top_seller->order_item_qty);
            }
        }
        return array('top_sellers' => apply_filters('woocommerce_api_report_response', $top_sellers_data, $this->report, $fields, $this->server));
    }
    private function setup_report($filter)
    {
        include_once WC()->plugin_path() . '/includes/admin/reports/class-wc-admin-report.php';
        include_once WC()->plugin_path() . '/includes/admin/reports/class-wc-report-sales-by-date.php';
        $this->report = new WC_Report_Sales_By_Date();
        if (empty($filter['period'])) {
            $filter['period'] = 'custom';
            if (!empty($filter['date_min']) || !empty($filter['date_max'])) {
                $_GET['start_date'] = $this->server->parse_datetime($filter['date_min']);
                $_GET['end_date'] = isset($filter['date_max']) ? $this->server->parse_datetime($filter['date_max']) : null;
            } else {
                $_GET['start_date'] = $_GET['end_date'] = date('Y-m-d', current_time('timestamp'));
            }
        } else {
            if (!in_array($filter['period'], array('week', 'month', 'last_month', 'year'))) {
                $filter['period'] = 'week';
            }
            if ('week' === $filter['period']) {
                $filter['period'] = '7day';
            }
        }
        $this->report->calculate_current_range($filter['period']);
    }
    protected function validate_request($id = null, $type = null, $context = null)
    {
        if (!current_user_can('view_woocommerce_reports')) {
            return new WP_Error('woocommerce_api_user_cannot_read_report', __('You do not have permission to read this report', 'woocommerce'), array('status' => 401));
        } else {
            return true;
        }
    }
}