only('startDate', 'endDate', 'outlet')) ->get() ->groupBy('created_at') ->transform(fn($transactions) => [[ 'date' => $transactions->first()->getRawOriginal('created_at'), 'createdAt' => $transactions->first()->created_at, 'totalTransaction' => $transactions->count(), 'totalPrice' => (new TransactionService)->totalPriceGroupAsString($transactions), ]]) ->flatten(1) ->toArray(); $transaction = (new TransactionService)->getPaginator($transactions); return inertia('transaction/Report', [ 'filters' => request()->all('startDate', 'endDate', 'outlet'), 'transactions' => $transaction, 'outlets' => Outlet::all() ->transform(fn($outlet) => [ 'label' => $outlet->name, 'value' => $outlet->id, ]), ]); } /** * Export to excel */ public function exportExcel() { return new TransactionExport(request()); } }