TopUpController.php 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Requests\TopUp\StoreTopUpRequest;
  4. use App\Http\Requests\TopUp\UpdateTopUpRequest;
  5. use App\Models\Member;
  6. use App\Models\TopUp;
  7. use App\Models\TypeMember;
  8. use Inertia\Inertia;
  9. class TopUpController extends Controller
  10. {
  11. /**
  12. * Display a listing of the resource.
  13. *
  14. * @return \Inertia\Response
  15. */
  16. public function index()
  17. {
  18. return inertia('topup/Index', [
  19. 'filters' => request()->all('startDate', 'endDate', 'search'),
  20. 'topUp' => TopUp::filter(request()->only('startDate', 'endDate', 'search'))
  21. ->latest()
  22. ->paginate(10)
  23. ->withQueryString()
  24. ->through(fn($topUp) => [
  25. 'updatedAt' => $topUp->updated_at,
  26. 'name' => $topUp->member->name,
  27. 'phone' => $topUp->member->phone,
  28. 'platNumber' => $topUp->member->plat_number,
  29. 'balance' => $topUp->balance,
  30. 'expDate' => $topUp->exp_date,
  31. ]),
  32. ]);
  33. }
  34. /**
  35. * Show the form for creating a new resource.
  36. *
  37. * @return \Inertia\Response
  38. */
  39. public function create()
  40. {
  41. return inertia('topup/Create', [
  42. 'typeMembers' => TypeMember::get()->transform(fn($typeMember) => [
  43. 'label' => $typeMember->type,
  44. 'value' => $typeMember->id,
  45. ]),
  46. 'members' => Inertia::lazy(
  47. fn() => Member::filter(request()->only('search'))->latest()->get()->transform(fn($member) => [
  48. 'id' => $member->id,
  49. 'name' => $member->name,
  50. 'phone' => $member->phone,
  51. 'platNumber' => $member->plat_number,
  52. ])
  53. ),
  54. ]);
  55. }
  56. /**
  57. * Store a newly created resource in storage.
  58. *
  59. * @param \Illuminate\Http\Request $request
  60. * @return \Illuminate\Http\Response
  61. */
  62. public function store(StoreTopUpRequest $request)
  63. {
  64. TopUp::create([
  65. 'balance' => $request->balance,
  66. 'exp_date' => $request->exp_date,
  67. 'member_id' => $request->member_id,
  68. 'user_id' => auth()->user()->id,
  69. ]);
  70. return back()->with('success', __('messages.success.store.top_up'));
  71. }
  72. /**
  73. * Display the specified resource.
  74. *
  75. * @param TopUp $topUp
  76. * @return \Inertia\Response
  77. */
  78. public function show(TopUp $topUp)
  79. {
  80. return inertia('topup/Show', [
  81. 'topUp' => [
  82. 'updatedAt' => $topUp->updated_at,
  83. 'name' => $topUp->member->name,
  84. 'phone' => $topUp->member->phone,
  85. 'platNumber' => $topUp->member->plat_number,
  86. 'balance' => $topUp->balance,
  87. 'expDate' => $topUp->exp_date,
  88. 'user' => [
  89. 'name' => $topUp->user->name,
  90. 'phone' => $topUp->user->phone,
  91. 'email' => $topUp->user->email,
  92. ],
  93. ],
  94. ]);
  95. }
  96. /**
  97. * Show the form for editing the specified resource.
  98. *
  99. * @param TopUp $topUp
  100. * @return \Inertia\Response
  101. */
  102. public function edit(TopUp $topUp)
  103. {
  104. return inertia('topup/Index', [
  105. 'topUp' => [
  106. 'balance' => $topUp->balance,
  107. 'exp_date' => $topUp->balance,
  108. ],
  109. ]);
  110. }
  111. /**
  112. * Update the specified resource in storage.
  113. *
  114. * @param \Illuminate\Http\Request $request
  115. * @param TopUp $topUp
  116. * @return \Illuminate\Http\Response
  117. */
  118. public function update(UpdateTopUpRequest $request, TopUp $topUp)
  119. {
  120. $topUp->update($request->validated());
  121. return back()->with('success', __('messages.success.update.top_up'));
  122. }
  123. /**
  124. * Remove the specified resource from storage.
  125. *
  126. * @param TopUp $topUp
  127. * @return \Illuminate\Http\Response
  128. */
  129. public function destroy(TopUp $topUp)
  130. {
  131. $topUp->delete();
  132. return to_route('users.index')->with('success', __('messages.success.destroy.top_up'));
  133. }
  134. }