MOON
Server: Apache
System: Linux server.royaltuning.hu 4.18.0-425.13.1.el8_7.x86_64 #1 SMP Tue Feb 21 04:20:52 EST 2023 x86_64
User: royaltuning (1001)
PHP: 8.2.30
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //usr/local/apache/htdocs/Modules/Report/CustomersOrderReport.php
<?php

namespace Modules\Report;

use Modules\Order\Entities\Order;

class CustomersOrderReport extends Report
{
    protected function view()
    {
        return 'report::admin.reports.customers_order_report.index';
    }

    protected function query()
    {
        return Order::select('customer_id', 'customer_first_name', 'customer_last_name', 'customer_email')
            ->selectRaw('MIN(orders.created_at) as start_date')
            ->selectRaw('MAX(orders.created_at) as end_date')
            ->selectRaw('COUNT(*) as total_orders')
            ->join('order_products', 'orders.id', '=', 'order_products.order_id')
            ->selectRaw('SUM(order_products.qty) as total_products')
            ->selectRaw('SUM(orders.total) as total')
            ->when(request()->has('customer_name'), function ($query) {
                $query->where('customer_first_name', 'like', request('customer_name') . '%')
                    ->orWhere('customer_last_name', 'like', request('customer_name') . '%');
            })
            ->when(request()->has('customer_email'), function ($query) {
                $query->where('customer_email', request('customer_email'));
            })
            ->groupBy([
                'orders.id',
                'customer_id',
                'customer_first_name',
                'customer_last_name',
                'customer_email',
            ]);
    }
}