mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-07 13:41:23 +00:00
Fix aggregates for customers using withSum() (SQL-portable, no DB mode tweaks) (#486)
* Update CustomersController.php Fix: replace GROUP BY + SUM join with withSum() to avoid ONLY_FULL_GROUP_BY; no API changes (same aliases) * Update CustomersController.php style: apply Laravel Pint formatting
This commit is contained in:
@@ -8,7 +8,6 @@ use App\Http\Requests\DeleteCustomersRequest;
|
||||
use App\Http\Resources\CustomerResource;
|
||||
use App\Models\Customer;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class CustomersController extends Controller
|
||||
{
|
||||
@@ -26,13 +25,8 @@ class CustomersController extends Controller
|
||||
$customers = Customer::with('creator')
|
||||
->whereCompany()
|
||||
->applyFilters($request->all())
|
||||
->select(
|
||||
'customers.*',
|
||||
DB::raw('sum(invoices.base_due_amount) as base_due_amount'),
|
||||
DB::raw('sum(invoices.due_amount) as due_amount'),
|
||||
)
|
||||
->groupBy('customers.id')
|
||||
->leftJoin('invoices', 'customers.id', '=', 'invoices.customer_id')
|
||||
->withSum('invoices as base_due_amount', 'base_due_amount')
|
||||
->withSum('invoices as due_amount', 'due_amount')
|
||||
->paginateData($limit);
|
||||
|
||||
return CustomerResource::collection($customers)
|
||||
|
||||
Reference in New Issue
Block a user