ExpenseController.php 3.8KB

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