MemberController.php 4.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Requests\Member\StoreMemberRequest;
  4. use App\Http\Requests\Member\UpdateMemberRequest;
  5. use App\Models\Member;
  6. use App\Models\TypeMember;
  7. use App\Models\TypeVehicle;
  8. use Inertia\Inertia;
  9. class MemberController 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('member/Index', [
  19. 'filters' => request()->all('search'),
  20. 'members' => Member::filter(request()->only('search'))
  21. ->latest()
  22. ->paginate(10)
  23. ->withQueryString()
  24. ->through(fn($member) => [
  25. 'id' => $member->id,
  26. 'updatedAt' => $member->updated_at,
  27. 'name' => $member->name,
  28. 'phone' => $member->phone,
  29. 'platNumber' => $member->plat_number,
  30. 'type' => $member->typeMember->type,
  31. 'price' => $member->typeMember->price,
  32. ]),
  33. ]);
  34. }
  35. /**
  36. * Show the form for creating a new resource.
  37. *
  38. * @return \Inertia\Response
  39. */
  40. public function create()
  41. {
  42. return inertia('member/Create', [
  43. 'typeMembers' => TypeMember::get()->transform(fn($typeMember) => [
  44. 'label' => $typeMember->type,
  45. 'value' => $typeMember->id,
  46. ]),
  47. 'typeVehicles' => TypeVehicle::get()->transform(fn($typeVehicle) => [
  48. 'label' => $typeVehicle->type,
  49. 'value' => $typeVehicle->id,
  50. ]),
  51. 'typeMember' => Inertia::lazy(
  52. fn() => TypeMember::filter(request('id'))->get()->transform(fn($typeMember) => [
  53. 'type' => $typeMember->type,
  54. 'description' => $typeMember->description,
  55. 'price' => $typeMember->price,
  56. 'max' => $typeMember->max,
  57. ])->first()
  58. ),
  59. ]);
  60. }
  61. /**
  62. * Store a newly created resource in storage.
  63. *
  64. * @param \Illuminate\Http\Request $request
  65. * @return \Illuminate\Http\Response
  66. */
  67. public function store(StoreMemberRequest $request)
  68. {
  69. dd(request());
  70. $member = Member::create([
  71. 'name' => $request->name,
  72. 'phone' => $request->phone,
  73. 'exp_date' => now()->addDays(30),
  74. 'type_member_id' => $request->type_member_id,
  75. ]);
  76. $member->topUps()->create([
  77. 'amount' => TypeMember::find($request->type_member_id)->getRawOriginal('price'),
  78. 'exp_date' => now()->addDays(30),
  79. 'user_id' => auth()->user()->id,
  80. ]);
  81. foreach ($request->vehicles as $vehicle) {
  82. $member->vehicles()->create([
  83. 'plat_number' => $vehicle['platNumber'],
  84. 'type_vehicle_id' => $vehicle['typeVehicleId'],
  85. ]);
  86. }
  87. return back()->with('success', __('messages.success.store.member'));
  88. }
  89. /**
  90. * Display the specified resource.
  91. *
  92. * @param Member $member
  93. * @return \Inertia\Response
  94. */
  95. public function show(Member $member)
  96. {
  97. //
  98. }
  99. /**
  100. * Show the form for editing the specified resource.
  101. *
  102. * @param Member $member
  103. * @return \Inertia\Response
  104. */
  105. public function edit(Member $member)
  106. {
  107. return inertia('member/Edit', [
  108. 'member' => [
  109. 'id' => $member->id,
  110. 'name' => $member->name,
  111. 'phone' => $member->phone,
  112. 'plat_number' => $member->plat_number,
  113. 'type_member_id' => $member->type_member_id,
  114. ],
  115. 'typeMembers' => TypeMember::get()->transform(fn($typeMember) => [
  116. 'label' => $typeMember->type,
  117. 'value' => $typeMember->id,
  118. ]),
  119. ]);
  120. }
  121. /**
  122. * Update the specified resource in storage.
  123. *
  124. * @param \Illuminate\Http\Request $request
  125. * @param Member $member
  126. * @return \Illuminate\Http\Response
  127. */
  128. public function update(UpdateMemberRequest $request, Member $member)
  129. {
  130. $member->update($request->validated());
  131. return back()->with('success', __('messages.success.update.member'));
  132. }
  133. /**
  134. * Remove the specified resource from storage.
  135. *
  136. * @param Member $member
  137. * @return \Illuminate\Http\Response
  138. */
  139. public function destroy($member)
  140. {
  141. $member->delete();
  142. return to_route('members.index')->with('success', __('messages.success.destroy.member'));
  143. }
  144. }