ReportTransactionController.php 1.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Exports\TransactionExport;
  4. use App\Models\Outlet;
  5. use App\Models\Transaction;
  6. use App\Services\TransactionService;
  7. use Inertia\Controller;
  8. use Inertia\Inertia;
  9. class ReportTransactionController extends Controller
  10. {
  11. /**
  12. * Display a listing of the resource.
  13. *
  14. * @return \Inertia\Response
  15. */
  16. public function index()
  17. {
  18. $transactions = Transaction::filter(request()->only('startDate', 'endDate', 'outlet'))
  19. ->get()
  20. ->groupBy('created_at')
  21. ->transform(fn($transactions) => [[
  22. 'date' => $transactions->first()->getRawOriginal('created_at'),
  23. 'createdAt' => $transactions->first()->created_at,
  24. 'totalTransaction' => $transactions->count(),
  25. 'totalPrice' => (new TransactionService)->totalPriceGroupAsString($transactions),
  26. ]])
  27. ->flatten(1)
  28. ->toArray();
  29. $transaction = (new TransactionService)->getPaginator($transactions);
  30. return inertia('transaction/Report', [
  31. 'filters' => request()->all('startDate', 'endDate', 'outlet'),
  32. 'transactions' => Inertia::lazy(
  33. fn() => $transaction
  34. ),
  35. 'outlets' => Outlet::all()
  36. ->transform(fn($outlet) => [
  37. 'label' => $outlet->name,
  38. 'value' => $outlet->id,
  39. ]),
  40. ]);
  41. }
  42. /**
  43. * Export to excel
  44. */
  45. public function exportExcel()
  46. {
  47. return new TransactionExport(request());
  48. }
  49. }