ExpenseController.php 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Expense\StoreExpenseRequest;
  5. use App\Models\Expense;
  6. use Illuminate\Database\QueryException;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Facades\DB;
  9. use Inertia\Inertia;
  10. class ExpenseController extends Controller
  11. {
  12. /**
  13. * Display a listing of the resource.
  14. *
  15. * @return \Inertia\Response
  16. */
  17. public function index()
  18. {
  19. return inertia('expense/Index', [
  20. 'filters' => request()->all('startDate', 'endDate', 'outlet'),
  21. 'expenses' => Expense::filter(request()->only('startDate', 'endDate', 'outlet'))
  22. ->latest()
  23. ->paginate(10)
  24. ->withQueryString()
  25. ->through(fn($expense) => [
  26. 'id' => $expense->id,
  27. 'createdAt' => $expense->created_at,
  28. 'amount' => $expense->amount,
  29. 'user' => $expense->user->name,
  30. ]),
  31. ]);
  32. }
  33. /**
  34. * Show the form for creating a new resource.
  35. *
  36. * @return \Illuminate\Http\Response
  37. */
  38. public function create()
  39. {
  40. return inertia('expense/Create');
  41. }
  42. /**
  43. * Store a newly created resource in storage.
  44. *
  45. * @param \Illuminate\Http\Request $request
  46. * @return \Illuminate\Http\Response
  47. */
  48. public function store(StoreExpenseRequest $request)
  49. {
  50. DB::beginTransaction();
  51. try {
  52. $expense = Expense::create([
  53. 'description' => $request->description,
  54. 'amount' => $request->amount,
  55. 'user_id' => $request->user()->id,
  56. ]);
  57. $expense->mutation()->create([
  58. 'type' => 2,
  59. 'amount' => $expense->getRawOriginal('amount'),
  60. ]);
  61. DB::commit();
  62. return back()->with('success', __('messages.success.store.expense'));
  63. } catch (QueryException $e) {
  64. DB::rollBack();
  65. return back()->with('error', __('messages.error.store.expense'));
  66. }
  67. }
  68. /**
  69. * Display the specified resource.
  70. *
  71. * @param Expense $expense
  72. * @return \Inertia\Response
  73. */
  74. public function show(Expense $expense)
  75. {
  76. return inertia('expense/Show', [
  77. 'expense' => [
  78. 'created_at' => $expense->created_at,
  79. 'amount' => $expense->amount,
  80. 'description' => $expense->description,
  81. 'user' => [
  82. 'name' => $expense->user->name,
  83. 'phone' => $expense->user->phone,
  84. 'email' => $expense->user->email,
  85. ],
  86. ],
  87. ]);
  88. }
  89. /**
  90. * Show the form for editing the specified resource.
  91. *
  92. * @param int $id
  93. * @return \Illuminate\Http\Response
  94. */
  95. public function edit($id)
  96. {
  97. //
  98. }
  99. /**
  100. * Update the specified resource in storage.
  101. *
  102. * @param \Illuminate\Http\Request $request
  103. * @param int $id
  104. * @return \Illuminate\Http\Response
  105. */
  106. public function update(Request $request, $id)
  107. {
  108. //
  109. }
  110. /**
  111. * Remove the specified resource from storage.
  112. *
  113. * @param int $id
  114. * @return \Illuminate\Http\Response
  115. */
  116. public function destroy($id)
  117. {
  118. //
  119. }
  120. }