ExpenseController.php 2.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Expense;
  4. use App\Models\Outlet;
  5. use Illuminate\Http\Request;
  6. class ExpenseController extends Controller
  7. {
  8. /**
  9. * Display a listing of the resource.
  10. *
  11. * @return \Inertia\Response
  12. */
  13. public function index()
  14. {
  15. return inertia('expense/Index', [
  16. 'filters' => request()->all('dates', 'outlet'),
  17. 'expenses' => Expense::latest()
  18. ->filter(request()->only('dates', 'outlet'))
  19. ->paginate(10)
  20. ->withQueryString()
  21. ->through(fn($expense) => [
  22. 'id' => $expense->id,
  23. 'createdAt' => $expense->created_at,
  24. 'amount' => $expense->amount,
  25. 'outlet' => $expense->outlet->name,
  26. 'user' => $expense->user->name,
  27. 'description' => $expense->description,
  28. ]),
  29. 'outlets' => Outlet::all()
  30. ->transform(fn($outlet) => [
  31. 'label' => $outlet->name,
  32. 'value' => $outlet->id,
  33. ]),
  34. ]);
  35. }
  36. /**
  37. * Show the form for creating a new resource.
  38. *
  39. * @return \Illuminate\Http\Response
  40. */
  41. public function create()
  42. {
  43. return inertia('expense/Create');
  44. }
  45. /**
  46. * Store a newly created resource in storage.
  47. *
  48. * @param \Illuminate\Http\Request $request
  49. * @return \Illuminate\Http\Response
  50. */
  51. public function store(Request $request)
  52. {
  53. dd($request);
  54. }
  55. /**
  56. * Display the specified resource.
  57. *
  58. * @param int $id
  59. * @return \Illuminate\Http\Response
  60. */
  61. public function show($id)
  62. {
  63. //
  64. }
  65. /**
  66. * Show the form for editing the specified resource.
  67. *
  68. * @param int $id
  69. * @return \Illuminate\Http\Response
  70. */
  71. public function edit($id)
  72. {
  73. //
  74. }
  75. /**
  76. * Update the specified resource in storage.
  77. *
  78. * @param \Illuminate\Http\Request $request
  79. * @param int $id
  80. * @return \Illuminate\Http\Response
  81. */
  82. public function update(Request $request, $id)
  83. {
  84. //
  85. }
  86. /**
  87. * Remove the specified resource from storage.
  88. *
  89. * @param int $id
  90. * @return \Illuminate\Http\Response
  91. */
  92. public function destroy($id)
  93. {
  94. //
  95. }
  96. }