UserController.php 5.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\User\ChangePasswordRequest;
  5. use App\Http\Requests\User\StoreUserRequest;
  6. use App\Http\Requests\User\UpdateUserRequest;
  7. use App\Models\Role;
  8. use App\Models\User;
  9. use Illuminate\Support\Facades\Hash;
  10. class UserController extends Controller
  11. {
  12. /**
  13. * Create the controller instance.
  14. *
  15. * @return void
  16. */
  17. public function __construct()
  18. {
  19. $this->authorizeResource(User::class);
  20. }
  21. /**
  22. * Display a listing of the resource.
  23. *
  24. * @return \Inertia\Response
  25. */
  26. public function index()
  27. {
  28. return inertia('user/Index', [
  29. 'initialSearch' => request('search'),
  30. 'users' => User::filter(request()->only('search'))
  31. ->latest()
  32. ->paginate(10)
  33. ->withQueryString()
  34. ->through(fn($user) => [
  35. 'id' => $user->id,
  36. 'name' => $user->name,
  37. 'phone' => $user->phone,
  38. 'email' => $user->email,
  39. 'role' => $user->role->name,
  40. 'status' => $user->status,
  41. ]),
  42. ]);
  43. }
  44. /**
  45. * Show the form for creating a new resource.
  46. *
  47. * @return \Inertia\Response
  48. */
  49. public function create()
  50. {
  51. return inertia('user/Create', [
  52. 'roles' => Role::whereNotIn('id', [1])
  53. ->get()
  54. ->transform(fn($role) => [
  55. 'label' => $role->name,
  56. 'value' => $role->id,
  57. ]),
  58. ]);
  59. }
  60. /**
  61. * Store a newly created resource in storage.
  62. *
  63. * @param \Illuminate\Http\Request $request
  64. * @return \Illuminate\Http\Response
  65. */
  66. public function store(StoreUserRequest $request)
  67. {
  68. User::create($request->validated());
  69. return back()->with('success', __('messages.success.store.user'));
  70. }
  71. /**
  72. * Display the specified resource.
  73. *
  74. * @param User $user
  75. * @return \Inertia\Response
  76. */
  77. public function show(User $user)
  78. {
  79. return inertia('user/Show', [
  80. 'user' => [
  81. 'id' => $user->id,
  82. 'name' => $user->name,
  83. 'phone' => $user->phone,
  84. 'email' => $user->email,
  85. 'role_id' => $user->role_id,
  86. ],
  87. 'roles' => Role::whereNotIn('id', [1])
  88. ->get()
  89. ->transform(fn($role) => [
  90. 'label' => $role->name,
  91. 'value' => $role->id,
  92. ]),
  93. ]);
  94. }
  95. /**
  96. * Show the form for editing the specified resource.
  97. *
  98. * @param User $user
  99. * @return \Inertia\Response
  100. */
  101. public function edit(User $user)
  102. {
  103. return inertia('user/Edit', [
  104. 'user' => [
  105. 'id' => $user->id,
  106. 'name' => $user->name,
  107. 'phone' => $user->phone,
  108. 'email' => $user->email,
  109. 'role_id' => $user->role_id,
  110. ],
  111. 'roles' => Role::whereNotIn('id', [1])
  112. ->get()
  113. ->transform(fn($role) => [
  114. 'label' => $role->name,
  115. 'value' => $role->id,
  116. ]),
  117. ]);
  118. }
  119. /**
  120. * Update the specified resource in storage.
  121. *
  122. * @param \Illuminate\Http\Request $request
  123. * @param User $user
  124. * @return \Illuminate\Http\Response
  125. */
  126. public function update(UpdateUserRequest $request, User $user)
  127. {
  128. $user->update($request->validated());
  129. return back()->with('success', __('messages.success.update.user'));
  130. }
  131. /**
  132. * Remove the specified resource from storage.
  133. *
  134. * @param User $user
  135. * @return \Illuminate\Http\Response
  136. */
  137. public function destroy(User $user)
  138. {
  139. $user->delete();
  140. return to_route('users.index')->with('success', __('messages.success.destroy.user'));
  141. }
  142. /**
  143. * Block user
  144. *
  145. * @param User $user
  146. * @return \Illuminate\Http\Response
  147. */
  148. public function block(User $user)
  149. {
  150. $user->status = !$user->getRawOriginal('status');
  151. $user->update();
  152. if ($user->getRawOriginal('status')) {
  153. $msg = __('messages.user.active_user');
  154. } else {
  155. $msg = __('messages.user.no_active_user');
  156. }
  157. return back()->with('success', $msg);
  158. }
  159. /**
  160. * Change Password
  161. *
  162. * @param \Illuminate\Http\Request $request
  163. * @return \Illuminate\Http\Response
  164. */
  165. public function changePassword(ChangePasswordRequest $request)
  166. {
  167. if (!Hash::check($request->old_password, $request->user()->password)) {
  168. return back()->with('error', __('messages.error.store.change_password'));
  169. }
  170. $request->user()->update(['password' => bcrypt($request->new_password)]);
  171. return back()->with('success', __('messages.success.update.change_password'));
  172. }
  173. }